summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/nouveau/nouveau_connector.c
diff options
context:
space:
mode:
authorFrancisco Jerez <currojerez@riseup.net>2010-06-16 17:52:44 +0400
committerBen Skeggs <bskeggs@redhat.com>2010-07-13 04:13:03 +0400
commit2fa67f12e71d7f8adade7c4e6bb839156dea2365 (patch)
treeb0b51c57c4f5f2f363ed7f4113fa9091dcffbab3 /drivers/gpu/drm/nouveau/nouveau_connector.c
parent7a2e4e03b77b929b10f3007395128a9870090653 (diff)
downloadlinux-2fa67f12e71d7f8adade7c4e6bb839156dea2365.tar.xz
drm/nouveau: Put the dithering check back in nouveau_connector_create.
a7b9f9e5adef dropped it by accident. Signed-off-by: Francisco Jerez <currojerez@riseup.net> Tested-by: Thibaut Girka <thib@sitedethib.com> Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/nouveau/nouveau_connector.c')
-rw-r--r--drivers/gpu/drm/nouveau/nouveau_connector.c26
1 files changed, 22 insertions, 4 deletions
diff --git a/drivers/gpu/drm/nouveau/nouveau_connector.c b/drivers/gpu/drm/nouveau/nouveau_connector.c
index a8c44c9eedf6..79190206b398 100644
--- a/drivers/gpu/drm/nouveau/nouveau_connector.c
+++ b/drivers/gpu/drm/nouveau/nouveau_connector.c
@@ -737,7 +737,7 @@ nouveau_connector_create(struct drm_device *dev,
struct nouveau_connector *nv_connector = NULL;
struct drm_connector *connector;
struct drm_encoder *encoder;
- int type;
+ int type, ret = 0;
NV_DEBUG_KMS(dev, "\n");
@@ -813,9 +813,21 @@ nouveau_connector_create(struct drm_device *dev,
if (!connector->encoder_ids[0]) {
NV_WARN(dev, " no encoders, ignoring\n");
- drm_connector_cleanup(connector);
- kfree(connector);
- return 0;
+ goto fail;
+ }
+
+ /* Check if we need dithering enabled */
+ if (dcb->type == DCB_CONNECTOR_LVDS) {
+ bool dummy, is_24bit = false;
+
+ ret = nouveau_bios_parse_lvds_table(dev, 0, &dummy, &is_24bit);
+ if (ret) {
+ NV_ERROR(dev, "Error parsing LVDS table, disabling "
+ "LVDS\n");
+ goto fail;
+ }
+
+ nv_connector->use_dithering = !is_24bit;
}
/* Init DVI-I specific properties */
@@ -865,4 +877,10 @@ nouveau_connector_create(struct drm_device *dev,
drm_sysfs_connector_add(connector);
return 0;
+
+fail:
+ drm_connector_cleanup(connector);
+ kfree(connector);
+ return ret;
+
}