1*25da2beaSAndroid Build Coastguard Worker /* SPDX-License-Identifier: MIT */
2*25da2beaSAndroid Build Coastguard Worker #include <stdio.h>
3*25da2beaSAndroid Build Coastguard Worker #include <time.h>
4*25da2beaSAndroid Build Coastguard Worker #include <sys/time.h>
5*25da2beaSAndroid Build Coastguard Worker #include "liburing.h"
6*25da2beaSAndroid Build Coastguard Worker
mtime_since(const struct timeval * s,const struct timeval * e)7*25da2beaSAndroid Build Coastguard Worker static unsigned long long mtime_since(const struct timeval *s,
8*25da2beaSAndroid Build Coastguard Worker const struct timeval *e)
9*25da2beaSAndroid Build Coastguard Worker {
10*25da2beaSAndroid Build Coastguard Worker long long sec, usec;
11*25da2beaSAndroid Build Coastguard Worker
12*25da2beaSAndroid Build Coastguard Worker sec = e->tv_sec - s->tv_sec;
13*25da2beaSAndroid Build Coastguard Worker usec = (e->tv_usec - s->tv_usec);
14*25da2beaSAndroid Build Coastguard Worker if (sec > 0 && usec < 0) {
15*25da2beaSAndroid Build Coastguard Worker sec--;
16*25da2beaSAndroid Build Coastguard Worker usec += 1000000;
17*25da2beaSAndroid Build Coastguard Worker }
18*25da2beaSAndroid Build Coastguard Worker
19*25da2beaSAndroid Build Coastguard Worker sec *= 1000;
20*25da2beaSAndroid Build Coastguard Worker usec /= 1000;
21*25da2beaSAndroid Build Coastguard Worker return sec + usec;
22*25da2beaSAndroid Build Coastguard Worker }
23*25da2beaSAndroid Build Coastguard Worker
mtime_since_now(struct timeval * tv)24*25da2beaSAndroid Build Coastguard Worker static unsigned long long mtime_since_now(struct timeval *tv)
25*25da2beaSAndroid Build Coastguard Worker {
26*25da2beaSAndroid Build Coastguard Worker struct timeval end;
27*25da2beaSAndroid Build Coastguard Worker
28*25da2beaSAndroid Build Coastguard Worker gettimeofday(&end, NULL);
29*25da2beaSAndroid Build Coastguard Worker return mtime_since(tv, &end);
30*25da2beaSAndroid Build Coastguard Worker }
31*25da2beaSAndroid Build Coastguard Worker
main(int argc,char * argv[])32*25da2beaSAndroid Build Coastguard Worker int main(int argc, char *argv[])
33*25da2beaSAndroid Build Coastguard Worker {
34*25da2beaSAndroid Build Coastguard Worker struct __kernel_timespec ts1, ts2;
35*25da2beaSAndroid Build Coastguard Worker struct io_uring_cqe *cqe;
36*25da2beaSAndroid Build Coastguard Worker struct io_uring_sqe *sqe;
37*25da2beaSAndroid Build Coastguard Worker struct io_uring ring;
38*25da2beaSAndroid Build Coastguard Worker unsigned long msec;
39*25da2beaSAndroid Build Coastguard Worker struct timeval tv;
40*25da2beaSAndroid Build Coastguard Worker int ret;
41*25da2beaSAndroid Build Coastguard Worker
42*25da2beaSAndroid Build Coastguard Worker if (argc > 1)
43*25da2beaSAndroid Build Coastguard Worker return 0;
44*25da2beaSAndroid Build Coastguard Worker
45*25da2beaSAndroid Build Coastguard Worker ret = io_uring_queue_init(32, &ring, 0);
46*25da2beaSAndroid Build Coastguard Worker if (ret) {
47*25da2beaSAndroid Build Coastguard Worker fprintf(stderr, "io_uring_queue_init=%d\n", ret);
48*25da2beaSAndroid Build Coastguard Worker return 1;
49*25da2beaSAndroid Build Coastguard Worker }
50*25da2beaSAndroid Build Coastguard Worker
51*25da2beaSAndroid Build Coastguard Worker sqe = io_uring_get_sqe(&ring);
52*25da2beaSAndroid Build Coastguard Worker io_uring_prep_nop(sqe);
53*25da2beaSAndroid Build Coastguard Worker ret = io_uring_submit(&ring);
54*25da2beaSAndroid Build Coastguard Worker if (ret != 1) {
55*25da2beaSAndroid Build Coastguard Worker fprintf(stderr, "io_uring_submit1=%d\n", ret);
56*25da2beaSAndroid Build Coastguard Worker return 1;
57*25da2beaSAndroid Build Coastguard Worker }
58*25da2beaSAndroid Build Coastguard Worker
59*25da2beaSAndroid Build Coastguard Worker
60*25da2beaSAndroid Build Coastguard Worker ts1.tv_sec = 5,
61*25da2beaSAndroid Build Coastguard Worker ts1.tv_nsec = 0;
62*25da2beaSAndroid Build Coastguard Worker ret = io_uring_wait_cqe_timeout(&ring, &cqe, &ts1);
63*25da2beaSAndroid Build Coastguard Worker if (ret) {
64*25da2beaSAndroid Build Coastguard Worker fprintf(stderr, "io_uring_wait_cqe_timeout=%d\n", ret);
65*25da2beaSAndroid Build Coastguard Worker return 1;
66*25da2beaSAndroid Build Coastguard Worker }
67*25da2beaSAndroid Build Coastguard Worker io_uring_cqe_seen(&ring, cqe);
68*25da2beaSAndroid Build Coastguard Worker gettimeofday(&tv, NULL);
69*25da2beaSAndroid Build Coastguard Worker
70*25da2beaSAndroid Build Coastguard Worker ts2.tv_sec = 1;
71*25da2beaSAndroid Build Coastguard Worker ts2.tv_nsec = 0;
72*25da2beaSAndroid Build Coastguard Worker sqe = io_uring_get_sqe(&ring);
73*25da2beaSAndroid Build Coastguard Worker io_uring_prep_timeout(sqe, &ts2, 0, 0);
74*25da2beaSAndroid Build Coastguard Worker sqe->user_data = 89;
75*25da2beaSAndroid Build Coastguard Worker ret = io_uring_submit(&ring);
76*25da2beaSAndroid Build Coastguard Worker if (ret != 1) {
77*25da2beaSAndroid Build Coastguard Worker fprintf(stderr, "io_uring_submit2=%d\n", ret);
78*25da2beaSAndroid Build Coastguard Worker return 1;
79*25da2beaSAndroid Build Coastguard Worker }
80*25da2beaSAndroid Build Coastguard Worker
81*25da2beaSAndroid Build Coastguard Worker io_uring_wait_cqe(&ring, &cqe);
82*25da2beaSAndroid Build Coastguard Worker io_uring_cqe_seen(&ring, cqe);
83*25da2beaSAndroid Build Coastguard Worker msec = mtime_since_now(&tv);
84*25da2beaSAndroid Build Coastguard Worker if (msec >= 900 && msec <= 1100) {
85*25da2beaSAndroid Build Coastguard Worker io_uring_queue_exit(&ring);
86*25da2beaSAndroid Build Coastguard Worker return 0;
87*25da2beaSAndroid Build Coastguard Worker }
88*25da2beaSAndroid Build Coastguard Worker
89*25da2beaSAndroid Build Coastguard Worker fprintf(stderr, "%s: Timeout seems wonky (got %lu)\n", __FUNCTION__,
90*25da2beaSAndroid Build Coastguard Worker msec);
91*25da2beaSAndroid Build Coastguard Worker io_uring_queue_exit(&ring);
92*25da2beaSAndroid Build Coastguard Worker return 1;
93*25da2beaSAndroid Build Coastguard Worker }
94