diff options
author | Alex Deucher <alexander.deucher@amd.com> | 2011-11-03 11:21:39 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2011-11-03 13:53:18 -0400 |
commit | 64912e997f0fe13512e4c7b90e4f7c11cb922ab5 (patch) | |
tree | 0025b6451825a0400c4f15df7e448dafeccb996f | |
parent | a18cee15ed4c8b6a35f96b7b26a46bac32e04bd9 (diff) |
drm/radeon/kms: set HPD polarity in hpd_init()
Polarity needs to be set accordingly to connector status (connected
or disconnected). Set it up in hpd_init() so first hotplug works
reliably no matter what is the initial set of connector. hpd_init()
also covers resume so HPD will work correctly after resume as well.
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Cc: Jerome Glisse <j.glisse@gmail.com>
Cc: stable@kernel.org
Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r-- | drivers/gpu/drm/radeon/evergreen.c | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/r100.c | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/r600.c | 19 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_connectors.c | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/rs600.c | 1 |
5 files changed, 12 insertions, 11 deletions
diff --git a/drivers/gpu/drm/radeon/evergreen.c b/drivers/gpu/drm/radeon/evergreen.c index db9027d871e3..7ce9c87e695e 100644 --- a/drivers/gpu/drm/radeon/evergreen.c +++ b/drivers/gpu/drm/radeon/evergreen.c | |||
@@ -353,6 +353,7 @@ void evergreen_hpd_init(struct radeon_device *rdev) | |||
353 | default: | 353 | default: |
354 | break; | 354 | break; |
355 | } | 355 | } |
356 | radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd); | ||
356 | } | 357 | } |
357 | if (rdev->irq.installed) | 358 | if (rdev->irq.installed) |
358 | evergreen_irq_set(rdev); | 359 | evergreen_irq_set(rdev); |
diff --git a/drivers/gpu/drm/radeon/r100.c b/drivers/gpu/drm/radeon/r100.c index 8f8b8fa14357..4191eaf47381 100644 --- a/drivers/gpu/drm/radeon/r100.c +++ b/drivers/gpu/drm/radeon/r100.c | |||
@@ -536,6 +536,7 @@ void r100_hpd_init(struct radeon_device *rdev) | |||
536 | default: | 536 | default: |
537 | break; | 537 | break; |
538 | } | 538 | } |
539 | radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd); | ||
539 | } | 540 | } |
540 | if (rdev->irq.installed) | 541 | if (rdev->irq.installed) |
541 | r100_irq_set(rdev); | 542 | r100_irq_set(rdev); |
diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c index 75b8e004ca80..ff3ae48aa1a7 100644 --- a/drivers/gpu/drm/radeon/r600.c +++ b/drivers/gpu/drm/radeon/r600.c | |||
@@ -762,13 +762,14 @@ void r600_hpd_init(struct radeon_device *rdev) | |||
762 | struct drm_device *dev = rdev->ddev; | 762 | struct drm_device *dev = rdev->ddev; |
763 | struct drm_connector *connector; | 763 | struct drm_connector *connector; |
764 | 764 | ||
765 | if (ASIC_IS_DCE3(rdev)) { | 765 | list_for_each_entry(connector, &dev->mode_config.connector_list, head) { |
766 | u32 tmp = DC_HPDx_CONNECTION_TIMER(0x9c4) | DC_HPDx_RX_INT_TIMER(0xfa); | 766 | struct radeon_connector *radeon_connector = to_radeon_connector(connector); |
767 | if (ASIC_IS_DCE32(rdev)) | 767 | |
768 | tmp |= DC_HPDx_EN; | 768 | if (ASIC_IS_DCE3(rdev)) { |
769 | u32 tmp = DC_HPDx_CONNECTION_TIMER(0x9c4) | DC_HPDx_RX_INT_TIMER(0xfa); | ||
770 | if (ASIC_IS_DCE32(rdev)) | ||
771 | tmp |= DC_HPDx_EN; | ||
769 | 772 | ||
770 | list_for_each_entry(connector, &dev->mode_config.connector_list, head) { | ||
771 | struct radeon_connector *radeon_connector = to_radeon_connector(connector); | ||
772 | switch (radeon_connector->hpd.hpd) { | 773 | switch (radeon_connector->hpd.hpd) { |
773 | case RADEON_HPD_1: | 774 | case RADEON_HPD_1: |
774 | WREG32(DC_HPD1_CONTROL, tmp); | 775 | WREG32(DC_HPD1_CONTROL, tmp); |
@@ -798,10 +799,7 @@ void r600_hpd_init(struct radeon_device *rdev) | |||
798 | default: | 799 | default: |
799 | break; | 800 | break; |
800 | } | 801 | } |
801 | } | 802 | } else { |
802 | } else { | ||
803 | list_for_each_entry(connector, &dev->mode_config.connector_list, head) { | ||
804 | struct radeon_connector *radeon_connector = to_radeon_connector(connector); | ||
805 | switch (radeon_connector->hpd.hpd) { | 803 | switch (radeon_connector->hpd.hpd) { |
806 | case RADEON_HPD_1: | 804 | case RADEON_HPD_1: |
807 | WREG32(DC_HOT_PLUG_DETECT1_CONTROL, DC_HOT_PLUG_DETECTx_EN); | 805 | WREG32(DC_HOT_PLUG_DETECT1_CONTROL, DC_HOT_PLUG_DETECTx_EN); |
@@ -819,6 +817,7 @@ void r600_hpd_init(struct radeon_device *rdev) | |||
819 | break; | 817 | break; |
820 | } | 818 | } |
821 | } | 819 | } |
820 | radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd); | ||
822 | } | 821 | } |
823 | if (rdev->irq.installed) | 822 | if (rdev->irq.installed) |
824 | r600_irq_set(rdev); | 823 | r600_irq_set(rdev); |
diff --git a/drivers/gpu/drm/radeon/radeon_connectors.c b/drivers/gpu/drm/radeon/radeon_connectors.c index ea3720cd98f2..e7cb3ab09243 100644 --- a/drivers/gpu/drm/radeon/radeon_connectors.c +++ b/drivers/gpu/drm/radeon/radeon_connectors.c | |||
@@ -1733,7 +1733,6 @@ radeon_add_atom_connector(struct drm_device *dev, | |||
1733 | connector->polled = DRM_CONNECTOR_POLL_CONNECT; | 1733 | connector->polled = DRM_CONNECTOR_POLL_CONNECT; |
1734 | } else | 1734 | } else |
1735 | connector->polled = DRM_CONNECTOR_POLL_HPD; | 1735 | connector->polled = DRM_CONNECTOR_POLL_HPD; |
1736 | radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd); | ||
1737 | 1736 | ||
1738 | connector->display_info.subpixel_order = subpixel_order; | 1737 | connector->display_info.subpixel_order = subpixel_order; |
1739 | drm_sysfs_connector_add(connector); | 1738 | drm_sysfs_connector_add(connector); |
diff --git a/drivers/gpu/drm/radeon/rs600.c b/drivers/gpu/drm/radeon/rs600.c index 9320dd6404f6..02e0390daa8e 100644 --- a/drivers/gpu/drm/radeon/rs600.c +++ b/drivers/gpu/drm/radeon/rs600.c | |||
@@ -287,6 +287,7 @@ void rs600_hpd_init(struct radeon_device *rdev) | |||
287 | default: | 287 | default: |
288 | break; | 288 | break; |
289 | } | 289 | } |
290 | radeon_hpd_set_polarity(rdev, radeon_connector->hpd.hpd); | ||
290 | } | 291 | } |
291 | if (rdev->irq.installed) | 292 | if (rdev->irq.installed) |
292 | rs600_irq_set(rdev); | 293 | rs600_irq_set(rdev); |