* Other, TV specific properties: margins & TV modes.
         */
        dev->mode_config.tv_left_margin_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "left margin", 2);
-       dev->mode_config.tv_left_margin_property->values[0] = 0;
-       dev->mode_config.tv_left_margin_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "left margin", 0, 100);
 
        dev->mode_config.tv_right_margin_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "right margin", 2);
-       dev->mode_config.tv_right_margin_property->values[0] = 0;
-       dev->mode_config.tv_right_margin_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "right margin", 0, 100);
 
        dev->mode_config.tv_top_margin_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "top margin", 2);
-       dev->mode_config.tv_top_margin_property->values[0] = 0;
-       dev->mode_config.tv_top_margin_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "top margin", 0, 100);
 
        dev->mode_config.tv_bottom_margin_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "bottom margin", 2);
-       dev->mode_config.tv_bottom_margin_property->values[0] = 0;
-       dev->mode_config.tv_bottom_margin_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "bottom margin", 0, 100);
 
        dev->mode_config.tv_mode_property =
                drm_property_create(dev, DRM_MODE_PROP_ENUM,
                                      i, modes[i]);
 
        dev->mode_config.tv_brightness_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "brightness", 2);
-       dev->mode_config.tv_brightness_property->values[0] = 0;
-       dev->mode_config.tv_brightness_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "brightness", 0, 100);
 
        dev->mode_config.tv_contrast_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "contrast", 2);
-       dev->mode_config.tv_contrast_property->values[0] = 0;
-       dev->mode_config.tv_contrast_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "contrast", 0, 100);
 
        dev->mode_config.tv_flicker_reduction_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "flicker reduction", 2);
-       dev->mode_config.tv_flicker_reduction_property->values[0] = 0;
-       dev->mode_config.tv_flicker_reduction_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "flicker reduction", 0, 100);
 
        dev->mode_config.tv_overscan_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "overscan", 2);
-       dev->mode_config.tv_overscan_property->values[0] = 0;
-       dev->mode_config.tv_overscan_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "overscan", 0, 100);
 
        dev->mode_config.tv_saturation_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "saturation", 2);
-       dev->mode_config.tv_saturation_property->values[0] = 0;
-       dev->mode_config.tv_saturation_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "saturation", 0, 100);
 
        dev->mode_config.tv_hue_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "hue", 2);
-       dev->mode_config.tv_hue_property->values[0] = 0;
-       dev->mode_config.tv_hue_property->values[1] = 100;
+               drm_property_create_range(dev, 0, "hue", 0, 100);
 
        return 0;
 }
 }
 EXPORT_SYMBOL(drm_property_create_enum);
 
+struct drm_property *drm_property_create_range(struct drm_device *dev, int flags,
+                                        const char *name,
+                                        uint64_t min, uint64_t max)
+{
+       struct drm_property *property;
+
+       flags |= DRM_MODE_PROP_RANGE;
+
+       property = drm_property_create(dev, flags, name, 2);
+       if (!property)
+               return NULL;
+
+       property->values[0] = min;
+       property->values[1] = max;
+
+       return property;
+}
+EXPORT_SYMBOL(drm_property_create_range);
+
 int drm_property_add_enum(struct drm_property *property, int index,
                          uint64_t value, const char *name)
 {
 
        if (dev_priv->backlight_property)
                return 0;
 
-       backlight = drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                                       "backlight", 2);
-       backlight->values[0] = 0;
-       backlight->values[1] = 100;
+       backlight = drm_property_create_range(dev, 0, "backlight", 0, 100);
 
        dev_priv->backlight_property = backlight;
 
 
                psb_intel_sdvo_connector->max_##name = data_value[0]; \
                psb_intel_sdvo_connector->cur_##name = response; \
                psb_intel_sdvo_connector->name = \
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE, #name, 2); \
+                       drm_property_create_range(dev, 0, #name, 0, data_value[0]); \
                if (!psb_intel_sdvo_connector->name) return false; \
-               psb_intel_sdvo_connector->name->values[0] = 0; \
-               psb_intel_sdvo_connector->name->values[1] = data_value[0]; \
                drm_connector_attach_property(connector, \
                                              psb_intel_sdvo_connector->name, \
                                              psb_intel_sdvo_connector->cur_##name); \
                psb_intel_sdvo_connector->left_margin = data_value[0] - response;
                psb_intel_sdvo_connector->right_margin = psb_intel_sdvo_connector->left_margin;
                psb_intel_sdvo_connector->left =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                           "left_margin", 2);
+                       drm_property_create_range(dev, 0, "left_margin", 0, data_value[0]);
                if (!psb_intel_sdvo_connector->left)
                        return false;
 
-               psb_intel_sdvo_connector->left->values[0] = 0;
-               psb_intel_sdvo_connector->left->values[1] = data_value[0];
                drm_connector_attach_property(connector,
                                              psb_intel_sdvo_connector->left,
                                              psb_intel_sdvo_connector->left_margin);
 
                psb_intel_sdvo_connector->right =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                           "right_margin", 2);
+                       drm_property_create_range(dev, 0, "right_margin", 0, data_value[0]);
                if (!psb_intel_sdvo_connector->right)
                        return false;
 
