diff options
author | Roy Spliet <rspliet@eclipso.eu> | 2014-09-12 12:00:13 -0400 |
---|---|---|
committer | Ben Skeggs <bskeggs@redhat.com> | 2014-09-15 08:25:14 -0400 |
commit | 1dce6264045cd23e9c07574ed0bb31c7dce9354f (patch) | |
tree | 0251e4549f88dfb21ab967ed24eee5e6260e1307 /drivers/gpu/drm/nouveau/nv50_display.c | |
parent | 2a7fa6744cd8333a414b5f3bfe4de647d787102e (diff) |
drm/nv50/kms: Set VBLANK time in modeset script
Solves blinking on reclocking memory. The value set is an underestimate, but
with non-reduced vblanking this should give us plenty of time
Signed-off-by: Roy Spliet <rspliet@eclipso.eu>
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/nouveau/nv50_display.c')
-rw-r--r-- | drivers/gpu/drm/nouveau/nv50_display.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/drivers/gpu/drm/nouveau/nv50_display.c b/drivers/gpu/drm/nouveau/nv50_display.c index 03949eaa629f..c15060e7336c 100644 --- a/drivers/gpu/drm/nouveau/nv50_display.c +++ b/drivers/gpu/drm/nouveau/nv50_display.c | |||
@@ -1066,7 +1066,7 @@ nv50_crtc_mode_set(struct drm_crtc *crtc, struct drm_display_mode *umode, | |||
1066 | u32 vscan = (mode->flags & DRM_MODE_FLAG_DBLSCAN) ? 2 : 1; | 1066 | u32 vscan = (mode->flags & DRM_MODE_FLAG_DBLSCAN) ? 2 : 1; |
1067 | u32 hactive, hsynce, hbackp, hfrontp, hblanke, hblanks; | 1067 | u32 hactive, hsynce, hbackp, hfrontp, hblanke, hblanks; |
1068 | u32 vactive, vsynce, vbackp, vfrontp, vblanke, vblanks; | 1068 | u32 vactive, vsynce, vbackp, vfrontp, vblanke, vblanks; |
1069 | u32 vblan2e = 0, vblan2s = 1; | 1069 | u32 vblan2e = 0, vblan2s = 1, vblankus = 0; |
1070 | u32 *push; | 1070 | u32 *push; |
1071 | int ret; | 1071 | int ret; |
1072 | 1072 | ||
@@ -1083,6 +1083,11 @@ nv50_crtc_mode_set(struct drm_crtc *crtc, struct drm_display_mode *umode, | |||
1083 | vblanke = vsynce + vbackp; | 1083 | vblanke = vsynce + vbackp; |
1084 | vfrontp = (mode->vsync_start - mode->vdisplay) * vscan / ilace; | 1084 | vfrontp = (mode->vsync_start - mode->vdisplay) * vscan / ilace; |
1085 | vblanks = vactive - vfrontp - 1; | 1085 | vblanks = vactive - vfrontp - 1; |
1086 | /* XXX: Safe underestimate, even "0" works */ | ||
1087 | vblankus = (vactive - mode->vdisplay - 2) * hactive; | ||
1088 | vblankus *= 1000; | ||
1089 | vblankus /= mode->clock; | ||
1090 | |||
1086 | if (mode->flags & DRM_MODE_FLAG_INTERLACE) { | 1091 | if (mode->flags & DRM_MODE_FLAG_INTERLACE) { |
1087 | vblan2e = vactive + vsynce + vbackp; | 1092 | vblan2e = vactive + vsynce + vbackp; |
1088 | vblan2s = vblan2e + (mode->vdisplay * vscan / ilace); | 1093 | vblan2s = vblan2e + (mode->vdisplay * vscan / ilace); |
@@ -1099,14 +1104,14 @@ nv50_crtc_mode_set(struct drm_crtc *crtc, struct drm_display_mode *umode, | |||
1099 | evo_mthd(push, 0x0804 + (nv_crtc->index * 0x400), 2); | 1104 | evo_mthd(push, 0x0804 + (nv_crtc->index * 0x400), 2); |
1100 | evo_data(push, 0x00800000 | mode->clock); | 1105 | evo_data(push, 0x00800000 | mode->clock); |
1101 | evo_data(push, (ilace == 2) ? 2 : 0); | 1106 | evo_data(push, (ilace == 2) ? 2 : 0); |
1102 | evo_mthd(push, 0x0810 + (nv_crtc->index * 0x400), 6); | 1107 | evo_mthd(push, 0x0810 + (nv_crtc->index * 0x400), 8); |
1103 | evo_data(push, 0x00000000); | 1108 | evo_data(push, 0x00000000); |
1104 | evo_data(push, (vactive << 16) | hactive); | 1109 | evo_data(push, (vactive << 16) | hactive); |
1105 | evo_data(push, ( vsynce << 16) | hsynce); | 1110 | evo_data(push, ( vsynce << 16) | hsynce); |
1106 | evo_data(push, (vblanke << 16) | hblanke); | 1111 | evo_data(push, (vblanke << 16) | hblanke); |
1107 | evo_data(push, (vblanks << 16) | hblanks); | 1112 | evo_data(push, (vblanks << 16) | hblanks); |
1108 | evo_data(push, (vblan2e << 16) | vblan2s); | 1113 | evo_data(push, (vblan2e << 16) | vblan2s); |
1109 | evo_mthd(push, 0x082c + (nv_crtc->index * 0x400), 1); | 1114 | evo_data(push, vblankus); |
1110 | evo_data(push, 0x00000000); | 1115 | evo_data(push, 0x00000000); |
1111 | evo_mthd(push, 0x0900 + (nv_crtc->index * 0x400), 2); | 1116 | evo_mthd(push, 0x0900 + (nv_crtc->index * 0x400), 2); |
1112 | evo_data(push, 0x00000311); | 1117 | evo_data(push, 0x00000311); |