diff options
author | Alex Deucher <alexdeucher@gmail.com> | 2009-12-04 16:56:37 -0500 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2009-12-07 19:48:22 -0500 |
commit | d4877cf2293f5463f531769fd12300cb3417c778 (patch) | |
tree | ee9533aaf9fac0bbec859cf5d888fa73a71875bd /drivers/gpu/drm/radeon/rs600.c | |
parent | 429770b3e39999c4d025fbcb9959502adc3989d8 (diff) |
drm/radeon/kms: enable hpd support
This enabled interrupt driven hpd support for all
radeon chips. Assuming the hpd pin is wired up
correctly, the driver will generate uevents on
digital monitor connect and disconnect and retrain
DP monitors automatically.
Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/rs600.c')
-rw-r--r-- | drivers/gpu/drm/radeon/rs600.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/drivers/gpu/drm/radeon/rs600.c b/drivers/gpu/drm/radeon/rs600.c index 6364ba1d4153..fd5ab01f6ad1 100644 --- a/drivers/gpu/drm/radeon/rs600.c +++ b/drivers/gpu/drm/radeon/rs600.c | |||
@@ -388,6 +388,7 @@ int rs600_irq_process(struct radeon_device *rdev) | |||
388 | { | 388 | { |
389 | uint32_t status, msi_rearm; | 389 | uint32_t status, msi_rearm; |
390 | uint32_t r500_disp_int; | 390 | uint32_t r500_disp_int; |
391 | bool queue_hotplug = false; | ||
391 | 392 | ||
392 | status = rs600_irq_ack(rdev, &r500_disp_int); | 393 | status = rs600_irq_ack(rdev, &r500_disp_int); |
393 | if (!status && !r500_disp_int) { | 394 | if (!status && !r500_disp_int) { |
@@ -403,13 +404,17 @@ int rs600_irq_process(struct radeon_device *rdev) | |||
403 | if (G_007EDC_LB_D2_VBLANK_INTERRUPT(r500_disp_int)) | 404 | if (G_007EDC_LB_D2_VBLANK_INTERRUPT(r500_disp_int)) |
404 | drm_handle_vblank(rdev->ddev, 1); | 405 | drm_handle_vblank(rdev->ddev, 1); |
405 | if (G_007EDC_DC_HOT_PLUG_DETECT1_INTERRUPT(r500_disp_int)) { | 406 | if (G_007EDC_DC_HOT_PLUG_DETECT1_INTERRUPT(r500_disp_int)) { |
406 | DRM_INFO("HPD1\n"); | 407 | queue_hotplug = true; |
408 | DRM_DEBUG("HPD1\n"); | ||
407 | } | 409 | } |
408 | if (G_007EDC_DC_HOT_PLUG_DETECT2_INTERRUPT(r500_disp_int)) { | 410 | if (G_007EDC_DC_HOT_PLUG_DETECT2_INTERRUPT(r500_disp_int)) { |
409 | DRM_INFO("HPD2\n"); | 411 | queue_hotplug = true; |
412 | DRM_DEBUG("HPD2\n"); | ||
410 | } | 413 | } |
411 | status = rs600_irq_ack(rdev, &r500_disp_int); | 414 | status = rs600_irq_ack(rdev, &r500_disp_int); |
412 | } | 415 | } |
416 | if (queue_hotplug) | ||
417 | queue_work(rdev->wq, &rdev->hotplug_work); | ||
413 | if (rdev->msi_enabled) { | 418 | if (rdev->msi_enabled) { |
414 | switch (rdev->family) { | 419 | switch (rdev->family) { |
415 | case CHIP_RS600: | 420 | case CHIP_RS600: |