#define SN_ENH_FRAME_REG                       0x5A
 #define  VSTREAM_ENABLE                                BIT(3)
 #define SN_DATA_FORMAT_REG                     0x5B
+#define  BPP_18_RGB                            BIT(0)
 #define SN_HPD_DISABLE_REG                     0x5C
 #define  HPD_DISABLE                           BIT(0)
 #define SN_AUX_WDATA_REG(x)                    (0x64 + (x))
        regmap_write(pdata->regmap, SN_DSIA_CLK_FREQ_REG, val);
 }
 
+static unsigned int ti_sn_bridge_get_bpp(struct ti_sn_bridge *pdata)
+{
+       if (pdata->connector.display_info.bpc <= 6)
+               return 18;
+       else
+               return 24;
+}
+
 /**
  * LUT index corresponds to register value and
  * LUT values corresponds to dp data rate supported
 
 static void ti_sn_bridge_set_dp_rate(struct ti_sn_bridge *pdata)
 {
-       unsigned int bit_rate_mhz, dp_rate_mhz;
+       unsigned int bit_rate_khz, dp_rate_mhz;
        unsigned int i;
        struct drm_display_mode *mode =
                &pdata->bridge.encoder->crtc->state->adjusted_mode;
 
-       /*
-        * Calculate minimum bit rate based on our pixel clock.  At
-        * the moment this driver never sets the DP_18BPP_EN bit in
-        * register 0x5b so we hardcode 24bpp.
-        */
-       bit_rate_mhz = (mode->clock / 1000) * 24;
+       /* Calculate minimum bit rate based on our pixel clock. */
+       bit_rate_khz = mode->clock * ti_sn_bridge_get_bpp(pdata);
 
        /* Calculate minimum DP data rate, taking 80% as per DP spec */
-       dp_rate_mhz = ((bit_rate_mhz / pdata->dp_lanes) * DP_CLK_FUDGE_NUM) /
-                                                       DP_CLK_FUDGE_DEN;
+       dp_rate_mhz = DIV_ROUND_UP(bit_rate_khz * DP_CLK_FUDGE_NUM,
+                                  1000 * pdata->dp_lanes * DP_CLK_FUDGE_DEN);
 
        for (i = 1; i < ARRAY_SIZE(ti_sn_bridge_dp_rate_lut) - 1; i++)
                if (ti_sn_bridge_dp_rate_lut[i] > dp_rate_mhz)
        regmap_update_bits(pdata->regmap, SN_DSI_LANES_REG,
                           CHA_DSI_LANES_MASK, val);
 
+       /* Set the DP output format (18 bpp or 24 bpp) */
+       val = (ti_sn_bridge_get_bpp(pdata) == 18) ? BPP_18_RGB : 0;
+       regmap_update_bits(pdata->regmap, SN_DATA_FORMAT_REG, BPP_18_RGB, val);
+
        /* DP lane config */
        val = DP_NUM_LANES(min(pdata->dp_lanes, 3));
        regmap_update_bits(pdata->regmap, SN_SSC_CONFIG_REG, DP_NUM_LANES_MASK,