aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Deucher <alexander.deucher@amd.com>2011-11-03 11:21:39 -0400
committerDave Airlie <airlied@redhat.com>2011-11-03 13:53:18 -0400
commit64912e997f0fe13512e4c7b90e4f7c11cb922ab5 (patch)
tree0025b6451825a0400c4f15df7e448dafeccb996f
parenta18cee15ed4c8b6a35f96b7b26a46bac32e04bd9 (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.c1
-rw-r--r--drivers/gpu/drm/radeon/r100.c1
-rw-r--r--drivers/gpu/drm/radeon/r600.c19
-rw-r--r--drivers/gpu/drm/radeon/radeon_connectors.c1
-rw-r--r--drivers/gpu/drm/radeon/rs600.c1
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);