diff options
author | Daniel Vetter <daniel.vetter@ffwll.ch> | 2012-12-02 08:02:51 -0500 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2012-12-14 10:45:22 -0500 |
commit | 2ef9bdfe64079c9d0b98dc89af3af52918b818a0 (patch) | |
tree | d755083f2702b1ac6f2f8ed449d2e65d9e7e4582 /drivers/gpu/drm/radeon/radeon.h | |
parent | 9add1ac3dd256ad12e266f8403daf928be19953f (diff) |
drm/radeon: add W|RREG32_IDX for MM_INDEX|DATA based mmio accesss
Just refactoring to make the next patche simpler. Now all indirect register
access in the new modesetting driver should go through the r100_mm_(w|r)reg
fucntions.
RADEON_READ_MM from the old driver seems to be totally unused, so just kill
it.
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/radeon.h')
-rw-r--r-- | drivers/gpu/drm/radeon/radeon.h | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/drivers/gpu/drm/radeon/radeon.h b/drivers/gpu/drm/radeon/radeon.h index 1b9120a875ef..609bb18d09f1 100644 --- a/drivers/gpu/drm/radeon/radeon.h +++ b/drivers/gpu/drm/radeon/radeon.h | |||
@@ -1631,8 +1631,10 @@ int radeon_device_init(struct radeon_device *rdev, | |||
1631 | void radeon_device_fini(struct radeon_device *rdev); | 1631 | void radeon_device_fini(struct radeon_device *rdev); |
1632 | int radeon_gpu_wait_for_idle(struct radeon_device *rdev); | 1632 | int radeon_gpu_wait_for_idle(struct radeon_device *rdev); |
1633 | 1633 | ||
1634 | uint32_t r100_mm_rreg(struct radeon_device *rdev, uint32_t reg); | 1634 | uint32_t r100_mm_rreg(struct radeon_device *rdev, uint32_t reg, |
1635 | void r100_mm_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); | 1635 | bool always_indirect); |
1636 | void r100_mm_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v, | ||
1637 | bool always_indirect); | ||
1636 | u32 r100_io_rreg(struct radeon_device *rdev, u32 reg); | 1638 | u32 r100_io_rreg(struct radeon_device *rdev, u32 reg); |
1637 | void r100_io_wreg(struct radeon_device *rdev, u32 reg, u32 v); | 1639 | void r100_io_wreg(struct radeon_device *rdev, u32 reg, u32 v); |
1638 | 1640 | ||
@@ -1648,9 +1650,11 @@ void r100_io_wreg(struct radeon_device *rdev, u32 reg, u32 v); | |||
1648 | #define WREG8(reg, v) writeb(v, (rdev->rmmio) + (reg)) | 1650 | #define WREG8(reg, v) writeb(v, (rdev->rmmio) + (reg)) |
1649 | #define RREG16(reg) readw((rdev->rmmio) + (reg)) | 1651 | #define RREG16(reg) readw((rdev->rmmio) + (reg)) |
1650 | #define WREG16(reg, v) writew(v, (rdev->rmmio) + (reg)) | 1652 | #define WREG16(reg, v) writew(v, (rdev->rmmio) + (reg)) |
1651 | #define RREG32(reg) r100_mm_rreg(rdev, (reg)) | 1653 | #define RREG32(reg) r100_mm_rreg(rdev, (reg), false) |
1652 | #define DREG32(reg) printk(KERN_INFO "REGISTER: " #reg " : 0x%08X\n", r100_mm_rreg(rdev, (reg))) | 1654 | #define RREG32_IDX(reg) r100_mm_rreg(rdev, (reg), true) |
1653 | #define WREG32(reg, v) r100_mm_wreg(rdev, (reg), (v)) | 1655 | #define DREG32(reg) printk(KERN_INFO "REGISTER: " #reg " : 0x%08X\n", r100_mm_rreg(rdev, (reg), false)) |
1656 | #define WREG32(reg, v) r100_mm_wreg(rdev, (reg), (v), false) | ||
1657 | #define WREG32_IDX(reg, v) r100_mm_wreg(rdev, (reg), (v), true) | ||
1654 | #define REG_SET(FIELD, v) (((v) << FIELD##_SHIFT) & FIELD##_MASK) | 1658 | #define REG_SET(FIELD, v) (((v) << FIELD##_SHIFT) & FIELD##_MASK) |
1655 | #define REG_GET(FIELD, v) (((v) << FIELD##_SHIFT) & FIELD##_MASK) | 1659 | #define REG_GET(FIELD, v) (((v) << FIELD##_SHIFT) & FIELD##_MASK) |
1656 | #define RREG32_PLL(reg) rdev->pll_rreg(rdev, (reg)) | 1660 | #define RREG32_PLL(reg) rdev->pll_rreg(rdev, (reg)) |
@@ -1675,7 +1679,7 @@ void r100_io_wreg(struct radeon_device *rdev, u32 reg, u32 v); | |||
1675 | tmp_ |= ((val) & ~(mask)); \ | 1679 | tmp_ |= ((val) & ~(mask)); \ |
1676 | WREG32_PLL(reg, tmp_); \ | 1680 | WREG32_PLL(reg, tmp_); \ |
1677 | } while (0) | 1681 | } while (0) |
1678 | #define DREG32_SYS(sqf, rdev, reg) seq_printf((sqf), #reg " : 0x%08X\n", r100_mm_rreg((rdev), (reg))) | 1682 | #define DREG32_SYS(sqf, rdev, reg) seq_printf((sqf), #reg " : 0x%08X\n", r100_mm_rreg((rdev), (reg), false)) |
1679 | #define RREG32_IO(reg) r100_io_rreg(rdev, (reg)) | 1683 | #define RREG32_IO(reg) r100_io_rreg(rdev, (reg)) |
1680 | #define WREG32_IO(reg, v) r100_io_wreg(rdev, (reg), (v)) | 1684 | #define WREG32_IO(reg, v) r100_io_wreg(rdev, (reg), (v)) |
1681 | 1685 | ||