diff options
author | Alex Deucher <alexdeucher@gmail.com> | 2009-12-01 13:43:46 -0500 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2009-12-01 23:00:06 -0500 |
commit | d8f60cfc93452d0554f6a701aa8e3236cbee4636 (patch) | |
tree | d6048658b42bdd9443f424755cd85f855e1477ba /drivers/gpu/drm/radeon/radeon_asic.h | |
parent | 50dafba685c0f12c23d315820370b32d9ba64db7 (diff) |
drm/radeon/kms: Add support for interrupts on r6xx/r7xx chips (v3)
This enables the use of interrupts on r6xx/r7xx hardware.
Interrupts are implemented via a ring buffer. The GPU adds
interrupts vectors to the ring and the host reads them off
in the interrupt handler. The interrupt controller requires
firmware like the CP. This firmware must be installed and
accessble to the firmware loader for interrupts to function.
MSIs don't seem to work on my RS780. They work fine on all
my discrete cards. I'm not sure about other RS780s or
RS880s. I've disabled MSIs on RS780 and RS880, but it would
probably be worth checking on some other systems.
v2 - fix some checkpatch.pl problems;
re-read the disp int status reg if we restart the ih;
v3 - remove the irq handler if r600_irq_init() fails;
remove spinlock in r600_ih_ring_fini();
move ih rb overflow check to r600_get_ih_wptr();
move irq ack to separate function;
Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/radeon_asic.h')
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_asic.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_asic.h b/drivers/gpu/drm/radeon/radeon_asic.h index c7a7f84fe3ec..755f50555c3d 100644 --- a/drivers/gpu/drm/radeon/radeon_asic.h +++ b/drivers/gpu/drm/radeon/radeon_asic.h | |||
@@ -480,6 +480,7 @@ static struct radeon_asic r600_asic = { | |||
480 | .ring_ib_execute = &r600_ring_ib_execute, | 480 | .ring_ib_execute = &r600_ring_ib_execute, |
481 | .irq_set = &r600_irq_set, | 481 | .irq_set = &r600_irq_set, |
482 | .irq_process = &r600_irq_process, | 482 | .irq_process = &r600_irq_process, |
483 | .get_vblank_counter = &rs600_get_vblank_counter, | ||
483 | .fence_ring_emit = &r600_fence_ring_emit, | 484 | .fence_ring_emit = &r600_fence_ring_emit, |
484 | .cs_parse = &r600_cs_parse, | 485 | .cs_parse = &r600_cs_parse, |
485 | .copy_blit = &r600_copy_blit, | 486 | .copy_blit = &r600_copy_blit, |
@@ -520,6 +521,7 @@ static struct radeon_asic rv770_asic = { | |||
520 | .ring_ib_execute = &r600_ring_ib_execute, | 521 | .ring_ib_execute = &r600_ring_ib_execute, |
521 | .irq_set = &r600_irq_set, | 522 | .irq_set = &r600_irq_set, |
522 | .irq_process = &r600_irq_process, | 523 | .irq_process = &r600_irq_process, |
524 | .get_vblank_counter = &rs600_get_vblank_counter, | ||
523 | .fence_ring_emit = &r600_fence_ring_emit, | 525 | .fence_ring_emit = &r600_fence_ring_emit, |
524 | .cs_parse = &r600_cs_parse, | 526 | .cs_parse = &r600_cs_parse, |
525 | .copy_blit = &r600_copy_blit, | 527 | .copy_blit = &r600_copy_blit, |