浏览代码

drm: Pass the display mode to drm_calc_timestamping_constants()

We don't really use hwmode anymore in i915, so eliminating its use
from the core code seems prudent. Just pass the appropriate mode
to drm_calc_timestamping_constants().

Reviewed-by: mario.kleiner.de@gmail.com
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Ville Syrjälä 11 年之前
父节点
当前提交
545cdd5510
共有 4 个文件被更改,包括 14 次插入11 次删除
  1. 1 1
      drivers/gpu/drm/drm_crtc_helper.c
  2. 9 8
      drivers/gpu/drm/drm_irq.c
  3. 2 1
      drivers/gpu/drm/i915/intel_display.c
  4. 2 1
      include/drm/drmP.h

+ 1 - 1
drivers/gpu/drm/drm_crtc_helper.c

@@ -536,7 +536,7 @@ bool drm_crtc_helper_set_mode(struct drm_crtc *crtc,
 	 * are later needed by vblank and swap-completion
 	 * are later needed by vblank and swap-completion
 	 * timestamping. They are derived from true hwmode.
 	 * timestamping. They are derived from true hwmode.
 	 */
 	 */
-	drm_calc_timestamping_constants(crtc);
+	drm_calc_timestamping_constants(crtc, &crtc->hwmode);
 
 
 	/* FIXME: add subpixel order */
 	/* FIXME: add subpixel order */
 done:
 done:

+ 9 - 8
drivers/gpu/drm/drm_irq.c

@@ -445,20 +445,22 @@ int drm_control(struct drm_device *dev, void *data,
  * adjustments into account.
  * adjustments into account.
  *
  *
  * @crtc drm_crtc whose timestamp constants should be updated.
  * @crtc drm_crtc whose timestamp constants should be updated.
+ * @mode display mode containing the scanout timings
  *
  *
  */
  */
-void drm_calc_timestamping_constants(struct drm_crtc *crtc)
+void drm_calc_timestamping_constants(struct drm_crtc *crtc,
+				     const struct drm_display_mode *mode)
 {
 {
 	s64 linedur_ns = 0, pixeldur_ns = 0, framedur_ns = 0;
 	s64 linedur_ns = 0, pixeldur_ns = 0, framedur_ns = 0;
 	u64 dotclock;
 	u64 dotclock;
 
 
 	/* Dot clock in Hz: */
 	/* Dot clock in Hz: */
-	dotclock = (u64) crtc->hwmode.clock * 1000;
+	dotclock = (u64) mode->clock * 1000;
 
 
 	/* Fields of interlaced scanout modes are only half a frame duration.
 	/* Fields of interlaced scanout modes are only half a frame duration.
 	 * Double the dotclock to get half the frame-/line-/pixelduration.
 	 * Double the dotclock to get half the frame-/line-/pixelduration.
 	 */
 	 */
-	if (crtc->hwmode.flags & DRM_MODE_FLAG_INTERLACE)
+	if (mode->flags & DRM_MODE_FLAG_INTERLACE)
 		dotclock *= 2;
 		dotclock *= 2;
 
 
 	/* Valid dotclock? */
 	/* Valid dotclock? */
@@ -469,10 +471,9 @@ void drm_calc_timestamping_constants(struct drm_crtc *crtc)
 		 * nanoseconds:
 		 * nanoseconds:
 		 */
 		 */
 		pixeldur_ns = (s64) div64_u64(1000000000, dotclock);
 		pixeldur_ns = (s64) div64_u64(1000000000, dotclock);
-		linedur_ns  = (s64) div64_u64(((u64) crtc->hwmode.crtc_htotal *
+		linedur_ns  = (s64) div64_u64(((u64) mode->crtc_htotal *
 					      1000000000), dotclock);
 					      1000000000), dotclock);
-		frame_size = crtc->hwmode.crtc_htotal *
-				crtc->hwmode.crtc_vtotal;
+		frame_size = mode->crtc_htotal * mode->crtc_vtotal;
 		framedur_ns = (s64) div64_u64((u64) frame_size * 1000000000,
 		framedur_ns = (s64) div64_u64((u64) frame_size * 1000000000,
 					      dotclock);
 					      dotclock);
 	} else
 	} else
@@ -484,8 +485,8 @@ void drm_calc_timestamping_constants(struct drm_crtc *crtc)
 	crtc->framedur_ns = framedur_ns;
 	crtc->framedur_ns = framedur_ns;
 
 
 	DRM_DEBUG("crtc %d: hwmode: htotal %d, vtotal %d, vdisplay %d\n",
 	DRM_DEBUG("crtc %d: hwmode: htotal %d, vtotal %d, vdisplay %d\n",
-		  crtc->base.id, crtc->hwmode.crtc_htotal,
-		  crtc->hwmode.crtc_vtotal, crtc->hwmode.crtc_vdisplay);
+		  crtc->base.id, mode->crtc_htotal,
+		  mode->crtc_vtotal, mode->crtc_vdisplay);
 	DRM_DEBUG("crtc %d: clock %d kHz framedur %d linedur %d, pixeldur %d\n",
 	DRM_DEBUG("crtc %d: clock %d kHz framedur %d linedur %d, pixeldur %d\n",
 		  crtc->base.id, (int) dotclock/1000, (int) framedur_ns,
 		  crtc->base.id, (int) dotclock/1000, (int) framedur_ns,
 		  (int) linedur_ns, (int) pixeldur_ns);
 		  (int) linedur_ns, (int) pixeldur_ns);

+ 2 - 1
drivers/gpu/drm/i915/intel_display.c

@@ -9693,7 +9693,8 @@ static int __intel_set_mode(struct drm_crtc *crtc,
 		 * are later needed by vblank and swap-completion
 		 * are later needed by vblank and swap-completion
 		 * timestamping. They are derived from true hwmode.
 		 * timestamping. They are derived from true hwmode.
 		 */
 		 */
-		drm_calc_timestamping_constants(crtc);
+		drm_calc_timestamping_constants(crtc,
+						&pipe_config->adjusted_mode);
 	}
 	}
 
 
 	/* FIXME: add subpixel order */
 	/* FIXME: add subpixel order */

+ 2 - 1
include/drm/drmP.h

@@ -1402,7 +1402,8 @@ extern int drm_calc_vbltimestamp_from_scanoutpos(struct drm_device *dev,
 						 struct timeval *vblank_time,
 						 struct timeval *vblank_time,
 						 unsigned flags,
 						 unsigned flags,
 						 struct drm_crtc *refcrtc);
 						 struct drm_crtc *refcrtc);
-extern void drm_calc_timestamping_constants(struct drm_crtc *crtc);
+extern void drm_calc_timestamping_constants(struct drm_crtc *crtc,
+					    const struct drm_display_mode *mode);
 
 
 extern bool
 extern bool
 drm_mode_parse_command_line_for_connector(const char *mode_option,
 drm_mode_parse_command_line_for_connector(const char *mode_option,