diff options
-rw-r--r-- | arch/arm/plat-omap/include/plat/display.h | 3 | ||||
-rw-r--r-- | drivers/video/omap2/dss/dispc.c | 24 | ||||
-rw-r--r-- | drivers/video/omap2/dss/dpi.c | 14 | ||||
-rw-r--r-- | drivers/video/omap2/dss/dsi.c | 2 | ||||
-rw-r--r-- | drivers/video/omap2/dss/dss.h | 4 | ||||
-rw-r--r-- | drivers/video/omap2/dss/manager.c | 17 | ||||
-rw-r--r-- | drivers/video/omap2/dss/rfbi.c | 2 | ||||
-rw-r--r-- | drivers/video/omap2/dss/sdi.c | 14 | ||||
-rw-r--r-- | drivers/video/omap2/dss/venc.c | 4 |
9 files changed, 61 insertions, 23 deletions
diff --git a/arch/arm/plat-omap/include/plat/display.h b/arch/arm/plat-omap/include/plat/display.h index 059b35cfd125..f05098dd5d5c 100644 --- a/arch/arm/plat-omap/include/plat/display.h +++ b/arch/arm/plat-omap/include/plat/display.h | |||
@@ -371,6 +371,9 @@ struct omap_overlay_manager { | |||
371 | int (*apply)(struct omap_overlay_manager *mgr); | 371 | int (*apply)(struct omap_overlay_manager *mgr); |
372 | int (*wait_for_go)(struct omap_overlay_manager *mgr); | 372 | int (*wait_for_go)(struct omap_overlay_manager *mgr); |
373 | int (*wait_for_vsync)(struct omap_overlay_manager *mgr); | 373 | int (*wait_for_vsync)(struct omap_overlay_manager *mgr); |
374 | |||
375 | int (*enable)(struct omap_overlay_manager *mgr); | ||
376 | int (*disable)(struct omap_overlay_manager *mgr); | ||
374 | }; | 377 | }; |
375 | 378 | ||
376 | struct omap_dss_device { | 379 | struct omap_dss_device { |
diff --git a/drivers/video/omap2/dss/dispc.c b/drivers/video/omap2/dss/dispc.c index 212cb800a5d2..5a5c31c163c7 100644 --- a/drivers/video/omap2/dss/dispc.c +++ b/drivers/video/omap2/dss/dispc.c | |||
@@ -1725,7 +1725,7 @@ static void _enable_lcd_out(bool enable) | |||
1725 | REG_FLD_MOD(DISPC_CONTROL, enable ? 1 : 0, 0, 0); | 1725 | REG_FLD_MOD(DISPC_CONTROL, enable ? 1 : 0, 0, 0); |
1726 | } | 1726 | } |
1727 | 1727 | ||
1728 | void dispc_enable_lcd_out(bool enable) | 1728 | static void dispc_enable_lcd_out(bool enable) |
1729 | { | 1729 | { |
1730 | struct completion frame_done_completion; | 1730 | struct completion frame_done_completion; |
1731 | bool is_on; | 1731 | bool is_on; |
@@ -1772,7 +1772,7 @@ static void _enable_digit_out(bool enable) | |||
1772 | REG_FLD_MOD(DISPC_CONTROL, enable ? 1 : 0, 1, 1); | 1772 | REG_FLD_MOD(DISPC_CONTROL, enable ? 1 : 0, 1, 1); |
1773 | } | 1773 | } |
1774 | 1774 | ||
1775 | void dispc_enable_digit_out(bool enable) | 1775 | static void dispc_enable_digit_out(bool enable) |
1776 | { | 1776 | { |
1777 | struct completion frame_done_completion; | 1777 | struct completion frame_done_completion; |
1778 | int r; | 1778 | int r; |
@@ -1836,6 +1836,26 @@ void dispc_enable_digit_out(bool enable) | |||
1836 | enable_clocks(0); | 1836 | enable_clocks(0); |
1837 | } | 1837 | } |
1838 | 1838 | ||
1839 | bool dispc_is_channel_enabled(enum omap_channel channel) | ||
1840 | { | ||
1841 | if (channel == OMAP_DSS_CHANNEL_LCD) | ||
1842 | return !!REG_GET(DISPC_CONTROL, 0, 0); | ||
1843 | else if (channel == OMAP_DSS_CHANNEL_DIGIT) | ||
1844 | return !!REG_GET(DISPC_CONTROL, 1, 1); | ||
1845 | else | ||
1846 | BUG(); | ||
1847 | } | ||
1848 | |||
1849 | void dispc_enable_channel(enum omap_channel channel, bool enable) | ||
1850 | { | ||
1851 | if (channel == OMAP_DSS_CHANNEL_LCD) | ||
1852 | dispc_enable_lcd_out(enable); | ||
1853 | else if (channel == OMAP_DSS_CHANNEL_DIGIT) | ||
1854 | dispc_enable_digit_out(enable); | ||
1855 | else | ||
1856 | BUG(); | ||
1857 | } | ||
1858 | |||
1839 | void dispc_lcd_enable_signal_polarity(bool act_high) | 1859 | void dispc_lcd_enable_signal_polarity(bool act_high) |
1840 | { | 1860 | { |
1841 | enable_clocks(1); | 1861 | enable_clocks(1); |
diff --git a/drivers/video/omap2/dss/dpi.c b/drivers/video/omap2/dss/dpi.c index c5091ed12a7d..77b95577ab30 100644 --- a/drivers/video/omap2/dss/dpi.c +++ b/drivers/video/omap2/dss/dpi.c | |||
@@ -194,7 +194,7 @@ static int dpi_display_enable(struct omap_dss_device *dssdev) | |||
194 | 194 | ||
195 | mdelay(2); | 195 | mdelay(2); |
196 | 196 | ||
197 | dispc_enable_lcd_out(1); | 197 | dssdev->manager->enable(dssdev->manager); |
198 | 198 | ||
199 | r = dssdev->driver->enable(dssdev); | 199 | r = dssdev->driver->enable(dssdev); |
200 | if (r) | 200 | if (r) |
@@ -205,7 +205,7 @@ static int dpi_display_enable(struct omap_dss_device *dssdev) | |||
205 | return 0; | 205 | return 0; |
206 | 206 | ||
207 | err6: | 207 | err6: |
208 | dispc_enable_lcd_out(0); | 208 | dssdev->manager->disable(dssdev->manager); |
209 | err5: | 209 | err5: |
210 | #ifdef CONFIG_OMAP2_DSS_USE_DSI_PLL | 210 | #ifdef CONFIG_OMAP2_DSS_USE_DSI_PLL |
211 | dsi_pll_uninit(); | 211 | dsi_pll_uninit(); |
@@ -235,7 +235,7 @@ static void dpi_display_disable(struct omap_dss_device *dssdev) | |||
235 | 235 | ||
236 | dssdev->driver->disable(dssdev); | 236 | dssdev->driver->disable(dssdev); |
237 | 237 | ||
238 | dispc_enable_lcd_out(0); | 238 | dssdev->manager->disable(dssdev->manager); |
239 | 239 | ||
240 | #ifdef CONFIG_OMAP2_DSS_USE_DSI_PLL | 240 | #ifdef CONFIG_OMAP2_DSS_USE_DSI_PLL |
241 | dss_select_dispc_clk_source(DSS_SRC_DSS1_ALWON_FCLK); | 241 | dss_select_dispc_clk_source(DSS_SRC_DSS1_ALWON_FCLK); |
@@ -263,7 +263,7 @@ static int dpi_display_suspend(struct omap_dss_device *dssdev) | |||
263 | if (dssdev->driver->suspend) | 263 | if (dssdev->driver->suspend) |
264 | dssdev->driver->suspend(dssdev); | 264 | dssdev->driver->suspend(dssdev); |
265 | 265 | ||
266 | dispc_enable_lcd_out(0); | 266 | dssdev->manager->disable(dssdev->manager); |
267 | 267 | ||
268 | dss_clk_disable(DSS_CLK_ICK | DSS_CLK_FCK1); | 268 | dss_clk_disable(DSS_CLK_ICK | DSS_CLK_FCK1); |
269 | 269 | ||
@@ -292,7 +292,7 @@ static int dpi_display_resume(struct omap_dss_device *dssdev) | |||
292 | 292 | ||
293 | dss_clk_enable(DSS_CLK_ICK | DSS_CLK_FCK1); | 293 | dss_clk_enable(DSS_CLK_ICK | DSS_CLK_FCK1); |
294 | 294 | ||
295 | dispc_enable_lcd_out(1); | 295 | dssdev->manager->enable(dssdev->manager); |
296 | 296 | ||
297 | if (dssdev->driver->resume) | 297 | if (dssdev->driver->resume) |
298 | dssdev->driver->resume(dssdev); | 298 | dssdev->driver->resume(dssdev); |
@@ -383,10 +383,10 @@ static int dpi_display_set_update_mode(struct omap_dss_device *dssdev, | |||
383 | return -EINVAL; | 383 | return -EINVAL; |
384 | 384 | ||
385 | if (mode == OMAP_DSS_UPDATE_DISABLED) { | 385 | if (mode == OMAP_DSS_UPDATE_DISABLED) { |
386 | dispc_enable_lcd_out(0); | 386 | dssdev->manager->disable(dssdev->manager); |
387 | dpi.update_enabled = 0; | 387 | dpi.update_enabled = 0; |
388 | } else { | 388 | } else { |
389 | dispc_enable_lcd_out(1); | 389 | dssdev->manager->enable(dssdev->manager); |
390 | dpi.update_enabled = 1; | 390 | dpi.update_enabled = 1; |
391 | } | 391 | } |
392 | 392 | ||
diff --git a/drivers/video/omap2/dss/dsi.c b/drivers/video/omap2/dss/dsi.c index 82733d18c0ac..b478a506e038 100644 --- a/drivers/video/omap2/dss/dsi.c +++ b/drivers/video/omap2/dss/dsi.c | |||
@@ -3013,7 +3013,7 @@ static int dsi_update_thread(void *data) | |||
3013 | x, y, w, h); | 3013 | x, y, w, h); |
3014 | 3014 | ||
3015 | dispc_enable_sidle(); | 3015 | dispc_enable_sidle(); |
3016 | dispc_enable_lcd_out(0); | 3016 | device->manager->disable(device->manager); |
3017 | 3017 | ||
3018 | dsi_reset_tx_fifo(0); | 3018 | dsi_reset_tx_fifo(0); |
3019 | } else { | 3019 | } else { |
diff --git a/drivers/video/omap2/dss/dss.h b/drivers/video/omap2/dss/dss.h index 3713dc698259..24326a5fd292 100644 --- a/drivers/video/omap2/dss/dss.h +++ b/drivers/video/omap2/dss/dss.h | |||
@@ -324,8 +324,8 @@ int dispc_setup_plane(enum omap_plane plane, | |||
324 | 324 | ||
325 | bool dispc_go_busy(enum omap_channel channel); | 325 | bool dispc_go_busy(enum omap_channel channel); |
326 | void dispc_go(enum omap_channel channel); | 326 | void dispc_go(enum omap_channel channel); |
327 | void dispc_enable_lcd_out(bool enable); | 327 | void dispc_enable_channel(enum omap_channel channel, bool enable); |
328 | void dispc_enable_digit_out(bool enable); | 328 | bool dispc_is_channel_enabled(enum omap_channel channel); |
329 | int dispc_enable_plane(enum omap_plane plane, bool enable); | 329 | int dispc_enable_plane(enum omap_plane plane, bool enable); |
330 | void dispc_enable_replication(enum omap_plane plane, bool enable); | 330 | void dispc_enable_replication(enum omap_plane plane, bool enable); |
331 | 331 | ||
diff --git a/drivers/video/omap2/dss/manager.c b/drivers/video/omap2/dss/manager.c index 486cd4aec652..4ede519c0a31 100644 --- a/drivers/video/omap2/dss/manager.c +++ b/drivers/video/omap2/dss/manager.c | |||
@@ -1077,7 +1077,7 @@ void dss_start_update(struct omap_dss_device *dssdev) | |||
1077 | mc->shadow_dirty = false; | 1077 | mc->shadow_dirty = false; |
1078 | } | 1078 | } |
1079 | 1079 | ||
1080 | dispc_enable_lcd_out(1); | 1080 | dssdev->manager->enable(dssdev->manager); |
1081 | } | 1081 | } |
1082 | 1082 | ||
1083 | static void dss_apply_irq_handler(void *data, u32 mask) | 1083 | static void dss_apply_irq_handler(void *data, u32 mask) |
@@ -1364,6 +1364,18 @@ static void omap_dss_mgr_get_info(struct omap_overlay_manager *mgr, | |||
1364 | *info = mgr->info; | 1364 | *info = mgr->info; |
1365 | } | 1365 | } |
1366 | 1366 | ||
1367 | static int dss_mgr_enable(struct omap_overlay_manager *mgr) | ||
1368 | { | ||
1369 | dispc_enable_channel(mgr->id, 1); | ||
1370 | return 0; | ||
1371 | } | ||
1372 | |||
1373 | static int dss_mgr_disable(struct omap_overlay_manager *mgr) | ||
1374 | { | ||
1375 | dispc_enable_channel(mgr->id, 0); | ||
1376 | return 0; | ||
1377 | } | ||
1378 | |||
1367 | static void omap_dss_add_overlay_manager(struct omap_overlay_manager *manager) | 1379 | static void omap_dss_add_overlay_manager(struct omap_overlay_manager *manager) |
1368 | { | 1380 | { |
1369 | ++num_managers; | 1381 | ++num_managers; |
@@ -1409,6 +1421,9 @@ int dss_init_overlay_managers(struct platform_device *pdev) | |||
1409 | mgr->wait_for_go = &dss_mgr_wait_for_go; | 1421 | mgr->wait_for_go = &dss_mgr_wait_for_go; |
1410 | mgr->wait_for_vsync = &dss_mgr_wait_for_vsync; | 1422 | mgr->wait_for_vsync = &dss_mgr_wait_for_vsync; |
1411 | 1423 | ||
1424 | mgr->enable = &dss_mgr_enable; | ||
1425 | mgr->disable = &dss_mgr_disable; | ||
1426 | |||
1412 | mgr->caps = OMAP_DSS_OVL_MGR_CAP_DISPC; | 1427 | mgr->caps = OMAP_DSS_OVL_MGR_CAP_DISPC; |
1413 | 1428 | ||
1414 | dss_overlay_setup_dispc_manager(mgr); | 1429 | dss_overlay_setup_dispc_manager(mgr); |
diff --git a/drivers/video/omap2/dss/rfbi.c b/drivers/video/omap2/dss/rfbi.c index b936495c065d..6b9cd767c7c1 100644 --- a/drivers/video/omap2/dss/rfbi.c +++ b/drivers/video/omap2/dss/rfbi.c | |||
@@ -382,7 +382,7 @@ void rfbi_transfer_area(u16 width, u16 height, | |||
382 | 382 | ||
383 | dispc_set_lcd_size(width, height); | 383 | dispc_set_lcd_size(width, height); |
384 | 384 | ||
385 | dispc_enable_lcd_out(1); | 385 | dispc_enable_channel(OMAP_DSS_CHANNEL_LCD, true); |
386 | 386 | ||
387 | rfbi.framedone_callback = callback; | 387 | rfbi.framedone_callback = callback; |
388 | rfbi.framedone_callback_data = data; | 388 | rfbi.framedone_callback_data = data; |
diff --git a/drivers/video/omap2/dss/sdi.c b/drivers/video/omap2/dss/sdi.c index c24f307d3da1..5f852edd4cbc 100644 --- a/drivers/video/omap2/dss/sdi.c +++ b/drivers/video/omap2/dss/sdi.c | |||
@@ -119,7 +119,7 @@ static int sdi_display_enable(struct omap_dss_device *dssdev) | |||
119 | mdelay(2); | 119 | mdelay(2); |
120 | } | 120 | } |
121 | 121 | ||
122 | dispc_enable_lcd_out(1); | 122 | dssdev->manager->enable(dssdev->manager); |
123 | 123 | ||
124 | if (dssdev->driver->enable) { | 124 | if (dssdev->driver->enable) { |
125 | r = dssdev->driver->enable(dssdev); | 125 | r = dssdev->driver->enable(dssdev); |
@@ -133,7 +133,7 @@ static int sdi_display_enable(struct omap_dss_device *dssdev) | |||
133 | 133 | ||
134 | return 0; | 134 | return 0; |
135 | err3: | 135 | err3: |
136 | dispc_enable_lcd_out(0); | 136 | dssdev->manager->disable(dssdev->manager); |
137 | err2: | 137 | err2: |
138 | dss_clk_disable(DSS_CLK_ICK | DSS_CLK_FCK1); | 138 | dss_clk_disable(DSS_CLK_ICK | DSS_CLK_FCK1); |
139 | err1: | 139 | err1: |
@@ -156,7 +156,7 @@ static void sdi_display_disable(struct omap_dss_device *dssdev) | |||
156 | if (dssdev->driver->disable) | 156 | if (dssdev->driver->disable) |
157 | dssdev->driver->disable(dssdev); | 157 | dssdev->driver->disable(dssdev); |
158 | 158 | ||
159 | dispc_enable_lcd_out(0); | 159 | dssdev->manager->disable(dssdev->manager); |
160 | 160 | ||
161 | dss_sdi_disable(); | 161 | dss_sdi_disable(); |
162 | 162 | ||
@@ -175,7 +175,7 @@ static int sdi_display_suspend(struct omap_dss_device *dssdev) | |||
175 | if (dssdev->driver->suspend) | 175 | if (dssdev->driver->suspend) |
176 | dssdev->driver->suspend(dssdev); | 176 | dssdev->driver->suspend(dssdev); |
177 | 177 | ||
178 | dispc_enable_lcd_out(0); | 178 | dssdev->manager->disable(dssdev->manager); |
179 | 179 | ||
180 | dss_sdi_disable(); | 180 | dss_sdi_disable(); |
181 | 181 | ||
@@ -200,7 +200,7 @@ static int sdi_display_resume(struct omap_dss_device *dssdev) | |||
200 | goto err; | 200 | goto err; |
201 | mdelay(2); | 201 | mdelay(2); |
202 | 202 | ||
203 | dispc_enable_lcd_out(1); | 203 | dssdev->manager->enable(dssdev->manager); |
204 | 204 | ||
205 | if (dssdev->driver->resume) | 205 | if (dssdev->driver->resume) |
206 | dssdev->driver->resume(dssdev); | 206 | dssdev->driver->resume(dssdev); |
@@ -220,10 +220,10 @@ static int sdi_display_set_update_mode(struct omap_dss_device *dssdev, | |||
220 | return -EINVAL; | 220 | return -EINVAL; |
221 | 221 | ||
222 | if (mode == OMAP_DSS_UPDATE_DISABLED) { | 222 | if (mode == OMAP_DSS_UPDATE_DISABLED) { |
223 | dispc_enable_lcd_out(0); | 223 | dssdev->manager->disable(dssdev->manager); |
224 | sdi.update_enabled = 0; | 224 | sdi.update_enabled = 0; |
225 | } else { | 225 | } else { |
226 | dispc_enable_lcd_out(1); | 226 | dssdev->manager->enable(dssdev->manager); |
227 | sdi.update_enabled = 1; | 227 | sdi.update_enabled = 1; |
228 | } | 228 | } |
229 | 229 | ||
diff --git a/drivers/video/omap2/dss/venc.c b/drivers/video/omap2/dss/venc.c index 44b4998c2052..4e6bd1dc8021 100644 --- a/drivers/video/omap2/dss/venc.c +++ b/drivers/video/omap2/dss/venc.c | |||
@@ -538,7 +538,7 @@ static void venc_power_on(struct omap_dss_device *dssdev) | |||
538 | if (dssdev->platform_enable) | 538 | if (dssdev->platform_enable) |
539 | dssdev->platform_enable(dssdev); | 539 | dssdev->platform_enable(dssdev); |
540 | 540 | ||
541 | dispc_enable_digit_out(1); | 541 | dssdev->manager->enable(dssdev->manager); |
542 | } | 542 | } |
543 | 543 | ||
544 | static void venc_power_off(struct omap_dss_device *dssdev) | 544 | static void venc_power_off(struct omap_dss_device *dssdev) |
@@ -546,7 +546,7 @@ static void venc_power_off(struct omap_dss_device *dssdev) | |||
546 | venc_write_reg(VENC_OUTPUT_CONTROL, 0); | 546 | venc_write_reg(VENC_OUTPUT_CONTROL, 0); |
547 | dss_set_dac_pwrdn_bgz(0); | 547 | dss_set_dac_pwrdn_bgz(0); |
548 | 548 | ||
549 | dispc_enable_digit_out(0); | 549 | dssdev->manager->disable(dssdev->manager); |
550 | 550 | ||
551 | if (dssdev->platform_disable) | 551 | if (dssdev->platform_disable) |
552 | dssdev->platform_disable(dssdev); | 552 | dssdev->platform_disable(dssdev); |