[PATCH i-g-t] tests/intel/xe_oa: Get stream status on read error

Umesh Nerlige Ramappa umesh.nerlige.ramappa at intel.com
Mon Apr 14 22:19:12 UTC 2025


On Thu, Apr 10, 2025 at 01:33:44PM -0700, Dixit, Ashutosh wrote:
>On Wed, 09 Apr 2025 16:34:41 -0700, Umesh Nerlige Ramappa wrote:
>>
>> Whenever read fails, get stream status so we know the state of OA status
>> bits.
>>
>> Signed-off-by: Umesh Nerlige Ramappa <umesh.nerlige.ramappa at intel.com>
>> ---
>>  tests/intel/xe_oa.c | 6 ++++++
>>  1 file changed, 6 insertions(+)
>>
>> diff --git a/tests/intel/xe_oa.c b/tests/intel/xe_oa.c
>> index 67acc74b3279..f3521c3d602e 100644
>> --- a/tests/intel/xe_oa.c
>> +++ b/tests/intel/xe_oa.c
>> @@ -2294,6 +2294,7 @@ static void test_polling_small_buf(void)
>>	errno = 0;
>>	ret = read(stream_fd, buf, sizeof(buf));
>>	igt_assert_eq(ret, -1);
>> +	get_stream_status(stream_fd);
>>	igt_assert_eq(errno, ENOSPC);
>>
>>	/* Poll with 0 timeout and expect POLLIN flag to be set */
>> @@ -2568,6 +2569,7 @@ test_enable_disable(const struct drm_xe_engine_class_instance *hwe)
>>	errno = 0;
>>	ret = read(stream_fd, buf, sizeof(buf));
>>	igt_assert_eq(ret, -1);
>> +	get_stream_status(stream_fd);
>>	igt_assert_eq(errno, EINVAL);
>>
>>	do_ioctl(stream_fd, DRM_XE_OBSERVATION_IOCTL_ENABLE, 0);
>> @@ -2584,6 +2586,7 @@ test_enable_disable(const struct drm_xe_engine_class_instance *hwe)
>>	/* Ensure num_reports can be read */
>>	while ((ret = read(stream_fd, buf, sizeof(buf))) < 0 && errno == EINTR)
>>		;
>> +	get_stream_status(stream_fd);
>>	igt_assert_eq(ret, sizeof(buf));
>
>Here read() is not failing, so maybe we should drop this one? Otherwise:

But here we could get an EIO for some strange reason and would be good 
to know if a specific status bit was set. The idea was to call 
get_stream_status in all places where read was called.

Thanks,
Umesh

>
>Reviewed-by: Ashutosh Dixit <ashutosh.dixit at intel.com>
>
>>
>>	__perf_close(stream_fd);
>> @@ -2727,6 +2730,7 @@ test_non_sampling_read_error(void)
>>
>>	ret = read(stream_fd, buf, sizeof(buf));
>>	igt_assert_eq(ret, -1);
>> +	get_stream_status(stream_fd);
>>	igt_assert_eq(errno, EINVAL);
>>
>>	__perf_close(stream_fd);
>> @@ -2768,6 +2772,7 @@ test_disabled_read_error(void)
>>
>>	ret = read(stream_fd, buf, sizeof(buf));
>>	igt_assert_eq(ret, -1);
>> +	get_stream_status(stream_fd);
>>	igt_assert_eq(errno, EINVAL);
>>
>>	__perf_close(stream_fd);
>> @@ -2786,6 +2791,7 @@ test_disabled_read_error(void)
>>
>>	ret = read(stream_fd, buf, sizeof(buf));
>>	igt_assert_eq(ret, -1);
>> +	get_stream_status(stream_fd);
>>	igt_assert_eq(errno, EINVAL);
>>
>>	do_ioctl(stream_fd, DRM_XE_OBSERVATION_IOCTL_ENABLE, 0);
>> --
>> 2.43.0
>>


More information about the igt-dev mailing list