#include "../config-host.h" /* SPDX-License-Identifier: MIT */ /* * Test that the sqthread goes to sleep around the specified time, and that * the NEED_WAKEUP flag is then set. */ #include #include #include #include #include #include "liburing.h" #include "helpers.h" int main(int argc, char *argv[]) { struct io_uring_params p = {}; struct io_uring_sqe *sqe; struct io_uring_cqe *cqe; struct timeval tv; struct io_uring ring; unsigned long elapsed; bool seen_wakeup; int ret; if (argc > 1) return T_EXIT_SKIP; p.flags = IORING_SETUP_SQPOLL; p.sq_thread_idle = 100; ret = io_uring_queue_init_params(1, &ring, &p); if (ret) { if (geteuid()) { printf("%s: skipped, not root\n", argv[0]); return T_EXIT_SKIP; } fprintf(stderr, "queue_init=%d\n", ret); return T_EXIT_FAIL; } sqe = io_uring_get_sqe(&ring); io_uring_prep_nop(sqe); io_uring_submit(&ring); ret = io_uring_wait_cqe(&ring, &cqe); if (ret) { fprintf(stderr, "wait_cqe: %d\n", ret); return T_EXIT_FAIL; } io_uring_cqe_seen(&ring, cqe); elapsed = 0; seen_wakeup = false; gettimeofday(&tv, NULL); do { usleep(100); if (IO_URING_READ_ONCE(*ring.sq.kflags) & IORING_SQ_NEED_WAKEUP) { seen_wakeup = true; break; } elapsed = mtime_since_now(&tv); } while (elapsed < 1000); if (!seen_wakeup) { fprintf(stderr, "SQPOLL didn't flag wakeup\n"); return T_EXIT_FAIL; } /* should be around 100 msec */ if (elapsed < 90 || elapsed > 110) { fprintf(stderr, "SQPOLL wakeup timing off %lu\n", elapsed); return T_EXIT_FAIL; } return T_EXIT_PASS; }