[igt-dev] [PATCH i-g-t 1/1] tests/kms_rotation_crc: multiplane-rotation* faster

Jani Nikula jani.nikula at linux.intel.com
Mon Apr 29 09:33:10 UTC 2019


On Fri, 26 Apr 2019, Caz Yokoyama <Caz.Yokoyama at intel.com> wrote:
> Drop because nobody respond. Maybe because of one of
> - 42% faster has no value
> - the patch breaks purpose of the test.
> -caz

Or just maybe because there are 1000+ posts on the list per month,
everyone is busy, and the commit message could be clearer about what the
tradeoff is to make the test faster?

If nobody responds within a week or two, please ping for reviews either
on the list or on freenode #intel-gfx IRC channel. Or both. Please don't
just silently wait and build up frustration/anger when it could simply
be that the patch slipped through the cracks.


BR,
Jani.


>
> On Wed, 2019-04-03 at 12:11 -0700, Caz Yokoyama wrote:
>> by rotating 1/4 of data.
>> 
>> The test rotated 20% horizontally, 40% vertically of 1920x1200
>> display
>> plane. This patch makes them 10% and 20% respectively.
>> 
>> paint_squares(), igt_display_try_commit2() and igt_pipe_crc_current()
>> consume 99% of whole test. By this patch, paint_squares() and
>> igt_display_try_commit2() run 42% faster. Remaining
>> igt_pipe_crc_current()
>> runs same because it is synchronized with vsync.
>> multiplane-rotation-cropping-bottom sub test runs 22% faster.
>> 
>> Signed-off-by: Caz Yokoyama <caz.yokoyama at intel.com>
>> Cc: Chris Wilson <chris at chris-wilson.co.uk>
>> ---
>>  tests/kms_rotation_crc.c | 48 ++++++++++++++++++++----------------
>> ----
>>  1 file changed, 24 insertions(+), 24 deletions(-)
>> 
>> diff --git a/tests/kms_rotation_crc.c b/tests/kms_rotation_crc.c
>> index fc995d07..e0ba83da 100644
>> --- a/tests/kms_rotation_crc.c
>> +++ b/tests/kms_rotation_crc.c
>> @@ -534,18 +534,18 @@ static void test_multi_plane_rotation(data_t
>> *data, enum pipe pipe)
>>  		float_t height;
>>  		uint64_t tiling;
>>  	} planeconfigs[] = {
>> -	{IGT_ROTATION_0, .2f, .4f, LOCAL_DRM_FORMAT_MOD_NONE },
>> -	{IGT_ROTATION_0, .2f, .4f, LOCAL_I915_FORMAT_MOD_X_TILED },
>> -	{IGT_ROTATION_0, .2f, .4f, LOCAL_I915_FORMAT_MOD_Y_TILED },
>> -	{IGT_ROTATION_0, .2f, .4f, LOCAL_I915_FORMAT_MOD_Yf_TILED },
>> -	{IGT_ROTATION_90, .2f, .4f, LOCAL_I915_FORMAT_MOD_Y_TILED },
>> -	{IGT_ROTATION_90, .2f, .4f, LOCAL_I915_FORMAT_MOD_Yf_TILED },
>> -	{IGT_ROTATION_180, .2f, .4f, LOCAL_DRM_FORMAT_MOD_NONE },
>> -	{IGT_ROTATION_180, .2f, .4f, LOCAL_I915_FORMAT_MOD_X_TILED },
>> -	{IGT_ROTATION_180, .2f, .4f, LOCAL_I915_FORMAT_MOD_Y_TILED },
>> -	{IGT_ROTATION_180, .2f, .4f, LOCAL_I915_FORMAT_MOD_Yf_TILED },
>> -	{IGT_ROTATION_270, .2f, .4f, LOCAL_I915_FORMAT_MOD_Y_TILED },
>> -	{IGT_ROTATION_270, .2f, .4f, LOCAL_I915_FORMAT_MOD_Yf_TILED },
>> +	{IGT_ROTATION_0, .1f, .2f, LOCAL_DRM_FORMAT_MOD_NONE },
>> +	{IGT_ROTATION_0, .1f, .2f, LOCAL_I915_FORMAT_MOD_X_TILED },
>> +	{IGT_ROTATION_0, .1f, .2f, LOCAL_I915_FORMAT_MOD_Y_TILED },
>> +	{IGT_ROTATION_0, .1f, .2f, LOCAL_I915_FORMAT_MOD_Yf_TILED },
>> +	{IGT_ROTATION_90, .1f, .2f, LOCAL_I915_FORMAT_MOD_Y_TILED },
>> +	{IGT_ROTATION_90, .1f, .2f, LOCAL_I915_FORMAT_MOD_Yf_TILED },
>> +	{IGT_ROTATION_180, .1f, .2f, LOCAL_DRM_FORMAT_MOD_NONE },
>> +	{IGT_ROTATION_180, .1f, .2f, LOCAL_I915_FORMAT_MOD_X_TILED },
>> +	{IGT_ROTATION_180, .1f, .2f, LOCAL_I915_FORMAT_MOD_Y_TILED },
>> +	{IGT_ROTATION_180, .1f, .2f, LOCAL_I915_FORMAT_MOD_Yf_TILED },
>> +	{IGT_ROTATION_270, .1f, .2f, LOCAL_I915_FORMAT_MOD_Y_TILED },
>> +	{IGT_ROTATION_270, .1f, .2f, LOCAL_I915_FORMAT_MOD_Yf_TILED },
>>  	};
>>  
>>  	/*
>> @@ -842,11 +842,11 @@ igt_main
>>  		igt_require(gen >= 9);
>>  		cleanup_crtc(&data);
>>  		data.planepos[0].origo = p_top | p_left;
>> -		data.planepos[0].x = .2f;
>> -		data.planepos[0].y = .1f;
>> +		data.planepos[0].x = .1f;
>> +		data.planepos[0].y = .05f;
>>  		data.planepos[1].origo = p_top | p_right;
>> -		data.planepos[1].x = -.4f;
>> -		data.planepos[1].y = .1f;
>> +		data.planepos[1].x = -.2f;
>> +		data.planepos[1].y = .05f;
>>  		test_multi_plane_rotation(&data, 0);
>>  	}
>>  
>> @@ -854,11 +854,11 @@ igt_main
>>  		igt_require(gen >= 9);
>>  		cleanup_crtc(&data);
>>  		data.planepos[0].origo = p_top | p_left;
>> -		data.planepos[0].x = -.05f;
>> -		data.planepos[0].y = -.15f;
>> +		data.planepos[0].x = -.025f;
>> +		data.planepos[0].y = -.075f;
>>  		data.planepos[1].origo = p_top | p_right;
>> -		data.planepos[1].x = -.15f;
>> -		data.planepos[1].y = -.15f;
>> +		data.planepos[1].x = -.075f;
>> +		data.planepos[1].y = -.075f;
>>  		test_multi_plane_rotation(&data, 0);
>>  	}
>>  
>> @@ -866,11 +866,11 @@ igt_main
>>  		igt_require(gen >= 9);
>>  		cleanup_crtc(&data);
>>  		data.planepos[0].origo = p_bottom | p_left;
>> -		data.planepos[0].x = -.05f;
>> -		data.planepos[0].y = -.20f;
>> +		data.planepos[0].x = -.025f;
>> +		data.planepos[0].y = -.10f;
>>  		data.planepos[1].origo = p_bottom | p_right;
>> -		data.planepos[1].x = -.15f;
>> -		data.planepos[1].y = -.20f;
>> +		data.planepos[1].x = -.075f;
>> +		data.planepos[1].y = -.10f;
>>  		test_multi_plane_rotation(&data, 0);
>>  	}
>>  
>
> _______________________________________________
> igt-dev mailing list
> igt-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/igt-dev

-- 
Jani Nikula, Intel Open Source Graphics Center


More information about the igt-dev mailing list