drm/amdgpu: unify VM size handling of Vega10 with older generation
One function to rule them all. Signed-off-by: Christian König <christian.koenig@amd.com> Reviewed-by: Felix Kuehling <Felix.Kuehling@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
0410c5e514
commit
b38f41ebb8
@ -2573,21 +2573,6 @@ static uint32_t amdgpu_vm_get_block_size(uint64_t vm_size)
|
|||||||
return ((bits + 3) / 2);
|
return ((bits + 3) / 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* amdgpu_vm_set_fragment_size - adjust fragment size in PTE
|
|
||||||
*
|
|
||||||
* @adev: amdgpu_device pointer
|
|
||||||
* @fragment_size_default: the default fragment size if it's set auto
|
|
||||||
*/
|
|
||||||
void amdgpu_vm_set_fragment_size(struct amdgpu_device *adev,
|
|
||||||
uint32_t fragment_size_default)
|
|
||||||
{
|
|
||||||
if (amdgpu_vm_fragment_size == -1)
|
|
||||||
adev->vm_manager.fragment_size = fragment_size_default;
|
|
||||||
else
|
|
||||||
adev->vm_manager.fragment_size = amdgpu_vm_fragment_size;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* amdgpu_vm_adjust_size - adjust vm size, block size and fragment size
|
* amdgpu_vm_adjust_size - adjust vm size, block size and fragment size
|
||||||
*
|
*
|
||||||
@ -2595,22 +2580,29 @@ void amdgpu_vm_set_fragment_size(struct amdgpu_device *adev,
|
|||||||
* @vm_size: the default vm size if it's set auto
|
* @vm_size: the default vm size if it's set auto
|
||||||
*/
|
*/
|
||||||
void amdgpu_vm_adjust_size(struct amdgpu_device *adev, uint32_t vm_size,
|
void amdgpu_vm_adjust_size(struct amdgpu_device *adev, uint32_t vm_size,
|
||||||
uint32_t fragment_size_default)
|
uint32_t fragment_size_default, unsigned max_level)
|
||||||
{
|
{
|
||||||
/* adjust vm size firstly */
|
/* adjust vm size first, but only for two level setups for now */
|
||||||
if (amdgpu_vm_size != -1)
|
if (amdgpu_vm_size != -1 && max_level == 1)
|
||||||
vm_size = amdgpu_vm_size;
|
vm_size = amdgpu_vm_size;
|
||||||
|
|
||||||
adev->vm_manager.max_pfn = (uint64_t)vm_size << 18;
|
adev->vm_manager.max_pfn = (uint64_t)vm_size << 18;
|
||||||
|
adev->vm_manager.num_level = max_level;
|
||||||
|
|
||||||
/* block size depends on vm size */
|
/* block size depends on vm size and hw setup*/
|
||||||
if (amdgpu_vm_block_size == -1)
|
if (adev->vm_manager.num_level > 1)
|
||||||
|
/* Use fixed block_size for multi level page tables */
|
||||||
|
adev->vm_manager.block_size = 9;
|
||||||
|
else if (amdgpu_vm_block_size == -1)
|
||||||
adev->vm_manager.block_size =
|
adev->vm_manager.block_size =
|
||||||
amdgpu_vm_get_block_size(vm_size);
|
amdgpu_vm_get_block_size(vm_size);
|
||||||
else
|
else
|
||||||
adev->vm_manager.block_size = amdgpu_vm_block_size;
|
adev->vm_manager.block_size = amdgpu_vm_block_size;
|
||||||
|
|
||||||
amdgpu_vm_set_fragment_size(adev, fragment_size_default);
|
if (amdgpu_vm_fragment_size == -1)
|
||||||
|
adev->vm_manager.fragment_size = fragment_size_default;
|
||||||
|
else
|
||||||
|
adev->vm_manager.fragment_size = amdgpu_vm_fragment_size;
|
||||||
|
|
||||||
DRM_INFO("vm size is %u GB, block size is %u-bit, fragment size is %u-bit\n",
|
DRM_INFO("vm size is %u GB, block size is %u-bit, fragment size is %u-bit\n",
|
||||||
vm_size, adev->vm_manager.block_size,
|
vm_size, adev->vm_manager.block_size,
|
||||||
|
@ -324,10 +324,8 @@ struct amdgpu_bo_va_mapping *amdgpu_vm_bo_lookup_mapping(struct amdgpu_vm *vm,
|
|||||||
uint64_t addr);
|
uint64_t addr);
|
||||||
void amdgpu_vm_bo_rmv(struct amdgpu_device *adev,
|
void amdgpu_vm_bo_rmv(struct amdgpu_device *adev,
|
||||||
struct amdgpu_bo_va *bo_va);
|
struct amdgpu_bo_va *bo_va);
|
||||||
void amdgpu_vm_set_fragment_size(struct amdgpu_device *adev,
|
|
||||||
uint32_t fragment_size_default);
|
|
||||||
void amdgpu_vm_adjust_size(struct amdgpu_device *adev, uint32_t vm_size,
|
void amdgpu_vm_adjust_size(struct amdgpu_device *adev, uint32_t vm_size,
|
||||||
uint32_t fragment_size_default);
|
uint32_t fragment_size_default, unsigned max_level);
|
||||||
int amdgpu_vm_ioctl(struct drm_device *dev, void *data, struct drm_file *filp);
|
int amdgpu_vm_ioctl(struct drm_device *dev, void *data, struct drm_file *filp);
|
||||||
bool amdgpu_vm_need_pipeline_sync(struct amdgpu_ring *ring,
|
bool amdgpu_vm_need_pipeline_sync(struct amdgpu_ring *ring,
|
||||||
struct amdgpu_job *job);
|
struct amdgpu_job *job);
|
||||||
|
@ -832,7 +832,7 @@ static int gmc_v6_0_sw_init(void *handle)
|
|||||||
if (r)
|
if (r)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
amdgpu_vm_adjust_size(adev, 64, 9);
|
amdgpu_vm_adjust_size(adev, 64, 9, 1);
|
||||||
|
|
||||||
adev->mc.mc_mask = 0xffffffffffULL;
|
adev->mc.mc_mask = 0xffffffffffULL;
|
||||||
|
|
||||||
@ -877,7 +877,6 @@ static int gmc_v6_0_sw_init(void *handle)
|
|||||||
* amdkfd will use VMIDs 8-15
|
* amdkfd will use VMIDs 8-15
|
||||||
*/
|
*/
|
||||||
adev->vm_manager.id_mgr[0].num_ids = AMDGPU_NUM_OF_VMIDS;
|
adev->vm_manager.id_mgr[0].num_ids = AMDGPU_NUM_OF_VMIDS;
|
||||||
adev->vm_manager.num_level = 1;
|
|
||||||
amdgpu_vm_manager_init(adev);
|
amdgpu_vm_manager_init(adev);
|
||||||
|
|
||||||
/* base offset of vram pages */
|
/* base offset of vram pages */
|
||||||
|
@ -971,7 +971,7 @@ static int gmc_v7_0_sw_init(void *handle)
|
|||||||
* Currently set to 4GB ((1 << 20) 4k pages).
|
* Currently set to 4GB ((1 << 20) 4k pages).
|
||||||
* Max GPUVM size for cayman and SI is 40 bits.
|
* Max GPUVM size for cayman and SI is 40 bits.
|
||||||
*/
|
*/
|
||||||
amdgpu_vm_adjust_size(adev, 64, 9);
|
amdgpu_vm_adjust_size(adev, 64, 9, 1);
|
||||||
|
|
||||||
/* Set the internal MC address mask
|
/* Set the internal MC address mask
|
||||||
* This is the max address of the GPU's
|
* This is the max address of the GPU's
|
||||||
@ -1026,7 +1026,6 @@ static int gmc_v7_0_sw_init(void *handle)
|
|||||||
* amdkfd will use VMIDs 8-15
|
* amdkfd will use VMIDs 8-15
|
||||||
*/
|
*/
|
||||||
adev->vm_manager.id_mgr[0].num_ids = AMDGPU_NUM_OF_VMIDS;
|
adev->vm_manager.id_mgr[0].num_ids = AMDGPU_NUM_OF_VMIDS;
|
||||||
adev->vm_manager.num_level = 1;
|
|
||||||
amdgpu_vm_manager_init(adev);
|
amdgpu_vm_manager_init(adev);
|
||||||
|
|
||||||
/* base offset of vram pages */
|
/* base offset of vram pages */
|
||||||
|
@ -1068,7 +1068,7 @@ static int gmc_v8_0_sw_init(void *handle)
|
|||||||
* Currently set to 4GB ((1 << 20) 4k pages).
|
* Currently set to 4GB ((1 << 20) 4k pages).
|
||||||
* Max GPUVM size for cayman and SI is 40 bits.
|
* Max GPUVM size for cayman and SI is 40 bits.
|
||||||
*/
|
*/
|
||||||
amdgpu_vm_adjust_size(adev, 64, 9);
|
amdgpu_vm_adjust_size(adev, 64, 9, 1);
|
||||||
|
|
||||||
/* Set the internal MC address mask
|
/* Set the internal MC address mask
|
||||||
* This is the max address of the GPU's
|
* This is the max address of the GPU's
|
||||||
@ -1123,7 +1123,6 @@ static int gmc_v8_0_sw_init(void *handle)
|
|||||||
* amdkfd will use VMIDs 8-15
|
* amdkfd will use VMIDs 8-15
|
||||||
*/
|
*/
|
||||||
adev->vm_manager.id_mgr[0].num_ids = AMDGPU_NUM_OF_VMIDS;
|
adev->vm_manager.id_mgr[0].num_ids = AMDGPU_NUM_OF_VMIDS;
|
||||||
adev->vm_manager.num_level = 1;
|
|
||||||
amdgpu_vm_manager_init(adev);
|
amdgpu_vm_manager_init(adev);
|
||||||
|
|
||||||
/* base offset of vram pages */
|
/* base offset of vram pages */
|
||||||
|
@ -769,16 +769,11 @@ static int gmc_v9_0_sw_init(void *handle)
|
|||||||
switch (adev->asic_type) {
|
switch (adev->asic_type) {
|
||||||
case CHIP_RAVEN:
|
case CHIP_RAVEN:
|
||||||
adev->mc.vram_type = AMDGPU_VRAM_TYPE_UNKNOWN;
|
adev->mc.vram_type = AMDGPU_VRAM_TYPE_UNKNOWN;
|
||||||
if (adev->rev_id == 0x0 || adev->rev_id == 0x1) {
|
if (adev->rev_id == 0x0 || adev->rev_id == 0x1)
|
||||||
adev->vm_manager.max_pfn = 1ULL << 36;
|
amdgpu_vm_adjust_size(adev, 256 * 1024, 9, 3);
|
||||||
adev->vm_manager.block_size = 9;
|
else
|
||||||
adev->vm_manager.num_level = 3;
|
|
||||||
amdgpu_vm_set_fragment_size(adev, 9);
|
|
||||||
} else {
|
|
||||||
/* vm_size is 64GB for legacy 2-level page support */
|
/* vm_size is 64GB for legacy 2-level page support */
|
||||||
amdgpu_vm_adjust_size(adev, 64, 9);
|
amdgpu_vm_adjust_size(adev, 64, 9, 1);
|
||||||
adev->vm_manager.num_level = 1;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case CHIP_VEGA10:
|
case CHIP_VEGA10:
|
||||||
/* XXX Don't know how to get VRAM type yet. */
|
/* XXX Don't know how to get VRAM type yet. */
|
||||||
@ -788,19 +783,12 @@ static int gmc_v9_0_sw_init(void *handle)
|
|||||||
* vm size is 256TB (48bit), maximum size of Vega10,
|
* vm size is 256TB (48bit), maximum size of Vega10,
|
||||||
* block size 512 (9bit)
|
* block size 512 (9bit)
|
||||||
*/
|
*/
|
||||||
adev->vm_manager.max_pfn = 1ULL << 36;
|
amdgpu_vm_adjust_size(adev, 256 * 1024, 9, 3);
|
||||||
adev->vm_manager.block_size = 9;
|
|
||||||
adev->vm_manager.num_level = 3;
|
|
||||||
amdgpu_vm_set_fragment_size(adev, 9);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
DRM_INFO("vm size is %llu GB, block size is %u-bit, fragment size is %u-bit\n",
|
|
||||||
adev->vm_manager.max_pfn >> 18, adev->vm_manager.block_size,
|
|
||||||
adev->vm_manager.fragment_size);
|
|
||||||
|
|
||||||
/* This interrupt is VMC page fault.*/
|
/* This interrupt is VMC page fault.*/
|
||||||
r = amdgpu_irq_add_id(adev, AMDGPU_IH_CLIENTID_VMC, 0,
|
r = amdgpu_irq_add_id(adev, AMDGPU_IH_CLIENTID_VMC, 0,
|
||||||
&adev->mc.vm_fault);
|
&adev->mc.vm_fault);
|
||||||
|
Loading…
Reference in New Issue
Block a user