提交 bf213523 编写于 作者: T Tomi Valkeinen

OMAPDSS: APPLY: move mgr->enabled to mgr_priv_data

struct omap_overlay_manager contains "enabled"-field, used to track if
the manager is enabled or not. This field should be internal to apply.c.

This patch moves the field to mgr_priv_data, and applies the necessary
locking when accessing the field.
Signed-off-by: NTomi Valkeinen <tomi.valkeinen@ti.com>
上级 9a147a65
...@@ -86,6 +86,9 @@ struct mgr_priv_data { ...@@ -86,6 +86,9 @@ struct mgr_priv_data {
bool manual_update; bool manual_update;
bool do_manual_update; bool do_manual_update;
/* If true, a display is enabled using this manager */
bool enabled;
}; };
static struct { static struct {
...@@ -609,6 +612,7 @@ int omap_dss_mgr_apply(struct omap_overlay_manager *mgr) ...@@ -609,6 +612,7 @@ int omap_dss_mgr_apply(struct omap_overlay_manager *mgr)
int r; int r;
unsigned long flags; unsigned long flags;
struct omap_overlay *ovl; struct omap_overlay *ovl;
struct mgr_priv_data *mp = get_mgr_priv(mgr);
DSSDBG("omap_dss_mgr_apply(%s)\n", mgr->name); DSSDBG("omap_dss_mgr_apply(%s)\n", mgr->name);
...@@ -630,7 +634,7 @@ int omap_dss_mgr_apply(struct omap_overlay_manager *mgr) ...@@ -630,7 +634,7 @@ int omap_dss_mgr_apply(struct omap_overlay_manager *mgr)
omap_dss_mgr_apply_ovl_fifos(ovl); omap_dss_mgr_apply_ovl_fifos(ovl);
r = 0; r = 0;
if (mgr->enabled && !mgr_manual_update(mgr)) { if (mp->enabled && !mgr_manual_update(mgr)) {
if (!dss_data.irq_enabled) if (!dss_data.irq_enabled)
dss_register_vsync_isr(); dss_register_vsync_isr();
...@@ -646,22 +650,38 @@ int omap_dss_mgr_apply(struct omap_overlay_manager *mgr) ...@@ -646,22 +650,38 @@ int omap_dss_mgr_apply(struct omap_overlay_manager *mgr)
void dss_mgr_enable(struct omap_overlay_manager *mgr) void dss_mgr_enable(struct omap_overlay_manager *mgr)
{ {
struct mgr_priv_data *mp = get_mgr_priv(mgr);
unsigned long flags;
mutex_lock(&apply_lock); mutex_lock(&apply_lock);
if (!mgr_manual_update(mgr)) if (!mgr_manual_update(mgr))
dispc_mgr_enable(mgr->id, true); dispc_mgr_enable(mgr->id, true);
mgr->enabled = true;
spin_lock_irqsave(&data_lock, flags);
mp->enabled = true;
spin_unlock_irqrestore(&data_lock, flags);
mutex_unlock(&apply_lock); mutex_unlock(&apply_lock);
} }
void dss_mgr_disable(struct omap_overlay_manager *mgr) void dss_mgr_disable(struct omap_overlay_manager *mgr)
{ {
struct mgr_priv_data *mp = get_mgr_priv(mgr);
unsigned long flags;
mutex_lock(&apply_lock); mutex_lock(&apply_lock);
if (!mgr_manual_update(mgr)) if (!mgr_manual_update(mgr))
dispc_mgr_enable(mgr->id, false); dispc_mgr_enable(mgr->id, false);
mgr->enabled = false;
spin_lock_irqsave(&data_lock, flags);
mp->enabled = false;
spin_unlock_irqrestore(&data_lock, flags);
mutex_unlock(&apply_lock); mutex_unlock(&apply_lock);
} }
......
...@@ -430,8 +430,6 @@ struct omap_overlay_manager { ...@@ -430,8 +430,6 @@ struct omap_overlay_manager {
struct omap_dss_device *device; struct omap_dss_device *device;
struct omap_overlay_manager_info info; struct omap_overlay_manager_info info;
bool enabled;
bool device_changed; bool device_changed;
/* if true, info has been changed but not applied() yet */ /* if true, info has been changed but not applied() yet */
bool info_dirty; bool info_dirty;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册