Commit ae9afa7
committed
Add ready_ CAS protocol and restructure IOCP work counting
Implement a thread-safety protocol to coordinate between the I/O
initiator thread and the GQCS dispatch thread:
- Add ready_ flag to overlapped_op with InterlockedCompareExchange
handshake between do_one() and on_pending()/on_completion()
- Add on_pending() for async paths: CAS coordinates with do_one() to
ensure the handler only dispatches after the initiator has returned
- Add on_completion() for sync error/noop paths: packs results into
the op and posts with key_result_stored for deferred dispatch
- Move work_started() to the top of connect/read_some/write_some/accept
unconditionally so one call covers all error and async paths
- Move work_finished() after complete() in do_one() so the handler
runs while outstanding_work is still positive1 parent 7354ab6 commit ae9afa7
4 files changed
Lines changed: 116 additions & 62 deletions
File tree
- include/boost/corosio/native/detail/iocp
Lines changed: 47 additions & 56 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
397 | 397 | | |
398 | 398 | | |
399 | 399 | | |
400 | | - | |
| 400 | + | |
401 | 401 | | |
402 | 402 | | |
| 403 | + | |
| 404 | + | |
403 | 405 | | |
404 | 406 | | |
405 | 407 | | |
| |||
409 | 411 | | |
410 | 412 | | |
411 | 413 | | |
412 | | - | |
413 | | - | |
414 | | - | |
| 414 | + | |
415 | 415 | | |
416 | 416 | | |
417 | 417 | | |
418 | 418 | | |
419 | 419 | | |
420 | 420 | | |
421 | | - | |
422 | | - | |
423 | | - | |
| 421 | + | |
424 | 422 | | |
425 | 423 | | |
426 | 424 | | |
427 | 425 | | |
428 | 426 | | |
429 | | - | |
430 | | - | |
431 | 427 | | |
432 | 428 | | |
433 | 429 | | |
| |||
437 | 433 | | |
438 | 434 | | |
439 | 435 | | |
440 | | - | |
441 | | - | |
442 | | - | |
443 | | - | |
| 436 | + | |
444 | 437 | | |
445 | 438 | | |
446 | 439 | | |
447 | | - | |
448 | | - | |
| 440 | + | |
| 441 | + | |
449 | 442 | | |
450 | 443 | | |
451 | 444 | | |
| |||
470 | 463 | | |
471 | 464 | | |
472 | 465 | | |
473 | | - | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
474 | 469 | | |
475 | 470 | | |
476 | 471 | | |
477 | 472 | | |
478 | | - | |
| 473 | + | |
479 | 474 | | |
480 | 475 | | |
481 | | - | |
482 | | - | |
483 | | - | |
484 | | - | |
| 476 | + | |
| 477 | + | |
485 | 478 | | |
486 | 479 | | |
487 | 480 | | |
| |||
491 | 484 | | |
492 | 485 | | |
493 | 486 | | |
494 | | - | |
495 | 487 | | |
496 | 488 | | |
497 | | - | |
498 | | - | |
499 | 489 | | |
500 | 490 | | |
501 | 491 | | |
| |||
505 | 495 | | |
506 | 496 | | |
507 | 497 | | |
508 | | - | |
509 | | - | |
510 | | - | |
| 498 | + | |
511 | 499 | | |
512 | 500 | | |
513 | 501 | | |
514 | | - | |
515 | | - | |
516 | | - | |
| 502 | + | |
| 503 | + | |
| 504 | + | |
| 505 | + | |
517 | 506 | | |
518 | 507 | | |
519 | 508 | | |
| |||
540 | 529 | | |
541 | 530 | | |
542 | 531 | | |
543 | | - | |
| 532 | + | |
| 533 | + | |
| 534 | + | |
544 | 535 | | |
545 | 536 | | |
546 | 537 | | |
547 | 538 | | |
548 | 539 | | |
549 | 540 | | |
550 | 541 | | |
551 | | - | |
552 | | - | |
553 | | - | |
| 542 | + | |
554 | 543 | | |
555 | 544 | | |
556 | 545 | | |
| |||
560 | 549 | | |
561 | 550 | | |
562 | 551 | | |
563 | | - | |
564 | | - | |
565 | | - | |
566 | 552 | | |
567 | 553 | | |
568 | 554 | | |
| |||
571 | 557 | | |
572 | 558 | | |
573 | 559 | | |
574 | | - | |
575 | | - | |
576 | | - | |
| 560 | + | |
577 | 561 | | |
578 | 562 | | |
579 | 563 | | |
| 564 | + | |
| 565 | + | |
| 566 | + | |
580 | 567 | | |
581 | 568 | | |
582 | 569 | | |
| |||
1005 | 992 | | |
1006 | 993 | | |
1007 | 994 | | |
| 995 | + | |
| 996 | + | |
| 997 | + | |
| 998 | + | |
| 999 | + | |
| 1000 | + | |
| 1001 | + | |
| 1002 | + | |
| 1003 | + | |
| 1004 | + | |
| 1005 | + | |
| 1006 | + | |
1008 | 1007 | | |
1009 | 1008 | | |
1010 | 1009 | | |
| |||
1179 | 1178 | | |
1180 | 1179 | | |
1181 | 1180 | | |
| 1181 | + | |
| 1182 | + | |
1182 | 1183 | | |
1183 | 1184 | | |
1184 | 1185 | | |
| |||
1189 | 1190 | | |
1190 | 1191 | | |
1191 | 1192 | | |
1192 | | - | |
1193 | | - | |
1194 | | - | |
| 1193 | + | |
1195 | 1194 | | |
1196 | 1195 | | |
1197 | 1196 | | |
| |||
1203 | 1202 | | |
1204 | 1203 | | |
1205 | 1204 | | |
1206 | | - | |
1207 | | - | |
1208 | | - | |
| 1205 | + | |
1209 | 1206 | | |
1210 | 1207 | | |
1211 | 1208 | | |
| |||
1221 | 1218 | | |
1222 | 1219 | | |
1223 | 1220 | | |
1224 | | - | |
1225 | | - | |
1226 | | - | |
| 1221 | + | |
1227 | 1222 | | |
1228 | 1223 | | |
1229 | 1224 | | |
1230 | 1225 | | |
1231 | | - | |
1232 | 1226 | | |
1233 | 1227 | | |
1234 | 1228 | | |
| |||
1239 | 1233 | | |
1240 | 1234 | | |
1241 | 1235 | | |
1242 | | - | |
1243 | 1236 | | |
1244 | 1237 | | |
1245 | 1238 | | |
1246 | 1239 | | |
1247 | | - | |
1248 | | - | |
1249 | | - | |
| 1240 | + | |
1250 | 1241 | | |
1251 | 1242 | | |
1252 | 1243 | | |
1253 | | - | |
1254 | | - | |
| 1244 | + | |
| 1245 | + | |
1255 | 1246 | | |
1256 | 1247 | | |
1257 | 1248 | | |
| |||
Lines changed: 2 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
60 | 60 | | |
61 | 61 | | |
62 | 62 | | |
| 63 | + | |
63 | 64 | | |
64 | 65 | | |
65 | 66 | | |
| |||
89 | 90 | | |
90 | 91 | | |
91 | 92 | | |
| 93 | + | |
92 | 94 | | |
93 | 95 | | |
94 | 96 | | |
| |||
Lines changed: 61 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
80 | 80 | | |
81 | 81 | | |
82 | 82 | | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
83 | 91 | | |
84 | 92 | | |
85 | 93 | | |
| |||
312 | 320 | | |
313 | 321 | | |
314 | 322 | | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
315 | 359 | | |
316 | 360 | | |
317 | 361 | | |
| |||
493 | 537 | | |
494 | 538 | | |
495 | 539 | | |
496 | | - | |
497 | 540 | | |
498 | 541 | | |
499 | | - | |
| 542 | + | |
500 | 543 | | |
501 | 544 | | |
502 | 545 | | |
503 | 546 | | |
504 | 547 | | |
505 | 548 | | |
| 549 | + | |
506 | 550 | | |
507 | | - | |
508 | | - | |
509 | | - | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
510 | 565 | | |
511 | 566 | | |
512 | 567 | | |
513 | 568 | | |
514 | 569 | | |
515 | 570 | | |
516 | | - | |
517 | 571 | | |
| 572 | + | |
518 | 573 | | |
519 | 574 | | |
520 | 575 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
129 | 129 | | |
130 | 130 | | |
131 | 131 | | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
132 | 138 | | |
133 | 139 | | |
134 | 140 | | |
| |||
0 commit comments