mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-11-27 01:11:31 +00:00
drm/radeon: add proper support for RADEON_VM_BLOCK_SIZE v2
This patch makes it possible to decide how many address bits are spend on the page directory vs the page tables. v2: remove unintended change Signed-off-by: Christian König <christian.koenig@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
ec3dbbcbd7
commit
1c89d27fb9
7 changed files with 9 additions and 1 deletions
|
|
@ -5378,6 +5378,7 @@ static int cik_pcie_gart_enable(struct radeon_device *rdev)
|
||||||
(u32)(rdev->dummy_page.addr >> 12));
|
(u32)(rdev->dummy_page.addr >> 12));
|
||||||
WREG32(VM_CONTEXT1_CNTL2, 4);
|
WREG32(VM_CONTEXT1_CNTL2, 4);
|
||||||
WREG32(VM_CONTEXT1_CNTL, ENABLE_CONTEXT | PAGE_TABLE_DEPTH(1) |
|
WREG32(VM_CONTEXT1_CNTL, ENABLE_CONTEXT | PAGE_TABLE_DEPTH(1) |
|
||||||
|
PAGE_TABLE_BLOCK_SIZE(RADEON_VM_BLOCK_SIZE - 9) |
|
||||||
RANGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
RANGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
||||||
RANGE_PROTECTION_FAULT_ENABLE_DEFAULT |
|
RANGE_PROTECTION_FAULT_ENABLE_DEFAULT |
|
||||||
DUMMY_PAGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
DUMMY_PAGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
||||||
|
|
|
||||||
|
|
@ -482,6 +482,7 @@
|
||||||
#define READ_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 16)
|
#define READ_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 16)
|
||||||
#define WRITE_PROTECTION_FAULT_ENABLE_INTERRUPT (1 << 18)
|
#define WRITE_PROTECTION_FAULT_ENABLE_INTERRUPT (1 << 18)
|
||||||
#define WRITE_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 19)
|
#define WRITE_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 19)
|
||||||
|
#define PAGE_TABLE_BLOCK_SIZE(x) (((x) & 0xF) << 24)
|
||||||
#define VM_CONTEXT1_CNTL 0x1414
|
#define VM_CONTEXT1_CNTL 0x1414
|
||||||
#define VM_CONTEXT0_CNTL2 0x1430
|
#define VM_CONTEXT0_CNTL2 0x1430
|
||||||
#define VM_CONTEXT1_CNTL2 0x1434
|
#define VM_CONTEXT1_CNTL2 0x1434
|
||||||
|
|
|
||||||
|
|
@ -1268,6 +1268,7 @@ static int cayman_pcie_gart_enable(struct radeon_device *rdev)
|
||||||
(u32)(rdev->dummy_page.addr >> 12));
|
(u32)(rdev->dummy_page.addr >> 12));
|
||||||
WREG32(VM_CONTEXT1_CNTL2, 4);
|
WREG32(VM_CONTEXT1_CNTL2, 4);
|
||||||
WREG32(VM_CONTEXT1_CNTL, ENABLE_CONTEXT | PAGE_TABLE_DEPTH(1) |
|
WREG32(VM_CONTEXT1_CNTL, ENABLE_CONTEXT | PAGE_TABLE_DEPTH(1) |
|
||||||
|
PAGE_TABLE_BLOCK_SIZE(RADEON_VM_BLOCK_SIZE - 9) |
|
||||||
RANGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
RANGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
||||||
RANGE_PROTECTION_FAULT_ENABLE_DEFAULT |
|
RANGE_PROTECTION_FAULT_ENABLE_DEFAULT |
|
||||||
DUMMY_PAGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
DUMMY_PAGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
||||||
|
|
|
||||||
|
|
@ -128,6 +128,7 @@
|
||||||
#define READ_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 16)
|
#define READ_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 16)
|
||||||
#define WRITE_PROTECTION_FAULT_ENABLE_INTERRUPT (1 << 18)
|
#define WRITE_PROTECTION_FAULT_ENABLE_INTERRUPT (1 << 18)
|
||||||
#define WRITE_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 19)
|
#define WRITE_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 19)
|
||||||
|
#define PAGE_TABLE_BLOCK_SIZE(x) (((x) & 0xF) << 24)
|
||||||
#define VM_CONTEXT1_CNTL 0x1414
|
#define VM_CONTEXT1_CNTL 0x1414
|
||||||
#define VM_CONTEXT0_CNTL2 0x1430
|
#define VM_CONTEXT0_CNTL2 0x1430
|
||||||
#define VM_CONTEXT1_CNTL2 0x1434
|
#define VM_CONTEXT1_CNTL2 0x1434
|
||||||
|
|
|
||||||
|
|
@ -964,6 +964,8 @@ void radeon_vm_bo_invalidate(struct radeon_device *rdev,
|
||||||
*/
|
*/
|
||||||
int radeon_vm_init(struct radeon_device *rdev, struct radeon_vm *vm)
|
int radeon_vm_init(struct radeon_device *rdev, struct radeon_vm *vm)
|
||||||
{
|
{
|
||||||
|
const unsigned align = min(RADEON_VM_PTB_ALIGN_SIZE,
|
||||||
|
RADEON_VM_PTE_COUNT * 8);
|
||||||
unsigned pd_size, pd_entries, pts_size;
|
unsigned pd_size, pd_entries, pts_size;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
|
|
@ -985,7 +987,7 @@ int radeon_vm_init(struct radeon_device *rdev, struct radeon_vm *vm)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
r = radeon_bo_create(rdev, pd_size, RADEON_VM_PTB_ALIGN_SIZE, false,
|
r = radeon_bo_create(rdev, pd_size, align, false,
|
||||||
RADEON_GEM_DOMAIN_VRAM, NULL,
|
RADEON_GEM_DOMAIN_VRAM, NULL,
|
||||||
&vm->page_directory);
|
&vm->page_directory);
|
||||||
if (r)
|
if (r)
|
||||||
|
|
|
||||||
|
|
@ -4095,6 +4095,7 @@ static int si_pcie_gart_enable(struct radeon_device *rdev)
|
||||||
(u32)(rdev->dummy_page.addr >> 12));
|
(u32)(rdev->dummy_page.addr >> 12));
|
||||||
WREG32(VM_CONTEXT1_CNTL2, 4);
|
WREG32(VM_CONTEXT1_CNTL2, 4);
|
||||||
WREG32(VM_CONTEXT1_CNTL, ENABLE_CONTEXT | PAGE_TABLE_DEPTH(1) |
|
WREG32(VM_CONTEXT1_CNTL, ENABLE_CONTEXT | PAGE_TABLE_DEPTH(1) |
|
||||||
|
PAGE_TABLE_BLOCK_SIZE(RADEON_VM_BLOCK_SIZE - 9) |
|
||||||
RANGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
RANGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
||||||
RANGE_PROTECTION_FAULT_ENABLE_DEFAULT |
|
RANGE_PROTECTION_FAULT_ENABLE_DEFAULT |
|
||||||
DUMMY_PAGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
DUMMY_PAGE_PROTECTION_FAULT_ENABLE_INTERRUPT |
|
||||||
|
|
|
||||||
|
|
@ -362,6 +362,7 @@
|
||||||
#define READ_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 16)
|
#define READ_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 16)
|
||||||
#define WRITE_PROTECTION_FAULT_ENABLE_INTERRUPT (1 << 18)
|
#define WRITE_PROTECTION_FAULT_ENABLE_INTERRUPT (1 << 18)
|
||||||
#define WRITE_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 19)
|
#define WRITE_PROTECTION_FAULT_ENABLE_DEFAULT (1 << 19)
|
||||||
|
#define PAGE_TABLE_BLOCK_SIZE(x) (((x) & 0xF) << 24)
|
||||||
#define VM_CONTEXT1_CNTL 0x1414
|
#define VM_CONTEXT1_CNTL 0x1414
|
||||||
#define VM_CONTEXT0_CNTL2 0x1430
|
#define VM_CONTEXT0_CNTL2 0x1430
|
||||||
#define VM_CONTEXT1_CNTL2 0x1434
|
#define VM_CONTEXT1_CNTL2 0x1434
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue