[PATCH] drm/radeon: adjust default radeon_vm_block_size

Grigori Goronzy greg at chown.ath.cx
Sat Jul 19 05:37:22 PDT 2014


On 19.07.2014 13:57, Christian König wrote:
> Yeah, I'm still playing a bit with this.
> 
> You need to consider the page directory size as well. If we have 4GB
> address space (32bits) and 12bits in the page, 12bits in the page tables
> then there are only 8bits for the page directory, right?
>
> Now 8bits for the page directory means we have 256 entries with 8bytes
> for each entry that makes 2048 bytes for the page directory. But since
> we allocate 4096 bytes for the page directory anyway we could support
> 8GB address space as well.
>

Yes, that's right... good idea. Larger VM space should also help a bit
with fragmentation under memory pressure, right?

> How about the v2 I've just send out to the list? It also adjusts the
> vm_size to a default of 8GB and let you get vm_block_sizes according to
> the following table:
>

Looks good, I think.

> vm_size         vm_block_size
> 1GB        =    9
> 2GB        =    10
> 4GB        =    11
> 8GB        =    12
> 16GB      =    12
> 32GB      =    13
> 64GB      =    13
> 128GB    =    14
> 256GB    =    14
> 512GB    =    15
> 1TB        =    15
> 
> Regards,
> Christian.
> 
> Am 18.07.2014 22:03, schrieb Grigori Goronzy:
>> On 18.07.2014 11:38, Christian König wrote:
>>> From: Christian König <christian.koenig at amd.com>
>>>
>>> Signed-off-by: Christian König <christian.koenig at amd.com>
>>> ---
>>>   drivers/gpu/drm/radeon/radeon_device.c | 6 +++++-
>>>   drivers/gpu/drm/radeon/radeon_drv.c    | 4 ++--
>>>   2 files changed, 7 insertions(+), 3 deletions(-)
>>>
>>> diff --git a/drivers/gpu/drm/radeon/radeon_device.c
>>> b/drivers/gpu/drm/radeon/radeon_device.c
>>> index 03686fa..a2960db 100644
>>> --- a/drivers/gpu/drm/radeon/radeon_device.c
>>> +++ b/drivers/gpu/drm/radeon/radeon_device.c
>>> @@ -1077,7 +1077,11 @@ static void radeon_check_arguments(struct
>>> radeon_device *rdev)
>>>       /* defines number of bits in page table versus page directory,
>>>        * a page is 4KB so we have 12 bits offset, minimum 9 bits in the
>>>        * page table and the remaining bits are in the page directory */
>>> -    if (radeon_vm_block_size < 9) {
>>> +    if (radeon_vm_block_size == -1) {
>>> +        radeon_vm_block_size = (ilog2(radeon_vm_size) + 10) / 2;
>>> +        radeon_vm_block_size = max(radeon_vm_block_size, 9);
>>> +
>>> +    } else if (radeon_vm_block_size < 9) {
>> Hm, that automatic calculation seems strange. Is there any particular
>> reason why you haven chosen this? This will use vm_block_size=11 for
>> 4096 MB VM space. I have used vm_block_size=12 with good results. This
>> manages 16 MB of VM space per page table, which seems reasonable. I also
>> see a noticeable CPU overhead reduction between 11 and 12.
>>
>> Grigori
>>
>>>           dev_warn(rdev->dev, "VM page table size (%d) to small\n",
>>>                radeon_vm_block_size);
>>>           radeon_vm_block_size = 9;
>>> diff --git a/drivers/gpu/drm/radeon/radeon_drv.c
>>> b/drivers/gpu/drm/radeon/radeon_drv.c
>>> index cb14213..fef5320 100644
>>> --- a/drivers/gpu/drm/radeon/radeon_drv.c
>>> +++ b/drivers/gpu/drm/radeon/radeon_drv.c
>>> @@ -174,7 +174,7 @@ int radeon_aspm = -1;
>>>   int radeon_runtime_pm = -1;
>>>   int radeon_hard_reset = 0;
>>>   int radeon_vm_size = 4096;
>>> -int radeon_vm_block_size = 9;
>>> +int radeon_vm_block_size = -1;
>>>   int radeon_deep_color = 0;
>>>     MODULE_PARM_DESC(no_wb, "Disable AGP writeback for scratch
>>> registers");
>>> @@ -246,7 +246,7 @@ module_param_named(hard_reset, radeon_hard_reset,
>>> int, 0444);
>>>   MODULE_PARM_DESC(vm_size, "VM address space size in megabytes
>>> (default 4GB)");
>>>   module_param_named(vm_size, radeon_vm_size, int, 0444);
>>>   -MODULE_PARM_DESC(vm_block_size, "VM page table size in bits
>>> (default 9)");
>>> +MODULE_PARM_DESC(vm_block_size, "VM page table size in bits (default
>>> depending on vm_size)");
>>>   module_param_named(vm_block_size, radeon_vm_block_size, int, 0444);
>>>     MODULE_PARM_DESC(deep_color, "Deep Color support (1 = enable, 0 =
>>> disable (default))");
>>>
>>
> 


-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 246 bytes
Desc: OpenPGP digital signature
URL: <http://lists.freedesktop.org/archives/dri-devel/attachments/20140719/30d5e92a/attachment-0001.sig>


More information about the dri-devel mailing list