aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Deucher <alexdeucher@gmail.com>2009-10-12 11:25:05 -0400
committerDave Airlie <airlied@redhat.com>2009-10-12 18:45:52 -0400
commitfb06ca8f8c61dfd7cbfa2092756577ff78a26dcd (patch)
tree460ae7fd3c14008f9f683f95b196dd5f0cbeaffb
parent39deb2d67515086f08a672e7574716ca0d3883a5 (diff)
drm/radeon/kms: properly handle mode id with native mode changes
drm modes are objects with indentifiers. Make sure to preserve the mode id when copying mode params. Signed-off-by: Alex Deucher <alexdeucher@gmail.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r--drivers/gpu/drm/radeon/radeon_connectors.c3
-rw-r--r--drivers/gpu/drm/radeon/radeon_encoders.c2
2 files changed, 3 insertions, 2 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_connectors.c b/drivers/gpu/drm/radeon/radeon_connectors.c
index 17d5659cff03..729207a1e83e 100644
--- a/drivers/gpu/drm/radeon/radeon_connectors.c
+++ b/drivers/gpu/drm/radeon/radeon_connectors.c
@@ -183,8 +183,7 @@ static struct drm_display_mode *radeon_fp_native_mode(struct drm_encoder *encode
183 if (native_mode->hdisplay != 0 && 183 if (native_mode->hdisplay != 0 &&
184 native_mode->vdisplay != 0 && 184 native_mode->vdisplay != 0 &&
185 native_mode->clock != 0) { 185 native_mode->clock != 0) {
186 mode = drm_mode_create(dev); 186 mode = drm_mode_duplicate(dev, native_mode);
187 *mode = *native_mode;
188 mode->type = DRM_MODE_TYPE_PREFERRED | DRM_MODE_TYPE_DRIVER; 187 mode->type = DRM_MODE_TYPE_PREFERRED | DRM_MODE_TYPE_DRIVER;
189 drm_mode_set_name(mode); 188 drm_mode_set_name(mode);
190 189
diff --git a/drivers/gpu/drm/radeon/radeon_encoders.c b/drivers/gpu/drm/radeon/radeon_encoders.c
index a9d4e0ab049a..10845f39124a 100644
--- a/drivers/gpu/drm/radeon/radeon_encoders.c
+++ b/drivers/gpu/drm/radeon/radeon_encoders.c
@@ -175,11 +175,13 @@ void radeon_rmx_mode_fixup(struct drm_encoder *encoder,
175 175
176 if (mode->hdisplay < native_mode->hdisplay || 176 if (mode->hdisplay < native_mode->hdisplay ||
177 mode->vdisplay < native_mode->vdisplay) { 177 mode->vdisplay < native_mode->vdisplay) {
178 int mode_id = adjusted_mode->base.id;
178 *adjusted_mode = *native_mode; 179 *adjusted_mode = *native_mode;
179 if (!ASIC_IS_AVIVO(rdev)) { 180 if (!ASIC_IS_AVIVO(rdev)) {
180 adjusted_mode->hdisplay = mode->hdisplay; 181 adjusted_mode->hdisplay = mode->hdisplay;
181 adjusted_mode->vdisplay = mode->vdisplay; 182 adjusted_mode->vdisplay = mode->vdisplay;
182 } 183 }
184 adjusted_mode->base.id = mode_id;
183 } 185 }
184} 186}
185 187