* @dma_formats        Supported formats for dma pipe
  * @cursor_formats     Supported formats for cursor pipe
  * @vig_formats        Supported formats for vig pipe
+ * @mdss_irqs:         Bitmap with the irqs supported by the target
  */
 struct dpu_mdss_cfg {
        u32 hwversion;
        const struct dpu_format_extended *dma_formats;
        const struct dpu_format_extended *cursor_formats;
        const struct dpu_format_extended *vig_formats;
+
+       unsigned long mdss_irqs;
 };
 
 struct dpu_mdss_hw_cfg_handler {
 
                start_idx = reg_idx * 32;
                end_idx = start_idx + 32;
 
-               if (start_idx >= ARRAY_SIZE(dpu_irq_map) ||
-                               end_idx > ARRAY_SIZE(dpu_irq_map))
+               if (!test_bit(reg_idx, &intr->irq_mask) ||
+                       start_idx >= ARRAY_SIZE(dpu_irq_map))
                        continue;
 
                /*
        if (!intr)
                return -EINVAL;
 
-       for (i = 0; i < ARRAY_SIZE(dpu_intr_set); i++)
-               DPU_REG_WRITE(&intr->hw, dpu_intr_set[i].clr_off, 0xffffffff);
+       for (i = 0; i < ARRAY_SIZE(dpu_intr_set); i++) {
+               if (test_bit(i, &intr->irq_mask))
+                       DPU_REG_WRITE(&intr->hw,
+                                       dpu_intr_set[i].clr_off, 0xffffffff);
+       }
 
        /* ensure register writes go through */
        wmb();
        if (!intr)
                return -EINVAL;
 
-       for (i = 0; i < ARRAY_SIZE(dpu_intr_set); i++)
-               DPU_REG_WRITE(&intr->hw, dpu_intr_set[i].en_off, 0x00000000);
+       for (i = 0; i < ARRAY_SIZE(dpu_intr_set); i++) {
+               if (test_bit(i, &intr->irq_mask))
+                       DPU_REG_WRITE(&intr->hw,
+                                       dpu_intr_set[i].en_off, 0x00000000);
+       }
 
        /* ensure register writes go through */
        wmb();
 
        spin_lock_irqsave(&intr->irq_lock, irq_flags);
        for (i = 0; i < ARRAY_SIZE(dpu_intr_set); i++) {
+               if (!test_bit(i, &intr->irq_mask))
+                       continue;
+
                /* Read interrupt status */
                intr->save_irq_status[i] = DPU_REG_READ(&intr->hw,
                                dpu_intr_set[i].status_off);
                return ERR_PTR(-ENOMEM);
        }
 
+       intr->irq_mask = m->mdss_irqs;
        spin_lock_init(&intr->irq_lock);
 
        return intr;