From: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>
To: igt-dev@lists.freedesktop.org, Ashutosh Dixit <ashutosh.dixit@intel.com>
Subject: [PATCH i-g-t v2 08/14] tests/intel/xe_oa: Simplify the buffer-fill test
Date: Mon, 3 Mar 2025 15:14:56 -0800 [thread overview]
Message-ID: <20250303231502.135720-9-umesh.nerlige.ramappa@intel.com> (raw)
In-Reply-To: <20250303231502.135720-1-umesh.nerlige.ramappa@intel.com>
Simplify the buffer-fill test for quicker runs on slow platforms.
We only want to test that the BUFFER OVERFLOW status is set when we do
not read the OA stream data in time. To do so, keeping reading zero
bytes of data until you hit a buffer overflow.
v2:
- Add reason to the commit msg
- Drop 'wraparound' from test description
- s/disable/disabled
- drop unnecessary double-bang for int to bool conversion
- Fix regression in test execution time
Signed-off-by: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>
Reviewed-by: Ashutosh Dixit <ashutosh.dixit@intel.com>
---
tests/intel/xe_oa.c | 128 +++++++++-----------------------------------
1 file changed, 24 insertions(+), 104 deletions(-)
diff --git a/tests/intel/xe_oa.c b/tests/intel/xe_oa.c
index dd16b39a9..3b9f13d9e 100644
--- a/tests/intel/xe_oa.c
+++ b/tests/intel/xe_oa.c
@@ -304,6 +304,7 @@ static size_t default_oa_buffer_size;
static struct intel_mmio_data mmio_data;
static igt_render_copyfunc_t render_copy;
static uint32_t rc_width, rc_height;
+static uint32_t buffer_fill_size;
static struct intel_xe_perf_metric_set *metric_set(const struct drm_xe_engine_class_instance *hwe)
{
@@ -1092,6 +1093,7 @@ init_sys_info(void)
rc_width = 1920;
rc_height = 1080;
+ buffer_fill_size = SZ_16M;
oa_exponent_default = max_oa_exponent_for_period_lte(1000000);
default_oa_buffer_size = get_default_oa_buffer_size(drm_fd);
@@ -2352,7 +2354,7 @@ test_oa_tlb_invalidate(const struct drm_xe_engine_class_instance *hwe)
/**
* SUBTEST: buffer-fill
- * Description: Test filling, wraparound and overflow of OA buffer
+ * Description: Test filling and overflow of OA buffer
*/
static void
test_buffer_fill(const struct drm_xe_engine_class_instance *hwe)
@@ -2373,123 +2375,41 @@ test_buffer_fill(const struct drm_xe_engine_class_instance *hwe)
DRM_XE_OA_PROPERTY_OA_FORMAT, __ff(fmt),
DRM_XE_OA_PROPERTY_OA_PERIOD_EXPONENT, oa_exponent,
DRM_XE_OA_PROPERTY_OA_ENGINE_INSTANCE, hwe->engine_instance,
+ DRM_XE_OA_PROPERTY_OA_DISABLED, true,
+ DRM_XE_OA_PROPERTY_OA_BUFFER_SIZE, buffer_fill_size,
};
struct intel_xe_oa_open_prop param = {
.num_properties = ARRAY_SIZE(properties) / 2,
.properties_ptr = to_user_pointer(properties),
};
- size_t report_size = get_oa_format(fmt).size;
- int buf_size = 65536 * report_size;
- uint8_t *buf = malloc(buf_size);
- int len;
- int n_full_oa_reports = default_oa_buffer_size / report_size;
- uint64_t fill_duration = n_full_oa_reports * oa_period;
- uint32_t *last_periodic_report = malloc(report_size);
+ char *buf = malloc(1024);
+ bool overflow_seen;
u32 oa_status;
+ int len;
- igt_assert(fill_duration < 1000000000);
-
+ igt_debug("oa_period %s\n", pretty_print_oa_period(oa_period));
stream_fd = __perf_open(drm_fd, ¶m, true /* prevent_pm */);
set_fd_flags(stream_fd, O_CLOEXEC);
- for (int i = 0; i < 5; i++) {
- bool overflow_seen;
- uint32_t n_periodic_reports;
- uint32_t first_timestamp = 0, last_timestamp = 0;
-
- do_ioctl(stream_fd, DRM_XE_OBSERVATION_IOCTL_ENABLE, 0);
-
- nanosleep(&(struct timespec){ .tv_sec = 0,
- .tv_nsec = fill_duration * 1.25 },
- NULL);
-again:
- oa_status = 0;
- while ((len = read(stream_fd, buf, buf_size)) == -1 && errno == EINTR)
- ;
-
- if (errno == EIO) {
- oa_status = get_stream_status(stream_fd);
- igt_debug("oa_status %#x\n", oa_status);
- overflow_seen = oa_status & DRM_XE_OASTATUS_BUFFER_OVERFLOW;
- igt_assert_eq(overflow_seen, true);
- goto again;
- }
- igt_assert_neq(len, -1);
-
- do_ioctl(stream_fd, DRM_XE_OBSERVATION_IOCTL_DISABLE, 0);
-
- igt_debug("fill_duration = %"PRIu64"ns, oa_exponent = %u\n",
- fill_duration, oa_exponent);
-
- do_ioctl(stream_fd, DRM_XE_OBSERVATION_IOCTL_ENABLE, 0);
-
- nanosleep(&(struct timespec){ .tv_sec = 0,
- .tv_nsec = fill_duration / 2 },
- NULL);
-
- n_periodic_reports = 0;
-
- /* Because of the race condition between notification of new
- * reports and reports landing in memory, we need to rely on
- * timestamps to figure whether we've read enough of them.
- */
- while (((last_timestamp - first_timestamp) * oa_period) < (fill_duration / 2)) {
-
- igt_debug("dts=%u elapsed=%"PRIu64" duration=%"PRIu64"\n",
- last_timestamp - first_timestamp,
- (last_timestamp - first_timestamp) * oa_period,
- fill_duration / 2);
-again_1:
- oa_status = 0;
- while ((len = read(stream_fd, buf, buf_size)) == -1 && errno == EINTR)
- ;
- if (errno == EIO) {
- oa_status = get_stream_status(stream_fd);
- igt_debug("oa_status %#x\n", oa_status);
- igt_assert(!(oa_status & DRM_XE_OASTATUS_BUFFER_OVERFLOW));
- goto again_1;
- }
- igt_assert_neq(len, -1);
-
- for (int offset = 0; offset < len; offset += report_size) {
- uint32_t *report = (void *) (buf + offset);
-
- igt_debug(" > report ts=%"PRIu64""
- " ts_delta_last_periodic=%"PRIu64" is_timer=%i ctx_id=%8x nb_periodic=%u\n",
- oa_timestamp(report, fmt),
- n_periodic_reports > 0 ? oa_timestamp_delta(report, last_periodic_report, fmt) : 0,
- oa_report_is_periodic(report),
- oa_report_get_ctx_id(report),
- n_periodic_reports);
-
- if (first_timestamp == 0)
- first_timestamp = oa_timestamp(report, fmt);
- last_timestamp = oa_timestamp(report, fmt);
-
- if (oa_report_is_periodic(report)) {
- memcpy(last_periodic_report, report, report_size);
- n_periodic_reports++;
- }
- }
- }
-
- do_ioctl(stream_fd, DRM_XE_OBSERVATION_IOCTL_DISABLE, 0);
-
- igt_debug("first ts = %u, last ts = %u\n", first_timestamp, last_timestamp);
+ /* OA buffer is disabled, we do not expect any error status */
+ oa_status = get_stream_status(stream_fd);
+ overflow_seen = oa_status & DRM_XE_OASTATUS_BUFFER_OVERFLOW;
+ igt_assert_eq(overflow_seen, 0);
- igt_debug("%f < %zu < %f\n",
- report_size * n_full_oa_reports * 0.45,
- n_periodic_reports * report_size,
- report_size * n_full_oa_reports * 0.55);
+ do_ioctl(stream_fd, DRM_XE_OBSERVATION_IOCTL_ENABLE, 0);
- igt_assert(n_periodic_reports * report_size >
- report_size * n_full_oa_reports * 0.45);
- igt_assert(n_periodic_reports * report_size <
- report_size * n_full_oa_reports * 0.55);
+ errno = 0;
+ /* Read 0 bytes repeatedly until you see an EIO */
+ while ((len = read(stream_fd, buf, 0)) == -1 && (errno == EINTR || errno == ENOSPC)) {
+ usleep(100);
}
+ igt_assert_eq(len, -1);
+ igt_assert_eq(errno, EIO);
- free(last_periodic_report);
- free(buf);
+ /* Ensure buffer overflowed */
+ oa_status = get_stream_status(stream_fd);
+ overflow_seen = oa_status & DRM_XE_OASTATUS_BUFFER_OVERFLOW;
+ igt_assert(overflow_seen);
__perf_close(stream_fd);
}
--
2.34.1
next prev parent reply other threads:[~2025-03-03 23:15 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-03-03 23:14 [PATCH i-g-t v2 00/14] Some refactor, rewrite and fixes for OA tests Umesh Nerlige Ramappa
2025-03-03 23:14 ` [PATCH i-g-t v2 01/14] tests/intel/xe_oa: Use static for global variables Umesh Nerlige Ramappa
2025-03-03 23:14 ` [PATCH i-g-t v2 02/14] tests/intel/xe_oa: Drop unused macro Umesh Nerlige Ramappa
2025-03-03 23:14 ` [PATCH i-g-t v2 03/14] tests/intel/xe_oa: Use period_ns in max_oa_exponent_for_period_lte Umesh Nerlige Ramappa
2025-03-03 23:38 ` Dixit, Ashutosh
2025-03-03 23:14 ` [PATCH i-g-t v2 04/14] tests/intel/xe_oa: Rename oa_exp_1_millisec to oa_exponent_default Umesh Nerlige Ramappa
2025-03-03 23:14 ` [PATCH i-g-t v2 05/14] tests/intel/xe_oa: Use default exponent for some tests Umesh Nerlige Ramappa
2025-03-03 23:14 ` [PATCH i-g-t v2 06/14] tests/intel/xe_oa: Use same render copy width and height across tests Umesh Nerlige Ramappa
2025-03-03 23:14 ` [PATCH i-g-t v2 07/14] tests/intel/xe_oa: Rewrite the polling small buf test Umesh Nerlige Ramappa
2025-03-04 0:05 ` Dixit, Ashutosh
2025-03-03 23:14 ` Umesh Nerlige Ramappa [this message]
2025-03-04 0:17 ` [PATCH i-g-t v2 08/14] tests/intel/xe_oa: Simplify the buffer-fill test Dixit, Ashutosh
2025-03-04 0:28 ` Dixit, Ashutosh
2025-03-04 15:11 ` Dixit, Ashutosh
2025-03-03 23:14 ` [PATCH i-g-t v2 09/14] tests/intel/xe_oa: Use default buffer size for non-zero reason Umesh Nerlige Ramappa
2025-03-03 23:14 ` [PATCH i-g-t v2 10/14] tests/intel/xe_oa: Test oa buffer sizes Umesh Nerlige Ramappa
2025-03-03 23:14 ` [PATCH i-g-t v2 11/14] tests/intel/xe_oa: Rewrite enable-disable test Umesh Nerlige Ramappa
2025-03-04 0:51 ` Dixit, Ashutosh
2025-03-04 15:04 ` Dixit, Ashutosh
2025-03-03 23:15 ` [PATCH i-g-t v2 12/14] tests/intel/xe_oa: Enable unprivileged-single-ctx-counters and fix it Umesh Nerlige Ramappa
2025-03-03 23:15 ` [PATCH i-g-t v2 13/14] tests/intel/xe_oa: Fix mmio_trigger_reports testing Umesh Nerlige Ramappa
2025-03-03 23:15 ` [PATCH i-g-t v2 14/14] tests/intel/xe_oa: Set boundaries for OA exponent test Umesh Nerlige Ramappa
2025-03-04 1:56 ` ✓ Xe.CI.BAT: success for Some refactor, rewrite and fixes for OA tests (rev2) Patchwork
2025-03-04 2:09 ` ✗ i915.CI.BAT: failure " Patchwork
2025-03-04 6:07 ` ✗ Xe.CI.Full: " Patchwork
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250303231502.135720-9-umesh.nerlige.ramappa@intel.com \
--to=umesh.nerlige.ramappa@intel.com \
--cc=ashutosh.dixit@intel.com \
--cc=igt-dev@lists.freedesktop.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox