diff --git a/lib/std/Io/Threaded.zig b/lib/std/Io/Threaded.zig index c9c38c6b29..05ff37b76e 100644 --- a/lib/std/Io/Threaded.zig +++ b/lib/std/Io/Threaded.zig @@ -2623,6 +2623,7 @@ fn batchCancel(userdata: ?*anyopaque, b: *Io.Batch) void { const metadatas_ptr: [*]WinOpMetadata = @ptrCast(@alignCast(reserved)); const metadatas = metadatas_ptr[0..b.operations.len]; for (metadatas, 0..) |*metadata, op| { + if (!metadata.pending) continue; const done = @atomicLoad(windows.NTSTATUS, &metadata.iosb.u.Status, .acquire) != .PENDING; if (done) continue; switch (operations[op]) { @@ -2633,6 +2634,7 @@ fn batchCancel(userdata: ?*anyopaque, b: *Io.Batch) void { } } for (metadatas) |*metadata| { + if (!metadata.pending) continue; while (@atomicLoad(windows.NTSTATUS, &metadata.iosb.u.Status, .acquire) == .PENDING) { waitForApcOrAlert(); }