[PATCH] drm/ttm: stop warning on TT shrinker failure

Christian König ckoenig.leichtzumerken at gmail.com
Fri Mar 19 18:53:48 UTC 2021


Am 19.03.21 um 18:52 schrieb Daniel Vetter:
> On Fri, Mar 19, 2021 at 03:08:57PM +0100, Christian König wrote:
>> Don't print a warning when we fail to allocate a page for swapping things out.
>>
>> Also rely on memalloc_nofs_save/memalloc_nofs_restore instead of GFP_NOFS.
> Uh this part doesn't make sense. Especially since you only do it for the
> debugfs file, not in general. Which means you've just completely broken
> the shrinker.

Are you sure? My impression is that GFP_NOFS should now work much more 
out of the box with the memalloc_nofs_save()/memalloc_nofs_restore().

> If this is just to paper over the seq_printf doing the wrong allocations,
> then just move that out from under the fs_reclaim_acquire/release part.

No, that wasn't the problem.

We have just seen to many failures to allocate pages for swapout and I 
think that would improve this because in a lot of cases we can then 
immediately swap things out instead of having to rely on upper layers.

Regards,
Christian.


>
> __GFP_NOWARN should be there indeed I think.
> -Daniel
>
>> Signed-off-by: Christian König <christian.koenig at amd.com>
>> ---
>>   drivers/gpu/drm/ttm/ttm_tt.c | 5 ++++-
>>   1 file changed, 4 insertions(+), 1 deletion(-)
>>
>> diff --git a/drivers/gpu/drm/ttm/ttm_tt.c b/drivers/gpu/drm/ttm/ttm_tt.c
>> index 2f0833c98d2c..86fa3e82dacc 100644
>> --- a/drivers/gpu/drm/ttm/ttm_tt.c
>> +++ b/drivers/gpu/drm/ttm/ttm_tt.c
>> @@ -369,7 +369,7 @@ static unsigned long ttm_tt_shrinker_scan(struct shrinker *shrink,
>>   	};
>>   	int ret;
>>   
>> -	ret = ttm_bo_swapout(&ctx, GFP_NOFS);
>> +	ret = ttm_bo_swapout(&ctx, GFP_KERNEL | __GFP_NOWARN);
>>   	return ret < 0 ? SHRINK_EMPTY : ret;
>>   }
>>   
>> @@ -389,10 +389,13 @@ static unsigned long ttm_tt_shrinker_count(struct shrinker *shrink,
>>   static int ttm_tt_debugfs_shrink_show(struct seq_file *m, void *data)
>>   {
>>   	struct shrink_control sc = { .gfp_mask = GFP_KERNEL };
>> +	unsigned int flags;
>>   
>>   	fs_reclaim_acquire(GFP_KERNEL);
>> +	flags = memalloc_nofs_save();
>>   	seq_printf(m, "%lu/%lu\n", ttm_tt_shrinker_count(&mm_shrinker, &sc),
>>   		   ttm_tt_shrinker_scan(&mm_shrinker, &sc));
>> +	memalloc_nofs_restore(flags);
>>   	fs_reclaim_release(GFP_KERNEL);
>>   
>>   	return 0;
>> -- 
>> 2.25.1
>>
>> _______________________________________________
>> dri-devel mailing list
>> dri-devel at lists.freedesktop.org
>> https://lists.freedesktop.org/mailman/listinfo/dri-devel



More information about the dri-devel mailing list