drm/fsl-dcu: mask all interrupts on initialization
authorStefan Agner <stefan@agner.ch>
Thu, 19 Nov 2015 01:27:04 +0000 (17:27 -0800)
committerStefan Agner <stefan@agner.ch>
Fri, 26 Feb 2016 00:13:16 +0000 (16:13 -0800)
The state of the interrupt mask register on initialization is
unknown, e.g. U-Boot could already used the DCU. So depending on
the boot loader, the outcome of the interrupt mask register could
be different. A defined state is much more preferable. Also, there
is no value in keeping interrupts enabled which we don't need.
Therefor, mask all interrupts on initialization.

Signed-off-by: Stefan Agner <stefan@agner.ch>
drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.c

index acb8758b63e2c9b51b6308ac5f79b0d5f4d54d91..e8d9337a66d8704805ad62121714f95be91a340c 100644 (file)
@@ -48,7 +48,6 @@ static const struct regmap_config fsl_dcu_regmap_config = {
 static int fsl_dcu_drm_irq_init(struct drm_device *dev)
 {
        struct fsl_dcu_drm_device *fsl_dev = dev->dev_private;
-       unsigned int value;
        int ret;
 
        ret = drm_irq_install(dev, fsl_dev->irq);
@@ -56,9 +55,7 @@ static int fsl_dcu_drm_irq_init(struct drm_device *dev)
                dev_err(dev->dev, "failed to install IRQ handler\n");
 
        regmap_write(fsl_dev->regmap, DCU_INT_STATUS, 0);
-       regmap_read(fsl_dev->regmap, DCU_INT_MASK, &value);
-       value &= DCU_INT_MASK_VBLANK;
-       regmap_write(fsl_dev->regmap, DCU_INT_MASK, value);
+       regmap_write(fsl_dev->regmap, DCU_INT_MASK, ~0);
        regmap_write(fsl_dev->regmap, DCU_UPDATE_MODE,
                     DCU_UPDATE_MODE_READREG);