mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-05 12:13:57 +08:00
OMAPDSS: DISPC: remove OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES
DISPC can drive data lines either on rising or falling pixel clock edge, which can be configured by the user. Sync lines can also be driven on rising or falling pixel clock edge, but additionally the HW can be configured to drive the sync lines on opposite clock edge from the data lines. This opposite edge setting does not make any sense, as the same effect can be achieved by just setting the sync lines to be driven on the other edge compared to the data lines. It feels like some kind of backward compatibility option, even if all DSS versions seem to have the same implementation. To simplify the code and configuration of the signals, and to make the dispc timings more compatible with what is used on other platforms, let's just remove the whole opposite-edge support. The drivers that used OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES setting are changed so that they use the opposite setting from the data edge. Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
This commit is contained in:
parent
6246c8b57c
commit
7a16360d56
@ -102,7 +102,7 @@ void copy_timings_drm_to_omap(struct omap_video_timings *timings,
|
|||||||
|
|
||||||
timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
||||||
timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
||||||
timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES;
|
timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static enum drm_connector_status omap_connector_detect(
|
static enum drm_connector_status omap_connector_detect(
|
||||||
|
@ -37,7 +37,7 @@ static const struct omap_video_timings dvic_default_timings = {
|
|||||||
.hsync_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
.hsync_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
||||||
.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
||||||
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
||||||
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES,
|
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct panel_drv_data {
|
struct panel_drv_data {
|
||||||
|
@ -37,7 +37,7 @@ static struct omap_video_timings lb035q02_timings = {
|
|||||||
.hsync_level = OMAPDSS_SIG_ACTIVE_LOW,
|
.hsync_level = OMAPDSS_SIG_ACTIVE_LOW,
|
||||||
.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
||||||
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
||||||
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES,
|
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct panel_drv_data {
|
struct panel_drv_data {
|
||||||
|
@ -54,7 +54,7 @@ static const struct omap_video_timings sharp_ls_timings = {
|
|||||||
.hsync_level = OMAPDSS_SIG_ACTIVE_LOW,
|
.hsync_level = OMAPDSS_SIG_ACTIVE_LOW,
|
||||||
.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
||||||
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
||||||
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES,
|
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
||||||
};
|
};
|
||||||
|
|
||||||
#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev)
|
#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev)
|
||||||
|
@ -108,7 +108,7 @@ static const struct omap_video_timings acx565akm_panel_timings = {
|
|||||||
|
|
||||||
.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
||||||
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
||||||
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES,
|
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
||||||
};
|
};
|
||||||
|
|
||||||
#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev)
|
#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev)
|
||||||
|
@ -58,7 +58,7 @@ static struct omap_video_timings td028ttec1_panel_timings = {
|
|||||||
|
|
||||||
.data_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
.data_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
||||||
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
||||||
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES,
|
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
||||||
};
|
};
|
||||||
|
|
||||||
#define JBT_COMMAND 0x000
|
#define JBT_COMMAND 0x000
|
||||||
|
@ -91,7 +91,7 @@ static const struct omap_video_timings tpo_td043_timings = {
|
|||||||
.hsync_level = OMAPDSS_SIG_ACTIVE_LOW,
|
.hsync_level = OMAPDSS_SIG_ACTIVE_LOW,
|
||||||
.data_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
.data_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
||||||
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
.de_level = OMAPDSS_SIG_ACTIVE_HIGH,
|
||||||
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES,
|
.sync_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
||||||
};
|
};
|
||||||
|
|
||||||
#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev)
|
#define to_panel_data(p) container_of(p, struct panel_drv_data, dssdev)
|
||||||
|
@ -2934,22 +2934,18 @@ static void _dispc_mgr_set_lcd_timings(enum omap_channel channel, int hsw,
|
|||||||
case OMAPDSS_DRIVE_SIG_FALLING_EDGE:
|
case OMAPDSS_DRIVE_SIG_FALLING_EDGE:
|
||||||
ipc = true;
|
ipc = true;
|
||||||
break;
|
break;
|
||||||
case OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES:
|
|
||||||
default:
|
default:
|
||||||
BUG();
|
BUG();
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (sync_pclk_edge) {
|
/* always use the 'rf' setting */
|
||||||
case OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES:
|
|
||||||
onoff = false;
|
|
||||||
rf = false;
|
|
||||||
break;
|
|
||||||
case OMAPDSS_DRIVE_SIG_FALLING_EDGE:
|
|
||||||
onoff = true;
|
onoff = true;
|
||||||
|
|
||||||
|
switch (sync_pclk_edge) {
|
||||||
|
case OMAPDSS_DRIVE_SIG_FALLING_EDGE:
|
||||||
rf = false;
|
rf = false;
|
||||||
break;
|
break;
|
||||||
case OMAPDSS_DRIVE_SIG_RISING_EDGE:
|
case OMAPDSS_DRIVE_SIG_RISING_EDGE:
|
||||||
onoff = true;
|
|
||||||
rf = true;
|
rf = true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -295,7 +295,9 @@ void videomode_to_omap_video_timings(const struct videomode *vm,
|
|||||||
OMAPDSS_DRIVE_SIG_RISING_EDGE :
|
OMAPDSS_DRIVE_SIG_RISING_EDGE :
|
||||||
OMAPDSS_DRIVE_SIG_FALLING_EDGE;
|
OMAPDSS_DRIVE_SIG_FALLING_EDGE;
|
||||||
|
|
||||||
ovt->sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES;
|
ovt->sync_pclk_edge = vm->flags & DISPLAY_FLAGS_PIXDATA_POSEDGE ?
|
||||||
|
OMAPDSS_DRIVE_SIG_FALLING_EDGE :
|
||||||
|
OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(videomode_to_omap_video_timings);
|
EXPORT_SYMBOL(videomode_to_omap_video_timings);
|
||||||
|
|
||||||
|
@ -4137,7 +4137,7 @@ static int dsi_display_init_dispc(struct platform_device *dsidev,
|
|||||||
dsi->timings.vsync_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
dsi->timings.vsync_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
||||||
dsi->timings.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
dsi->timings.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
||||||
dsi->timings.de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
dsi->timings.de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
||||||
dsi->timings.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES;
|
dsi->timings.sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
|
||||||
|
|
||||||
dss_mgr_set_timings(mgr, &dsi->timings);
|
dss_mgr_set_timings(mgr, &dsi->timings);
|
||||||
|
|
||||||
|
@ -869,7 +869,7 @@ static void rfbi_config_lcd_manager(struct omap_dss_device *dssdev)
|
|||||||
rfbi.timings.vsync_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
rfbi.timings.vsync_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
||||||
rfbi.timings.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
rfbi.timings.data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
||||||
rfbi.timings.de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
rfbi.timings.de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
||||||
rfbi.timings.sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES;
|
rfbi.timings.sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
|
||||||
|
|
||||||
dss_mgr_set_timings(mgr, &rfbi.timings);
|
dss_mgr_set_timings(mgr, &rfbi.timings);
|
||||||
}
|
}
|
||||||
|
@ -2073,7 +2073,7 @@ static int omapfb_mode_to_timings(const char *mode_str,
|
|||||||
} else {
|
} else {
|
||||||
timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
||||||
timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
||||||
timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES;
|
timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
timings->pixelclock = PICOS2KHZ(var->pixclock) * 1000;
|
timings->pixelclock = PICOS2KHZ(var->pixclock) * 1000;
|
||||||
@ -2223,7 +2223,7 @@ static void fb_videomode_to_omap_timings(struct fb_videomode *m,
|
|||||||
} else {
|
} else {
|
||||||
t->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
t->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE;
|
||||||
t->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
t->de_level = OMAPDSS_SIG_ACTIVE_HIGH;
|
||||||
t->sync_pclk_edge = OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES;
|
t->sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
t->x_res = m->xres;
|
t->x_res = m->xres;
|
||||||
|
@ -134,7 +134,6 @@ enum omap_dss_signal_level {
|
|||||||
};
|
};
|
||||||
|
|
||||||
enum omap_dss_signal_edge {
|
enum omap_dss_signal_edge {
|
||||||
OMAPDSS_DRIVE_SIG_OPPOSITE_EDGES,
|
|
||||||
OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
OMAPDSS_DRIVE_SIG_RISING_EDGE,
|
||||||
OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
OMAPDSS_DRIVE_SIG_FALLING_EDGE,
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user