OMAP: DSS2: rewrite use of context_loss_count
authorTomi Valkeinen <tomi.valkeinen@ti.com>
Mon, 23 May 2011 12:46:54 +0000 (15:46 +0300)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Mon, 25 Jul 2011 07:08:15 +0000 (10:08 +0300)
The function to get device's context loss count has changed from

omap_pm_get_last_off_on_transaction_id() to
omap_pm_get_dev_context_loss_count()

Change name of the function pointer in omapdss.h accordingly, and use
the term "context loss count" instead of "context id" in the code.

Restructure the context loss count functions to handle errors properly,
and ensure that context is always considered lost if an error happens.

Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
arch/arm/mach-omap2/display.c
drivers/video/omap2/dss/dss.c
drivers/video/omap2/dss/dss.h
include/video/omapdss.h

index 543fcb8b518cb227d967f32a03a0ed8d68b63400..084a51b1fb212d106c56a3b8381bc6ecc9cd832a 100644 (file)
@@ -117,7 +117,7 @@ int __init omap_display_init(struct omap_dss_board_info *board_data)
        }
 
        pdata.board_data = board_data;
-       pdata.board_data->get_last_off_on_transaction_id = NULL;
+       pdata.board_data->get_context_loss_count = NULL;
        pdata.opt_clock_available = opt_clock_available;
 
        for (i = 0; i < oh_count; i++) {
index 57ce428deb04b1f880923f8e63fd4ec58a18086e..4f3de3580f53781f4eed4adf5bae8c34c32b9447 100644 (file)
@@ -60,7 +60,7 @@ struct dss_reg {
 static struct {
        struct platform_device *pdev;
        void __iomem    *base;
-       int             ctx_id;
+       int             ctx_loss_cnt;
 
        struct clk      *dpll4_m4_ck;
        struct clk      *dss_ick;
@@ -665,34 +665,58 @@ void dss_select_hdmi_venc_clk_source(enum dss_hdmi_venc_clk_source_select hdmi)
 }
 
 /* CONTEXT */
-static int dss_get_ctx_id(void)
+static void dss_init_ctx_loss_count(void)
 {
-       struct omap_display_platform_data *pdata = dss.pdev->dev.platform_data;
-       int r;
+       struct device *dev = &dss.pdev->dev;
+       struct omap_display_platform_data *pdata = dev->platform_data;
+       struct omap_dss_board_info *board_data = pdata->board_data;
+       int cnt = 0;
 
-       if (!pdata->board_data->get_last_off_on_transaction_id)
-               return 0;
-       r = pdata->board_data->get_last_off_on_transaction_id(&dss.pdev->dev);
-       if (r < 0) {
-               dev_err(&dss.pdev->dev, "getting transaction ID failed, "
-                               "will force context restore\n");
-               r = -1;
-       }
-       return r;
+       /*
+        * get_context_loss_count returns negative on error. We'll ignore the
+        * error and store the error to ctx_loss_cnt, which will cause
+        * dss_need_ctx_restore() call to return true.
+        */
+
+       if (board_data->get_context_loss_count)
+               cnt = board_data->get_context_loss_count(dev);
+
+       WARN_ON(cnt < 0);
+
+       dss.ctx_loss_cnt = cnt;
+
+       DSSDBG("initial ctx_loss_cnt %u\n", cnt);
 }
 
-int dss_need_ctx_restore(void)
+static bool dss_need_ctx_restore(void)
 {
-       int id = dss_get_ctx_id();
+       struct device *dev = &dss.pdev->dev;
+       struct omap_display_platform_data *pdata = dev->platform_data;
+       struct omap_dss_board_info *board_data = pdata->board_data;
+       int cnt;
 
-       if (id < 0 || id != dss.ctx_id) {
-               DSSDBG("ctx id %d -> id %d\n",
-                               dss.ctx_id, id);
-               dss.ctx_id = id;
-               return 1;
-       } else {
-               return 0;
+       /*
+        * If get_context_loss_count is not available, assume that we need
+        * context restore always.
+        */
+       if (!board_data->get_context_loss_count)
+               return true;
+
+       cnt = board_data->get_context_loss_count(dev);
+       if (cnt < 0) {
+               dev_err(dev, "getting context loss count failed, will force "
+                               "context restore\n");
+               dss.ctx_loss_cnt = cnt;
+               return true;
        }
+
+       if (cnt == dss.ctx_loss_cnt)
+               return false;
+
+       DSSDBG("ctx_loss_cnt %d -> %d\n", dss.ctx_loss_cnt, cnt);
+       dss.ctx_loss_cnt = cnt;
+
+       return true;
 }
 
 static void save_all_ctx(void)
@@ -1046,8 +1070,7 @@ static int omap_dsshw_probe(struct platform_device *pdev)
 
        dss_clk_enable_all_no_ctx();
 
-       dss.ctx_id = dss_get_ctx_id();
-       DSSDBG("initial ctx id %u\n", dss.ctx_id);
+       dss_init_ctx_loss_count();
 
        /* disable LCD and DIGIT output. This seems to fix the synclost
         * problem that we get, if the bootloader starts the DSS and
index 0283f48450e60746b48ea8db4c39dbde13401756..ceafe8a0e917d5b876634ce98735f981d43720a4 100644 (file)
@@ -220,7 +220,6 @@ void dss_restore_context(void);
 void dss_clk_enable(enum dss_clock clks);
 void dss_clk_disable(enum dss_clock clks);
 unsigned long dss_clk_get_rate(enum dss_clock clk);
-int dss_need_ctx_restore(void);
 const char *dss_get_generic_clk_source_name(enum omap_dss_clk_source clk_src);
 void dss_dump_clocks(struct seq_file *s);
 
index c804bda059d54c502c29037c45267349265d568d..3a221de244e4a05275002998bcfa48661ca06e19 100644 (file)
@@ -238,7 +238,7 @@ int dsi_vc_send_bta_sync(struct omap_dss_device *dssdev, int channel);
 
 /* Board specific data */
 struct omap_dss_board_info {
-       int (*get_last_off_on_transaction_id)(struct device *dev);
+       int (*get_context_loss_count)(struct device *dev);
        int num_devices;
        struct omap_dss_device **devices;
        struct omap_dss_device *default_device;