-               psb_intel_sdvo_connector->right->values[0] = 0;
-               psb_intel_sdvo_connector->right->values[1] = data_value[0];
                drm_connector_attach_property(connector,
                                              psb_intel_sdvo_connector->right,
                                              psb_intel_sdvo_connector->right_margin);
                psb_intel_sdvo_connector->top_margin = data_value[0] - response;
                psb_intel_sdvo_connector->bottom_margin = psb_intel_sdvo_connector->top_margin;
                psb_intel_sdvo_connector->top =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                           "top_margin", 2);
+                       drm_property_create_range(dev, 0, "top_margin", 0, data_value[0]);
                if (!psb_intel_sdvo_connector->top)
                        return false;
 
-               psb_intel_sdvo_connector->top->values[0] = 0;
-               psb_intel_sdvo_connector->top->values[1] = data_value[0];
                drm_connector_attach_property(connector,
                                              psb_intel_sdvo_connector->top,
                                              psb_intel_sdvo_connector->top_margin);
 
                psb_intel_sdvo_connector->bottom =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                           "bottom_margin", 2);
+                       drm_property_create_range(dev, 0, "bottom_margin", 0, data_value[0]);
                if (!psb_intel_sdvo_connector->bottom)
                        return false;
 
-               psb_intel_sdvo_connector->bottom->values[0] = 0;
-               psb_intel_sdvo_connector->bottom->values[1] = data_value[0];
                drm_connector_attach_property(connector,
                                              psb_intel_sdvo_connector->bottom,
                                              psb_intel_sdvo_connector->bottom_margin);
                psb_intel_sdvo_connector->max_dot_crawl = 1;
                psb_intel_sdvo_connector->cur_dot_crawl = response & 0x1;
                psb_intel_sdvo_connector->dot_crawl =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE, "dot_crawl", 2);
+                       drm_property_create_range(dev, 0, "dot_crawl", 0, 1);
                if (!psb_intel_sdvo_connector->dot_crawl)
                        return false;
 
-               psb_intel_sdvo_connector->dot_crawl->values[0] = 0;
-               psb_intel_sdvo_connector->dot_crawl->values[1] = 1;
                drm_connector_attach_property(connector,
                                              psb_intel_sdvo_connector->dot_crawl,
                                              psb_intel_sdvo_connector->cur_dot_crawl);
 
 
        drm_mode_create_tv_properties(dev, NUM_TV_NORMS, ch7006_tv_norm_names);
 
-       priv->scale_property = drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                                  "scale", 2);
-       priv->scale_property->values[0] = 0;
-       priv->scale_property->values[1] = 2;
+       priv->scale_property = drm_property_create_range(dev, 0, "scale", 0, 2);
 
        drm_connector_attach_property(connector, conf->tv_select_subconnector_property,
                                      priv->select_subconnector);
 
                intel_sdvo_connector->max_##name = data_value[0]; \
                intel_sdvo_connector->cur_##name = response; \
                intel_sdvo_connector->name = \
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE, #name, 2); \
+                       drm_property_create_range(dev, 0, #name, 0, data_value[0]); \
                if (!intel_sdvo_connector->name) return false; \
-               intel_sdvo_connector->name->values[0] = 0; \
-               intel_sdvo_connector->name->values[1] = data_value[0]; \
                drm_connector_attach_property(connector, \
                                              intel_sdvo_connector->name, \
                                              intel_sdvo_connector->cur_##name); \
                intel_sdvo_connector->left_margin = data_value[0] - response;
                intel_sdvo_connector->right_margin = intel_sdvo_connector->left_margin;
                intel_sdvo_connector->left =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                           "left_margin", 2);
+                       drm_property_create_range(dev, 0, "left_margin", 0, data_value[0]);
                if (!intel_sdvo_connector->left)
                        return false;
 
-               intel_sdvo_connector->left->values[0] = 0;
-               intel_sdvo_connector->left->values[1] = data_value[0];
                drm_connector_attach_property(connector,
                                              intel_sdvo_connector->left,
                                              intel_sdvo_connector->left_margin);
 
                intel_sdvo_connector->right =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                           "right_margin", 2);
+                       drm_property_create_range(dev, 0, "right_margin", 0, data_value[0]);
                if (!intel_sdvo_connector->right)
                        return false;
 
-               intel_sdvo_connector->right->values[0] = 0;
-               intel_sdvo_connector->right->values[1] = data_value[0];
                drm_connector_attach_property(connector,
                                              intel_sdvo_connector->right,
                                              intel_sdvo_connector->right_margin);
                intel_sdvo_connector->top_margin = data_value[0] - response;
                intel_sdvo_connector->bottom_margin = intel_sdvo_connector->top_margin;
                intel_sdvo_connector->top =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                           "top_margin", 2);
+                       drm_property_create_range(dev, 0,
+                                           "top_margin", 0, data_value[0]);
                if (!intel_sdvo_connector->top)
                        return false;
 
