On Wed, Mar 16, 2016 at 12:21:40PM +0200, Jani Nikula wrote: > A small step moving us closer to DRM MIPI DSI code. Use enum > mipi_dsi_pixel_format instead of our own. The first benefit is being > able to use common mipi_dsi_pixel_format_to_bpp(). > > There's a little back and forth conversion with the VBT -> enum -> > register, since we have just shoved the VBT value into the register > directly. Longer term, all the VBT parsing and deciphering should be > done in intel_bios.c, and abstracted there. > > Signed-off-by: Jani Nikula <jani.nikula@xxxxxxxxx> lgtm Reviewed-by: Ville Syrjälä <ville.syrjala@xxxxxxxxxxxxxxx> > --- > drivers/gpu/drm/i915/intel_dsi.c | 25 +++++++++++++++++----- > drivers/gpu/drm/i915/intel_dsi.h | 10 +++++---- > drivers/gpu/drm/i915/intel_dsi_panel_vbt.c | 33 ++++++++++++++++++++++-------- > drivers/gpu/drm/i915/intel_dsi_pll.c | 30 +++++---------------------- > 4 files changed, 56 insertions(+), 42 deletions(-) > > diff --git a/drivers/gpu/drm/i915/intel_dsi.c b/drivers/gpu/drm/i915/intel_dsi.c > index 01b8e9f4c272..ea78b0bf7e14 100644 > --- a/drivers/gpu/drm/i915/intel_dsi.c > +++ b/drivers/gpu/drm/i915/intel_dsi.c > @@ -787,7 +787,7 @@ static void set_dsi_timings(struct drm_encoder *encoder, > struct drm_i915_private *dev_priv = dev->dev_private; > struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder); > enum port port; > - unsigned int bpp = dsi_pixel_format_bpp(intel_dsi->pixel_format); > + unsigned int bpp = mipi_dsi_pixel_format_to_bpp(intel_dsi->pixel_format); > unsigned int lane_count = intel_dsi->lane_count; > > u16 hactive, hfp, hsync, hbp, vfp, vsync, vbp; > @@ -849,6 +849,23 @@ static void set_dsi_timings(struct drm_encoder *encoder, > } > } > > +static u32 pixel_format_to_reg(enum mipi_dsi_pixel_format fmt) > +{ > + switch (fmt) { > + case MIPI_DSI_FMT_RGB888: > + return VID_MODE_FORMAT_RGB888; > + case MIPI_DSI_FMT_RGB666: > + return VID_MODE_FORMAT_RGB666; > + case MIPI_DSI_FMT_RGB666_PACKED: > + return VID_MODE_FORMAT_RGB666_PACKED; > + case MIPI_DSI_FMT_RGB565: > + return VID_MODE_FORMAT_RGB565; > + default: > + MISSING_CASE(fmt); > + return VID_MODE_FORMAT_RGB666; > + } > +} > + > static void intel_dsi_prepare(struct intel_encoder *intel_encoder) > { > struct drm_encoder *encoder = &intel_encoder->base; > @@ -858,7 +875,7 @@ static void intel_dsi_prepare(struct intel_encoder *intel_encoder) > struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder); > const struct drm_display_mode *adjusted_mode = &intel_crtc->config->base.adjusted_mode; > enum port port; > - unsigned int bpp = dsi_pixel_format_bpp(intel_dsi->pixel_format); > + unsigned int bpp = mipi_dsi_pixel_format_to_bpp(intel_dsi->pixel_format); > u32 val, tmp; > u16 mode_hdisplay; > > @@ -917,9 +934,7 @@ static void intel_dsi_prepare(struct intel_encoder *intel_encoder) > val |= CMD_MODE_DATA_WIDTH_8_BIT; /* XXX */ > } else { > val |= intel_dsi->channel << VID_MODE_CHANNEL_NUMBER_SHIFT; > - > - /* XXX: cross-check bpp vs. pixel format? */ > - val |= intel_dsi->pixel_format; > + val |= pixel_format_to_reg(intel_dsi->pixel_format); > } > > tmp = 0; > diff --git a/drivers/gpu/drm/i915/intel_dsi.h b/drivers/gpu/drm/i915/intel_dsi.h > index 92f39227b361..54f072cd78f1 100644 > --- a/drivers/gpu/drm/i915/intel_dsi.h > +++ b/drivers/gpu/drm/i915/intel_dsi.h > @@ -34,8 +34,6 @@ > #define DSI_DUAL_LINK_FRONT_BACK 1 > #define DSI_DUAL_LINK_PIXEL_ALT 2 > > -int dsi_pixel_format_bpp(int pixel_format); > - > struct intel_dsi_host; > > struct intel_dsi { > @@ -64,8 +62,12 @@ struct intel_dsi { > /* number of DSI lanes */ > unsigned int lane_count; > > - /* video mode pixel format for MIPI_DSI_FUNC_PRG register */ > - u32 pixel_format; > + /* > + * video mode pixel format > + * > + * XXX: consolidate on .format in struct mipi_dsi_device. > + */ > + enum mipi_dsi_pixel_format pixel_format; > > /* video mode format for MIPI_VIDEO_MODE_FORMAT register */ > u32 video_mode_format; > diff --git a/drivers/gpu/drm/i915/intel_dsi_panel_vbt.c b/drivers/gpu/drm/i915/intel_dsi_panel_vbt.c > index 7f145b4fec6a..8302a972d2d4 100644 > --- a/drivers/gpu/drm/i915/intel_dsi_panel_vbt.c > +++ b/drivers/gpu/drm/i915/intel_dsi_panel_vbt.c > @@ -412,6 +412,25 @@ static const struct drm_panel_funcs vbt_panel_funcs = { > .get_modes = vbt_panel_get_modes, > }; > > +/* XXX: This should be done when parsing the VBT in intel_bios.c */ > +static enum mipi_dsi_pixel_format pixel_format_from_vbt(u32 fmt) > +{ > + /* It just so happens the VBT matches register contents. */ > + switch (fmt) { > + case VID_MODE_FORMAT_RGB888: > + return MIPI_DSI_FMT_RGB888; > + case VID_MODE_FORMAT_RGB666: > + return MIPI_DSI_FMT_RGB666; > + case VID_MODE_FORMAT_RGB666_PACKED: > + return MIPI_DSI_FMT_RGB666_PACKED; > + case VID_MODE_FORMAT_RGB565: > + return MIPI_DSI_FMT_RGB565; > + default: > + MISSING_CASE(fmt); > + return MIPI_DSI_FMT_RGB666; > + } > +} > + > struct drm_panel *vbt_panel_init(struct intel_dsi *intel_dsi, u16 panel_id) > { > struct drm_device *dev = intel_dsi->base.base.dev; > @@ -420,7 +439,7 @@ struct drm_panel *vbt_panel_init(struct intel_dsi *intel_dsi, u16 panel_id) > struct mipi_pps_data *pps = dev_priv->vbt.dsi.pps; > struct drm_display_mode *mode = dev_priv->vbt.lfp_lvds_vbt_mode; > struct vbt_panel *vbt_panel; > - u32 bits_per_pixel = 24; > + u32 bpp; > u32 tlpx_ns, extra_byte_count, bitrate, tlpx_ui; > u32 ui_num, ui_den; > u32 prepare_cnt, exit_zero_cnt, clk_zero_cnt, trail_cnt; > @@ -436,12 +455,11 @@ struct drm_panel *vbt_panel_init(struct intel_dsi *intel_dsi, u16 panel_id) > intel_dsi->eotp_pkt = mipi_config->eot_pkt_disabled ? 0 : 1; > intel_dsi->clock_stop = mipi_config->enable_clk_stop ? 1 : 0; > intel_dsi->lane_count = mipi_config->lane_cnt + 1; > - intel_dsi->pixel_format = mipi_config->videomode_color_format << 7; > + intel_dsi->pixel_format = pixel_format_from_vbt(mipi_config->videomode_color_format << 7); > + bpp = mipi_dsi_pixel_format_to_bpp(intel_dsi->pixel_format); > + > intel_dsi->dual_link = mipi_config->dual_link; > intel_dsi->pixel_overlap = mipi_config->pixel_overlap; > - > - bits_per_pixel = dsi_pixel_format_bpp(intel_dsi->pixel_format); > - > intel_dsi->operation_mode = mipi_config->is_cmd_mode; > intel_dsi->video_mode_format = mipi_config->video_transfer_mode; > intel_dsi->escape_clk_div = mipi_config->byte_clk_sel; > @@ -475,8 +493,7 @@ struct drm_panel *vbt_panel_init(struct intel_dsi *intel_dsi, u16 panel_id) > */ > if (intel_dsi->video_mode_format == VIDEO_MODE_BURST) { > if (mipi_config->target_burst_mode_freq) { > - computed_ddr = > - (pclk * bits_per_pixel) / intel_dsi->lane_count; > + computed_ddr = (pclk * bpp) / intel_dsi->lane_count; > > if (mipi_config->target_burst_mode_freq < > computed_ddr) { > @@ -499,7 +516,7 @@ struct drm_panel *vbt_panel_init(struct intel_dsi *intel_dsi, u16 panel_id) > intel_dsi->burst_mode_ratio = burst_mode_ratio; > intel_dsi->pclk = pclk; > > - bitrate = (pclk * bits_per_pixel) / intel_dsi->lane_count; > + bitrate = (pclk * bpp) / intel_dsi->lane_count; > > switch (intel_dsi->escape_clk_div) { > case 0: > diff --git a/drivers/gpu/drm/i915/intel_dsi_pll.c b/drivers/gpu/drm/i915/intel_dsi_pll.c > index 9ef0f7806e4a..e3e343c80221 100644 > --- a/drivers/gpu/drm/i915/intel_dsi_pll.c > +++ b/drivers/gpu/drm/i915/intel_dsi_pll.c > @@ -30,27 +30,6 @@ > #include "i915_drv.h" > #include "intel_dsi.h" > > -int dsi_pixel_format_bpp(int pixel_format) > -{ > - int bpp; > - > - switch (pixel_format) { > - default: > - case VID_MODE_FORMAT_RGB888: > - case VID_MODE_FORMAT_RGB666: > - bpp = 24; > - break; > - case VID_MODE_FORMAT_RGB666_PACKED: > - bpp = 18; > - break; > - case VID_MODE_FORMAT_RGB565: > - bpp = 16; > - break; > - } > - > - return bpp; > -} > - > struct dsi_mnp { > u32 dsi_pll_ctrl; > u32 dsi_pll_div; > @@ -64,10 +43,11 @@ static const u32 lfsr_converts[] = { > }; > > /* Get DSI clock from pixel clock */ > -static u32 dsi_clk_from_pclk(u32 pclk, int pixel_format, int lane_count) > +static u32 dsi_clk_from_pclk(u32 pclk, enum mipi_dsi_pixel_format fmt, > + int lane_count) > { > u32 dsi_clk_khz; > - u32 bpp = dsi_pixel_format_bpp(pixel_format); > + u32 bpp = mipi_dsi_pixel_format_to_bpp(fmt); > > /* DSI data rate = pixel clock * bits per pixel / lane count > pixel clock is converted from KHz to Hz */ > @@ -232,9 +212,9 @@ static void bxt_disable_dsi_pll(struct intel_encoder *encoder) > DRM_ERROR("Timeout waiting for PLL lock deassertion\n"); > } > > -static void assert_bpp_mismatch(int pixel_format, int pipe_bpp) > +static void assert_bpp_mismatch(enum mipi_dsi_pixel_format fmt, int pipe_bpp) > { > - int bpp = dsi_pixel_format_bpp(pixel_format); > + int bpp = mipi_dsi_pixel_format_to_bpp(fmt); > > WARN(bpp != pipe_bpp, > "bpp match assertion failure (expected %d, current %d)\n", > -- > 2.1.4 -- Ville Syrjälä Intel OTC _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx