linux/drivers/video/omap2/dss
Archit Taneja 02b5ff1a96 OMAPDSS: APPLY: Don't treat an overlay's channel out as shadow bits
An overlay's channel out field isn't a shadow register. The TRM says that it's
taken into effect immediately. This understanding was missing and channel out
was treated as a shadow parameter, and in overlay's private data as extra info.

Program channel out bits directly in dss_ovl_set_manager(). In order to do this
safely, we need to be totally sure that the overlay is disabled in hardware. For
auto update managers, we can assume that the overlay was truly disabled at
dss_ovl_unset_manager() through the wait_pending_extra_info_updates() call.
However, when unsetting manager for an overlay that was previously connected to
a manager in manual update, we can't be sure if the overlay is truly disabled.
That is, op->enabled might not reflect the actual state of the overlay in
hardware. The older manager may require a manual update transfer to truly
disable the overlay. We expect the user of OMAPDSS to take care of this, in
OMAPDSS, we make sure that an overlay's manager isn't unset if there if
extra_info is still dirty for that overlay.

The wrong understanding of channel out bits also explains the reason why we see
sync lost when changing an overlay's manager which was previously connected to a
manual update manager. The following sequence of events caused this:

- When we disable the overlay, no register writes are actually done since the
  manager is manual update, op->enabled is set to false, and the
  extra_info_dirty flag is set. However, in hardware, the overlay is still
  enabled in both shadow and working registers.

- When we unset the manager, the software just configures the overlay's manager
  to point to NULL.

- When we set the overlay to a new manager(which is in auto update) through
  dss_ovl_set_manager, the check  for op->enabled passes, the channel field in
  extra info is set to the new manager. When we do an apply on this manager,
  the new channel out field is set in the hardware immediately, and since the
  overlay enable bit is still set in hardware, the new manager sees that the
  overlay is enabled, and tries to retrieve pixels from it, this leads to sync
  lost as it might be in the middle of processing a frame when we set the
  channel out bit.

The solution to this was to ensure that user space does another update after
disabling the overlay, this actually worked because the overlay was now truly
disabled, and an immediate write to channel out didn't impact since the manager
saw the new overlay as disabled, and doesn't try to retrieve pixels from it.

Remove channel as an extra_info field. Make dss_ovl_unset_manager more strict
about the overlay being disabled when detaching the manager. For overlays
connected to a manual update manager, unset_manager fails if we need another
update to disable the overlay.

We still need to a manual update to ensure the overlay is disabled to get change
the overlay's manager. We could work on doing a dummy update by using DISPC's
capability to gate the different video port signals. This is left for later.

Remove the comment about the sync lost issue.

Signed-off-by: Archit Taneja <archit@ti.com>
Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
2012-11-12 13:52:59 +02:00
..
apply.c OMAPDSS: APPLY: Don't treat an overlay's channel out as shadow bits 2012-11-12 13:52:59 +02:00
core.c OMAPDSS: fix DPI & DSI init order 2012-11-05 11:14:04 +02:00
dispc_coefs.c OMAPDSS: DISPC: Fix FIR coefficients 2012-03-06 14:08:23 +02:00
dispc.c OMAPDSS: DISPC: Use output width and height to calculate row/pix inc for writeback 2012-11-12 13:52:55 +02:00
dispc.h OMAPDSS: DISPC: Add writeback register offsets and dss features structs 2012-09-26 14:58:50 +03:00
display.c OMAPDSS: remove initial display code from omapdss 2012-10-29 12:44:25 +02:00
dpi.c OMAPDSS: DPI: always use DSI PLL if available 2012-11-05 11:17:39 +02:00
dsi.c OMAPDSS: HACK: look for regulators with omap4 names 2012-11-07 10:34:09 +02:00
dss_features.c OMAPDSS: HDMI: Add op to get audio DMA port address offset 2012-11-06 13:33:36 +02:00
dss_features.h OMAPDSS: HDMI: use omapdss_version 2012-10-16 13:44:00 +03:00
dss.c OMAPDSS: hide dss_select_dispc_clk_source() 2012-11-05 11:17:39 +02:00
dss.h OMAPDSS: hide dss_select_dispc_clk_source() 2012-11-05 11:17:39 +02:00
hdmi_panel.c OMAPDSS: HDMI: Make panel return dssdev register errors 2012-11-06 13:33:35 +02:00
hdmi.c OMAPDSS: HACK: look for regulators with omap4 names 2012-11-07 10:34:09 +02:00
Kconfig Merge branch '3.8/dss-version' 2012-10-18 11:02:51 +03:00
Makefile OMAPDSS: Create new debug config options 2012-10-12 14:15:30 +03:00
manager-sysfs.c OMAPDSS: MANAGER: Update display sysfs store 2012-09-26 14:58:37 +03:00
manager.c OMAPDSS: Remove old way of setting manager and device links 2012-09-26 14:58:38 +03:00
output.c OMAPDSS: Create links between managers, outputs and devices 2012-09-26 14:58:33 +03:00
overlay-sysfs.c OMAPDSS: split overlay sysfs code 2012-09-07 20:02:10 +03:00
overlay.c OMAPDSS: OVERLAY/MANAGER: Get device via output 2012-09-26 14:58:37 +03:00
rfbi.c OMAPDSS: export dss_get_def_display_name() 2012-10-29 12:40:46 +02:00
sdi.c OMAPDSS: export dss_get_def_display_name() 2012-10-29 12:40:46 +02:00
ti_hdmi_4xxx_ip.c OMAPDSS: HDMI: Add op to get audio DMA port address offset 2012-11-06 13:33:36 +02:00
ti_hdmi_4xxx_ip.h OMAPDSS: HDMI: Add an audio configuration function 2012-05-11 15:17:08 +03:00
ti_hdmi.h OMAPDSS: HDMI: Add op to get audio DMA port address offset 2012-11-06 13:33:36 +02:00
venc_panel.c OMAPDSS: remove omap_dss_device's suspend/resume 2012-10-24 08:46:23 +03:00
venc.c OMAPDSS: export dss_get_def_display_name() 2012-10-29 12:40:46 +02:00