return -EINVAL;
                }
  
 +              if (INTEL_INFO(dev)->gen >= 5) {
 +                      DRM_DEBUG("clip rectangles are only valid on pre-gen5\n");
 +                      return -EINVAL;
 +              }
 +
+               if (args->num_cliprects > UINT_MAX / sizeof(*cliprects)) {
+                       DRM_DEBUG("execbuf with %u cliprects\n",
+                                 args->num_cliprects);
+                       return -EINVAL;
+               }
++
                cliprects = kmalloc(args->num_cliprects * sizeof(*cliprects),
                                    GFP_KERNEL);
                if (cliprects == NULL) {
 
        if (ret)
                goto err_unpin;
  
 -      OUT_RING(MI_DISPLAY_FLIP |
 -               MI_DISPLAY_FLIP_PLANE(intel_crtc->plane));
 -      OUT_RING(fb->pitches[0] | obj->tiling_mode);
 -      OUT_RING(obj->gtt_offset);
 +      intel_ring_emit(ring, MI_DISPLAY_FLIP |
 +                      MI_DISPLAY_FLIP_PLANE(intel_crtc->plane));
 +      intel_ring_emit(ring, fb->pitches[0] | obj->tiling_mode);
 +      intel_ring_emit(ring, obj->gtt_offset);
  
-       pf = I915_READ(PF_CTL(intel_crtc->pipe)) & PF_ENABLE;
+       /* Contrary to the suggestions in the documentation,
+        * "Enable Panel Fitter" does not seem to be required when page
+        * flipping with a non-native mode, and worse causes a normal
+        * modeset to fail.
+        * pf = I915_READ(PF_CTL(intel_crtc->pipe)) & PF_ENABLE;
+        */
+       pf = 0;
        pipesrc = I915_READ(PIPESRC(intel_crtc->pipe)) & 0x0fff0fff;
 -      OUT_RING(pf | pipesrc);
 -      ADVANCE_LP_RING();
 +      intel_ring_emit(ring, pf | pipesrc);
 +      intel_ring_advance(ring);
        return 0;
  
  err_unpin:
 
                        return ret;
        }
  
 -      if (INTEL_INFO(dev)->gen >= 6) {
 -              I915_WRITE(INSTPM,
 -                         INSTPM_FORCE_ORDERING << 16 | INSTPM_FORCE_ORDERING);
 -
++      if (IS_GEN6(dev)) {
+               /* From the Sandybridge PRM, volume 1 part 3, page 24:
+                * "If this bit is set, STCunit will have LRA as replacement
+                *  policy. [...] This bit must be reset.  LRA replacement
+                *  policy is not supported."
+                */
+               I915_WRITE(CACHE_MODE_0,
 -                         CM0_STC_EVICT_DISABLE_LRA_SNB << CM0_MASK_SHIFT);
++                         _MASKED_BIT_DISABLE(CM0_STC_EVICT_DISABLE_LRA_SNB));
+       }
+ 
 +      if (INTEL_INFO(dev)->gen >= 6)
 +              I915_WRITE(INSTPM, _MASKED_BIT_ENABLE(INSTPM_FORCE_ORDERING));
 +
        return ret;
  }
  
 
        uint16_t width, height;
        uint16_t h_blank_len, h_sync_len, v_blank_len, v_sync_len;
        uint16_t h_sync_offset, v_sync_offset;
+       int mode_clock;
  
 -      width = mode->crtc_hdisplay;
 -      height = mode->crtc_vdisplay;
 +      width = mode->hdisplay;
 +      height = mode->vdisplay;
  
        /* do some mode translations */
 -      h_blank_len = mode->crtc_hblank_end - mode->crtc_hblank_start;
 -      h_sync_len = mode->crtc_hsync_end - mode->crtc_hsync_start;
 +      h_blank_len = mode->htotal - mode->hdisplay;
 +      h_sync_len = mode->hsync_end - mode->hsync_start;
  
 -      v_blank_len = mode->crtc_vblank_end - mode->crtc_vblank_start;
 -      v_sync_len = mode->crtc_vsync_end - mode->crtc_vsync_start;
 +      v_blank_len = mode->vtotal - mode->vdisplay;
 +      v_sync_len = mode->vsync_end - mode->vsync_start;
  
 -      h_sync_offset = mode->crtc_hsync_start - mode->crtc_hblank_start;
 -      v_sync_offset = mode->crtc_vsync_start - mode->crtc_vblank_start;
 +      h_sync_offset = mode->hsync_start - mode->hdisplay;
 +      v_sync_offset = mode->vsync_start - mode->vdisplay;
  
-       dtd->part1.clock = mode->clock / 10;
+       mode_clock = mode->clock;
+       mode_clock /= intel_mode_get_pixel_multiplier(mode) ?: 1;
+       mode_clock /= 10;
+       dtd->part1.clock = mode_clock;
+ 
        dtd->part1.h_active = width & 0xff;
        dtd->part1.h_blank = h_blank_len & 0xff;
        dtd->part1.h_high = (((width >> 8) & 0xf) << 4) |