-               intel_sdvo_connector->top->values[0] = 0;
-               intel_sdvo_connector->top->values[1] = data_value[0];
                drm_connector_attach_property(connector,
                                              intel_sdvo_connector->top,
                                              intel_sdvo_connector->top_margin);
 
                intel_sdvo_connector->bottom =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                           "bottom_margin", 2);
+                       drm_property_create_range(dev, 0,
+                                           "bottom_margin", 0, data_value[0]);
                if (!intel_sdvo_connector->bottom)
                        return false;
 
-               intel_sdvo_connector->bottom->values[0] = 0;
-               intel_sdvo_connector->bottom->values[1] = data_value[0];
                drm_connector_attach_property(connector,
                                              intel_sdvo_connector->bottom,
                                              intel_sdvo_connector->bottom_margin);
                intel_sdvo_connector->max_dot_crawl = 1;
                intel_sdvo_connector->cur_dot_crawl = response & 0x1;
                intel_sdvo_connector->dot_crawl =
-                       drm_property_create(dev, DRM_MODE_PROP_RANGE, "dot_crawl", 2);
+                       drm_property_create_range(dev, 0, "dot_crawl", 0, 1);
                if (!intel_sdvo_connector->dot_crawl)
                        return false;
 
-               intel_sdvo_connector->dot_crawl->values[0] = 0;
-               intel_sdvo_connector->dot_crawl->values[1] = 1;
                drm_connector_attach_property(connector,
                                              intel_sdvo_connector->dot_crawl,
                                              intel_sdvo_connector->cur_dot_crawl);
 
        PROP_ENUM(disp->underscan_property, gen, "underscan", underscan);
 
        disp->underscan_hborder_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "underscan hborder", 2);
-       disp->underscan_hborder_property->values[0] = 0;
-       disp->underscan_hborder_property->values[1] = 128;
+               drm_property_create_range(dev, 0, "underscan hborder", 0, 128);
 
        disp->underscan_vborder_property =
-               drm_property_create(dev, DRM_MODE_PROP_RANGE,
-                                   "underscan vborder", 2);
-       disp->underscan_vborder_property->values[0] = 0;
-       disp->underscan_vborder_property->values[1] = 128;
+               drm_property_create_range(dev, 0, "underscan vborder", 0, 128);
 
        dev->mode_config.funcs = (void *)&nouveau_mode_config_funcs;
        dev->mode_config.fb_base = pci_resource_start(dev->pdev, 1);
 
 
        if (rdev->is_atom_bios) {
                rdev->mode_info.coherent_mode_property =
-                       drm_property_create(rdev->ddev,
-                                           DRM_MODE_PROP_RANGE,
-                                           "coherent", 2);
+                       drm_property_create_range(rdev->ddev, 0 , "coherent", 0, 1);
                if (!rdev->mode_info.coherent_mode_property)
                        return -ENOMEM;
-
-               rdev->mode_info.coherent_mode_property->values[0] = 0;
-               rdev->mode_info.coherent_mode_property->values[1] = 1;
        }
 
        if (!ASIC_IS_AVIVO(rdev)) {
        }
 
        rdev->mode_info.load_detect_property =
-               drm_property_create(rdev->ddev,
-                                   DRM_MODE_PROP_RANGE,
-                                   "load detection", 2);
+               drm_property_create_range(rdev->ddev, 0, "load detection", 0, 1);
        if (!rdev->mode_info.load_detect_property)
                return -ENOMEM;
-       rdev->mode_info.load_detect_property->values[0] = 0;
-       rdev->mode_info.load_detect_property->values[1] = 1;
 
        drm_mode_create_scaling_mode_property(rdev->ddev);
 
                                    radeon_underscan_enum_list, sz);
 
        rdev->mode_info.underscan_hborder_property =
-               drm_property_create(rdev->ddev,
-                                       DRM_MODE_PROP_RANGE,
-                                       "underscan hborder", 2);
+               drm_property_create_range(rdev->ddev, 0,
+                                       "underscan hborder", 0, 128);
        if (!rdev->mode_info.underscan_hborder_property)
                return -ENOMEM;
-       rdev->mode_info.underscan_hborder_property->values[0] = 0;
-       rdev->mode_info.underscan_hborder_property->values[1] = 128;
 
        rdev->mode_info.underscan_vborder_property =
-               drm_property_create(rdev->ddev,
-                                       DRM_MODE_PROP_RANGE,
-                                       "underscan vborder", 2);
+               drm_property_create_range(rdev->ddev, 0,
+                                       "underscan vborder", 0, 128);
        if (!rdev->mode_info.underscan_vborder_property)
                return -ENOMEM;
-       rdev->mode_info.underscan_vborder_property->values[0] = 0;
-       rdev->mode_info.underscan_vborder_property->values[1] = 128;
 
        return 0;
 }
 
                                         const char *name,
                                         const struct drm_prop_enum_list *props,
                                         int num_values);
+struct drm_property *drm_property_create_range(struct drm_device *dev, int flags,
+                                        const char *name,
+                                        uint64_t min, uint64_t max);
 extern void drm_property_destroy(struct drm_device *dev, struct drm_property *property);
 extern int drm_property_add_enum(struct drm_property *property, int index,
                                 uint64_t value, const char *name);