forked from Minki/linux
OMAPDSS: OVERLAY: Clean up replication checking
Replication logic for an overlay depends on the color mode in which it is configured and the video port width of the manager it is connected to. video port width now held in dss_lcd_mgr_config in the manager's private data in APPLY. Use this instead of referring to the omap_dss_device connected to the manager. Replication is enabled in the case of TV manager, the video_port_width is set to a default value of 24 for TV manager. Make the replication checking an overlay function since it's more of an overlay characteristic than a display characteristic. Signed-off-by: Archit Taneja <archit@ti.com>
This commit is contained in:
parent
c47cdb3088
commit
6c6f510afb
@ -571,7 +571,7 @@ static void dss_ovl_write_regs(struct omap_overlay *ovl)
|
|||||||
|
|
||||||
mp = get_mgr_priv(ovl->manager);
|
mp = get_mgr_priv(ovl->manager);
|
||||||
|
|
||||||
replication = dss_use_replication(ovl->manager->device, oi->color_mode);
|
replication = dss_ovl_use_replication(mp->lcd_config, oi->color_mode);
|
||||||
|
|
||||||
r = dispc_ovl_setup(ovl->id, oi, replication, &mp->timings);
|
r = dispc_ovl_setup(ovl->id, oi, replication, &mp->timings);
|
||||||
if (r) {
|
if (r) {
|
||||||
|
@ -316,40 +316,6 @@ void omapdss_default_get_timings(struct omap_dss_device *dssdev,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(omapdss_default_get_timings);
|
EXPORT_SYMBOL(omapdss_default_get_timings);
|
||||||
|
|
||||||
/* Checks if replication logic should be used. Only use for active matrix,
|
|
||||||
* when overlay is in RGB12U or RGB16 mode, and LCD interface is
|
|
||||||
* 18bpp or 24bpp */
|
|
||||||
bool dss_use_replication(struct omap_dss_device *dssdev,
|
|
||||||
enum omap_color_mode mode)
|
|
||||||
{
|
|
||||||
int bpp;
|
|
||||||
|
|
||||||
if (mode != OMAP_DSS_COLOR_RGB12U && mode != OMAP_DSS_COLOR_RGB16)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
switch (dssdev->type) {
|
|
||||||
case OMAP_DISPLAY_TYPE_DPI:
|
|
||||||
bpp = dssdev->phy.dpi.data_lines;
|
|
||||||
break;
|
|
||||||
case OMAP_DISPLAY_TYPE_HDMI:
|
|
||||||
case OMAP_DISPLAY_TYPE_VENC:
|
|
||||||
case OMAP_DISPLAY_TYPE_SDI:
|
|
||||||
bpp = 24;
|
|
||||||
break;
|
|
||||||
case OMAP_DISPLAY_TYPE_DBI:
|
|
||||||
bpp = dssdev->ctrl.pixel_size;
|
|
||||||
break;
|
|
||||||
case OMAP_DISPLAY_TYPE_DSI:
|
|
||||||
bpp = dsi_get_pixel_size(dssdev->panel.dsi_pix_fmt);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
BUG();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return bpp > 16;
|
|
||||||
}
|
|
||||||
|
|
||||||
void dss_init_device(struct platform_device *pdev,
|
void dss_init_device(struct platform_device *pdev,
|
||||||
struct omap_dss_device *dssdev)
|
struct omap_dss_device *dssdev)
|
||||||
{
|
{
|
||||||
|
@ -231,8 +231,6 @@ void dss_init_device(struct platform_device *pdev,
|
|||||||
struct omap_dss_device *dssdev);
|
struct omap_dss_device *dssdev);
|
||||||
void dss_uninit_device(struct platform_device *pdev,
|
void dss_uninit_device(struct platform_device *pdev,
|
||||||
struct omap_dss_device *dssdev);
|
struct omap_dss_device *dssdev);
|
||||||
bool dss_use_replication(struct omap_dss_device *dssdev,
|
|
||||||
enum omap_color_mode mode);
|
|
||||||
|
|
||||||
/* manager */
|
/* manager */
|
||||||
int dss_init_overlay_managers(struct platform_device *pdev);
|
int dss_init_overlay_managers(struct platform_device *pdev);
|
||||||
@ -265,6 +263,8 @@ int dss_ovl_simple_check(struct omap_overlay *ovl,
|
|||||||
const struct omap_overlay_info *info);
|
const struct omap_overlay_info *info);
|
||||||
int dss_ovl_check(struct omap_overlay *ovl, struct omap_overlay_info *info,
|
int dss_ovl_check(struct omap_overlay *ovl, struct omap_overlay_info *info,
|
||||||
const struct omap_video_timings *mgr_timings);
|
const struct omap_video_timings *mgr_timings);
|
||||||
|
bool dss_ovl_use_replication(struct dss_lcd_mgr_config config,
|
||||||
|
enum omap_color_mode mode);
|
||||||
|
|
||||||
/* DSS */
|
/* DSS */
|
||||||
int dss_init_platform_driver(void) __init;
|
int dss_init_platform_driver(void) __init;
|
||||||
|
@ -687,3 +687,16 @@ int dss_ovl_check(struct omap_overlay *ovl, struct omap_overlay_info *info,
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Checks if replication logic should be used. Only use when overlay is in
|
||||||
|
* RGB12U or RGB16 mode, and video port width interface is 18bpp or 24bpp
|
||||||
|
*/
|
||||||
|
bool dss_ovl_use_replication(struct dss_lcd_mgr_config config,
|
||||||
|
enum omap_color_mode mode)
|
||||||
|
{
|
||||||
|
if (mode != OMAP_DSS_COLOR_RGB12U && mode != OMAP_DSS_COLOR_RGB16)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return config.video_port_width > 16;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user