tim2 = readl(priv->regs + CLCD_TIM2);
        tim2 &= (TIM2_BCD | TIM2_PCD_LO_MASK | TIM2_PCD_HI_MASK);
 
+       if (priv->variant->broken_clockdivider)
+               tim2 |= TIM2_BCD;
+
        if (mode->flags & DRM_MODE_FLAG_NHSYNC)
                tim2 |= TIM2_IHS;
 
                dev_err(drm->dev, "CLCD: unable to get clcdclk.\n");
                return PTR_ERR(parent);
        }
+       /* If the clock divider is broken, use the parent directly */
+       if (priv->variant->broken_clockdivider) {
+               priv->clk = parent;
+               return 0;
+       }
        parent_name = __clk_get_name(parent);
 
        spin_lock_init(&priv->tim2_lock);
 
  * @is_pl110: this is the early PL110 variant
  * @external_bgr: this is the Versatile Pl110 variant with external
  *     BGR/RGB routing
+ * @broken_clockdivider: the clock divider is broken and we need to
+ *     use the supplied clock directly
  * @formats: array of supported pixel formats on this variant
  * @nformats: the length of the array of supported pixel formats
  */
        const char *name;
        bool is_pl110;
        bool external_bgr;
+       bool broken_clockdivider;
        const u32 *formats;
        unsigned int nformats;
 };
 
 static const struct pl111_variant_data pl110_integrator = {
        .name = "PL110 Integrator",
        .is_pl110 = true,
+       .broken_clockdivider = true,
        .formats = pl110_integrator_pixel_formats,
        .nformats = ARRAY_SIZE(pl110_integrator_pixel_formats),
 };