struct hrtimer                  timer;
        struct timespec64               ts;
        enum hrtimer_mode               mode;
+       u32                             seq_offset;
 };
 
 struct io_timeout {
        }
 
        req->sequence = ctx->cached_sq_head + count - 1;
-       /* reuse it to store the count */
-       req->submit.sequence = count;
+       req->timeout.data->seq_offset = count;
 
        /*
         * Insertion sort, ensuring the first entry in the list is always
                struct io_kiocb *nxt = list_entry(entry, struct io_kiocb, list);
                unsigned nxt_sq_head;
                long long tmp, tmp_nxt;
+               u32 nxt_offset = nxt->timeout.data->seq_offset;
 
                if (nxt->flags & REQ_F_TIMEOUT_NOSEQ)
                        continue;
                 * long to store it.
                 */
                tmp = (long long)ctx->cached_sq_head + count - 1;
-               nxt_sq_head = nxt->sequence - nxt->submit.sequence + 1;
-               tmp_nxt = (long long)nxt_sq_head + nxt->submit.sequence - 1;
+               nxt_sq_head = nxt->sequence - nxt_offset + 1;
+               tmp_nxt = (long long)nxt_sq_head + nxt_offset - 1;
 
                /*
                 * cached_sq_head may overflow, and it will never overflow twice