提交 ac447df4 编写于 作者: J Jerome Glisse 提交者: Dave Airlie

drm/radeon/kms: Fix irq handling on AVIVO hw

Avivo hw have vblank interrupt in different place, fixes
irq handling (especialy irq disabling while suspending or
shuting down the module).
Signed-off-by: NJerome Glisse <jglisse@redhat.com>
Signed-off-by: NDave Airlie <airlied@redhat.com>
上级 e7d40b9a
...@@ -186,7 +186,7 @@ static int r520_startup(struct radeon_device *rdev) ...@@ -186,7 +186,7 @@ static int r520_startup(struct radeon_device *rdev)
} }
/* Enable IRQ */ /* Enable IRQ */
rdev->irq.sw_int = true; rdev->irq.sw_int = true;
r100_irq_set(rdev); rs600_irq_set(rdev);
/* 1M ring buffer */ /* 1M ring buffer */
r = r100_cp_init(rdev, 1024 * 1024); r = r100_cp_init(rdev, 1024 * 1024);
if (r) { if (r) {
......
...@@ -1064,6 +1064,8 @@ extern void rs400_gart_fini(struct radeon_device *rdev); ...@@ -1064,6 +1064,8 @@ extern void rs400_gart_fini(struct radeon_device *rdev);
/* rs600 */ /* rs600 */
extern void rs600_set_safe_registers(struct radeon_device *rdev); extern void rs600_set_safe_registers(struct radeon_device *rdev);
extern int rs600_irq_set(struct radeon_device *rdev);
extern void rs600_irq_disable(struct radeon_device *rdev);
/* rs690, rs740 */ /* rs690, rs740 */
extern void rs690_line_buffer_adjust(struct radeon_device *rdev, extern void rs690_line_buffer_adjust(struct radeon_device *rdev,
......
...@@ -229,6 +229,17 @@ static inline uint32_t rs600_irq_ack(struct radeon_device *rdev, u32 *r500_disp_ ...@@ -229,6 +229,17 @@ static inline uint32_t rs600_irq_ack(struct radeon_device *rdev, u32 *r500_disp_
return irqs & irq_mask; return irqs & irq_mask;
} }
void rs600_irq_disable(struct radeon_device *rdev)
{
u32 tmp;
WREG32(R_000040_GEN_INT_CNTL, 0);
WREG32(R_006540_DxMODE_INT_MASK, 0);
/* Wait and acknowledge irq */
mdelay(1);
rs600_irq_ack(rdev, &tmp);
}
int rs600_irq_process(struct radeon_device *rdev) int rs600_irq_process(struct radeon_device *rdev)
{ {
uint32_t status; uint32_t status;
...@@ -403,7 +414,7 @@ int rs600_suspend(struct radeon_device *rdev) ...@@ -403,7 +414,7 @@ int rs600_suspend(struct radeon_device *rdev)
{ {
r100_cp_disable(rdev); r100_cp_disable(rdev);
r100_wb_disable(rdev); r100_wb_disable(rdev);
r100_irq_disable(rdev); rs600_irq_disable(rdev);
rs600_gart_disable(rdev); rs600_gart_disable(rdev);
return 0; return 0;
} }
......
...@@ -606,7 +606,7 @@ static int rs690_startup(struct radeon_device *rdev) ...@@ -606,7 +606,7 @@ static int rs690_startup(struct radeon_device *rdev)
return r; return r;
/* Enable IRQ */ /* Enable IRQ */
rdev->irq.sw_int = true; rdev->irq.sw_int = true;
r100_irq_set(rdev); rs600_irq_set(rdev);
/* 1M ring buffer */ /* 1M ring buffer */
r = r100_cp_init(rdev, 1024 * 1024); r = r100_cp_init(rdev, 1024 * 1024);
if (r) { if (r) {
...@@ -647,7 +647,7 @@ int rs690_suspend(struct radeon_device *rdev) ...@@ -647,7 +647,7 @@ int rs690_suspend(struct radeon_device *rdev)
{ {
r100_cp_disable(rdev); r100_cp_disable(rdev);
r100_wb_disable(rdev); r100_wb_disable(rdev);
r100_irq_disable(rdev); rs600_irq_disable(rdev);
rs400_gart_disable(rdev); rs400_gart_disable(rdev);
return 0; return 0;
} }
......
...@@ -478,7 +478,7 @@ static int rv515_startup(struct radeon_device *rdev) ...@@ -478,7 +478,7 @@ static int rv515_startup(struct radeon_device *rdev)
} }
/* Enable IRQ */ /* Enable IRQ */
rdev->irq.sw_int = true; rdev->irq.sw_int = true;
r100_irq_set(rdev); rs600_irq_set(rdev);
/* 1M ring buffer */ /* 1M ring buffer */
r = r100_cp_init(rdev, 1024 * 1024); r = r100_cp_init(rdev, 1024 * 1024);
if (r) { if (r) {
...@@ -520,7 +520,7 @@ int rv515_suspend(struct radeon_device *rdev) ...@@ -520,7 +520,7 @@ int rv515_suspend(struct radeon_device *rdev)
{ {
r100_cp_disable(rdev); r100_cp_disable(rdev);
r100_wb_disable(rdev); r100_wb_disable(rdev);
r100_irq_disable(rdev); rs600_irq_disable(rdev);
if (rdev->flags & RADEON_IS_PCIE) if (rdev->flags & RADEON_IS_PCIE)
rv370_pcie_gart_disable(rdev); rv370_pcie_gart_disable(rdev);
return 0; return 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册