drivers/video: fsl-diu-fb: clean up reset of primary display
authorTimur Tabi <timur@freescale.com>
Tue, 16 Oct 2012 22:33:48 +0000 (17:33 -0500)
committerTimur Tabi <timur@freescale.com>
Mon, 26 Nov 2012 19:41:20 +0000 (13:41 -0600)
Commit 4b5006ec ("shared DIU framebuffer support") added the ability to
retain the splash screen until the framebuffer is opened by user space.
Clean up this code to eliminate redundant writes to registers, and eliminate
the use of dummy area descriptor.

Signed-off-by: Timur Tabi <timur@freescale.com>
drivers/video/fsl-diu-fb.c

index fa7f20039dd2e5412780c7302102cd5b3e1d4879..37175ac6584abbaef0ea0b84a92ffcf50aad7b1a 100644 (file)
@@ -496,8 +496,7 @@ static void fsl_diu_enable_panel(struct fb_info *info)
 
        switch (mfbi->index) {
        case PLANE0:
-               if (hw->desc[0] != ad->paddr)
-                       wr_reg_wa(&hw->desc[0], ad->paddr);
+               wr_reg_wa(&hw->desc[0], ad->paddr);
                break;
        case PLANE1_AOI0:
                cmfbi = &data->mfb[2];
@@ -549,8 +548,7 @@ static void fsl_diu_disable_panel(struct fb_info *info)
 
        switch (mfbi->index) {
        case PLANE0:
-               if (hw->desc[0] != data->dummy_ad.paddr)
-                       wr_reg_wa(&hw->desc[0], data->dummy_ad.paddr);
+               wr_reg_wa(&hw->desc[0], 0);
                break;
        case PLANE1_AOI0:
                cmfbi = &data->mfb[2];
@@ -1519,7 +1517,6 @@ static int __devinit fsl_diu_probe(struct platform_device *pdev)
        struct device_node *np = pdev->dev.of_node;
        struct mfb_info *mfbi;
        struct fsl_diu_data *data;
-       int diu_mode;
        dma_addr_t dma_addr; /* DMA addr of fsl_diu_data struct */
        unsigned int i;
        int ret;
@@ -1584,10 +1581,6 @@ static int __devinit fsl_diu_probe(struct platform_device *pdev)
                goto error;
        }
 
-       diu_mode = in_be32(&data->diu_reg->diu_mode);
-       if (diu_mode == MFB_MODE0)
-               out_be32(&data->diu_reg->diu_mode, 0); /* disable DIU */
-
        /* Get the IRQ of the DIU */
        data->irq = irq_of_parse_and_map(np, 0);
 
@@ -1609,11 +1602,11 @@ static int __devinit fsl_diu_probe(struct platform_device *pdev)
        data->dummy_ad.paddr = DMA_ADDR(data, dummy_ad);
 
        /*
-        * Let DIU display splash screen if it was pre-initialized
-        * by the bootloader, set dummy area descriptor otherwise.
+        * Let DIU continue to display splash screen if it was pre-initialized
+        * by the bootloader; otherwise, clear the display.
         */
-       if (diu_mode == MFB_MODE0)
-               out_be32(&data->diu_reg->desc[0], data->dummy_ad.paddr);
+       if (in_be32(&data->diu_reg->diu_mode) == MFB_MODE0)
+               out_be32(&data->diu_reg->desc[0], 0);
 
        out_be32(&data->diu_reg->desc[1], data->dummy_ad.paddr);
        out_be32(&data->diu_reg->desc[2], data->dummy_ad.paddr);