drm: Add drm_mode_copy()
authorVille Syrjälä <ville.syrjala@linux.intel.com>
Tue, 20 Mar 2012 14:46:15 +0000 (16:46 +0200)
committerMarkus Lehtonen <markus.lehtonen@linux.intel.com>
Tue, 3 Jul 2012 09:30:41 +0000 (12:30 +0300)
Add a helper function to copy a display mode. Use it in
drm_mode_duplicate() and nouveau mode_fixup hooks.

Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Signed-off-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
drivers/gpu/drm/drm_modes.c
drivers/gpu/drm/nouveau/nv50_dac.c
drivers/gpu/drm/nouveau/nv50_sor.c
include/drm/drm_crtc.h

index c2d32f2..3af6472 100644 (file)
@@ -715,6 +715,27 @@ EXPORT_SYMBOL(drm_mode_set_crtcinfo);
 
 
 /**
+ * drm_mode_copy - copy the mode
+ * @dst: mode to overwrite
+ * @src: mode to copy
+ *
+ * LOCKING:
+ * None.
+ *
+ * Copy an existing mode into another mode, preserving the object id
+ * of the destination mode.
+ */
+void drm_mode_copy(struct drm_display_mode *dst, const struct drm_display_mode *src)
+{
+       int id = dst->base.id;
+
+       *dst = *src;
+       dst->base.id = id;
+       INIT_LIST_HEAD(&dst->head);
+}
+EXPORT_SYMBOL(drm_mode_copy);
+
+/**
  * drm_mode_duplicate - allocate and duplicate an existing mode
  * @m: mode to duplicate
  *
@@ -728,16 +749,13 @@ struct drm_display_mode *drm_mode_duplicate(struct drm_device *dev,
                                            const struct drm_display_mode *mode)
 {
        struct drm_display_mode *nmode;
-       int new_id;
 
        nmode = drm_mode_create(dev);
        if (!nmode)
                return NULL;
 
-       new_id = nmode->base.id;
-       *nmode = *mode;
-       nmode->base.id = new_id;
-       INIT_LIST_HEAD(&nmode->head);
+       drm_mode_copy(nmode, mode);
+
        return nmode;
 }
 EXPORT_SYMBOL(drm_mode_duplicate);
index 808f3ec..8ae0dd2 100644 (file)
@@ -190,11 +190,8 @@ nv50_dac_mode_fixup(struct drm_encoder *encoder, struct drm_display_mode *mode,
        }
 
        if (connector->scaling_mode != DRM_MODE_SCALE_NONE &&
-            connector->native_mode) {
-               int id = adjusted_mode->base.id;
-               *adjusted_mode = *connector->native_mode;
-               adjusted_mode->base.id = id;
-       }
+            connector->native_mode)
+               drm_mode_copy(adjusted_mode, connector->native_mode);
 
        return true;
 }
index c25c593..57b8707 100644 (file)
@@ -160,11 +160,8 @@ nv50_sor_mode_fixup(struct drm_encoder *encoder, struct drm_display_mode *mode,
        }
 
        if (connector->scaling_mode != DRM_MODE_SCALE_NONE &&
-            connector->native_mode) {
-               int id = adjusted_mode->base.id;
-               *adjusted_mode = *connector->native_mode;
-               adjusted_mode->base.id = id;
-       }
+            connector->native_mode)
+               drm_mode_copy(adjusted_mode, connector->native_mode);
 
        return true;
 }
index 28026e5..0261d7e 100644 (file)
@@ -791,6 +791,7 @@ extern struct edid *drm_get_edid(struct drm_connector *connector,
 extern int drm_add_edid_modes(struct drm_connector *connector, struct edid *edid);
 extern void drm_mode_probed_add(struct drm_connector *connector, struct drm_display_mode *mode);
 extern void drm_mode_remove(struct drm_connector *connector, struct drm_display_mode *mode);
+extern void drm_mode_copy(struct drm_display_mode *dst, const struct drm_display_mode *src);
 extern struct drm_display_mode *drm_mode_duplicate(struct drm_device *dev,
                                                   const struct drm_display_mode *mode);
 extern void drm_mode_debug_printmodeline(struct drm_display_mode *mode);