Commit e9b3f74
committed
fix: defer reopen of live-thread proc fds until after clone()
Instead of rewriting /proc/<pid>/task/<tid>/... paths to the leader
thread (which returns wrong data), defer the actual open until after
threads exist in the restorer blob.
Phase 1 (collect): Mark live-thread proc paths with deferred_thread_fd
instead of rewriting them. Dead-thread TASK_HELPER case is unchanged.
Phase 2 (placeholder): Open /dev/null to reserve the fd number, then
collect deferred fd metadata into rst_mem for the restorer.
Phase 3 (restorer): After clone() creates all threads, loop through
deferred fds and reopen via sys_openat(proc_fd, path) + sys_dup2() +
sys_lseek(). At this point /proc/<pid>/task/<tid>/ exists.
The test is expanded to verify both dead-thread (fd validity check) and
live-thread (reads tid from /proc/self/task/<tid>/stat to prove it
points to the correct thread, not the leader) cases.1 parent ca27a87 commit e9b3f74
File tree
6 files changed
+293
-67
lines changed- criu
- include
- pie
- test/zdtm/static
6 files changed
+293
-67
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
272 | 272 | | |
273 | 273 | | |
274 | 274 | | |
275 | | - | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
276 | 279 | | |
277 | 280 | | |
278 | 281 | | |
279 | 282 | | |
280 | 283 | | |
281 | 284 | | |
282 | | - | |
283 | | - | |
284 | | - | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
285 | 288 | | |
286 | 289 | | |
287 | 290 | | |
| |||
500 | 503 | | |
501 | 504 | | |
502 | 505 | | |
| 506 | + | |
| 507 | + | |
| 508 | + | |
| 509 | + | |
| 510 | + | |
| 511 | + | |
| 512 | + | |
| 513 | + | |
| 514 | + | |
| 515 | + | |
| 516 | + | |
| 517 | + | |
| 518 | + | |
| 519 | + | |
| 520 | + | |
| 521 | + | |
| 522 | + | |
| 523 | + | |
| 524 | + | |
| 525 | + | |
| 526 | + | |
| 527 | + | |
| 528 | + | |
| 529 | + | |
| 530 | + | |
| 531 | + | |
| 532 | + | |
| 533 | + | |
| 534 | + | |
| 535 | + | |
| 536 | + | |
| 537 | + | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
| 543 | + | |
| 544 | + | |
| 545 | + | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
503 | 565 | | |
504 | 566 | | |
505 | 567 | | |
| |||
676 | 738 | | |
677 | 739 | | |
678 | 740 | | |
| 741 | + | |
| 742 | + | |
| 743 | + | |
679 | 744 | | |
680 | 745 | | |
681 | 746 | | |
| |||
1709 | 1774 | | |
1710 | 1775 | | |
1711 | 1776 | | |
1712 | | - | |
| 1777 | + | |
| 1778 | + | |
| 1779 | + | |
| 1780 | + | |
1713 | 1781 | | |
1714 | 1782 | | |
1715 | 1783 | | |
| |||
3133 | 3201 | | |
3134 | 3202 | | |
3135 | 3203 | | |
3136 | | - | |
| 3204 | + | |
| 3205 | + | |
| 3206 | + | |
3137 | 3207 | | |
3138 | 3208 | | |
3139 | 3209 | | |
| |||
3329 | 3399 | | |
3330 | 3400 | | |
3331 | 3401 | | |
| 3402 | + | |
3332 | 3403 | | |
3333 | 3404 | | |
3334 | 3405 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2552 | 2552 | | |
2553 | 2553 | | |
2554 | 2554 | | |
| 2555 | + | |
2555 | 2556 | | |
2556 | 2557 | | |
| 2558 | + | |
| 2559 | + | |
| 2560 | + | |
| 2561 | + | |
| 2562 | + | |
| 2563 | + | |
| 2564 | + | |
| 2565 | + | |
| 2566 | + | |
| 2567 | + | |
| 2568 | + | |
| 2569 | + | |
| 2570 | + | |
| 2571 | + | |
| 2572 | + | |
| 2573 | + | |
| 2574 | + | |
| 2575 | + | |
| 2576 | + | |
2557 | 2577 | | |
2558 | 2578 | | |
2559 | 2579 | | |
| |||
2690 | 2710 | | |
2691 | 2711 | | |
2692 | 2712 | | |
2693 | | - | |
2694 | | - | |
2695 | | - | |
2696 | | - | |
| 2713 | + | |
| 2714 | + | |
| 2715 | + | |
| 2716 | + | |
2697 | 2717 | | |
2698 | | - | |
2699 | | - | |
2700 | | - | |
2701 | | - | |
2702 | | - | |
2703 | | - | |
2704 | | - | |
| 2718 | + | |
| 2719 | + | |
| 2720 | + | |
| 2721 | + | |
2705 | 2722 | | |
2706 | 2723 | | |
2707 | 2724 | | |
| |||
2722 | 2739 | | |
2723 | 2740 | | |
2724 | 2741 | | |
| 2742 | + | |
| 2743 | + | |
2725 | 2744 | | |
2726 | 2745 | | |
2727 | 2746 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
24 | 24 | | |
25 | 25 | | |
26 | 26 | | |
| 27 | + | |
27 | 28 | | |
| 29 | + | |
28 | 30 | | |
29 | 31 | | |
30 | 32 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
141 | 141 | | |
142 | 142 | | |
143 | 143 | | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
144 | 151 | | |
145 | 152 | | |
146 | 153 | | |
| |||
196 | 203 | | |
197 | 204 | | |
198 | 205 | | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
199 | 209 | | |
200 | 210 | | |
201 | 211 | | |
| |||
256 | 266 | | |
257 | 267 | | |
258 | 268 | | |
259 | | - | |
| 269 | + | |
260 | 270 | | |
261 | 271 | | |
262 | 272 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
366 | 366 | | |
367 | 367 | | |
368 | 368 | | |
369 | | - | |
370 | 369 | | |
371 | 370 | | |
372 | 371 | | |
| |||
2198 | 2197 | | |
2199 | 2198 | | |
2200 | 2199 | | |
| 2200 | + | |
| 2201 | + | |
| 2202 | + | |
| 2203 | + | |
| 2204 | + | |
| 2205 | + | |
| 2206 | + | |
| 2207 | + | |
| 2208 | + | |
| 2209 | + | |
| 2210 | + | |
| 2211 | + | |
| 2212 | + | |
| 2213 | + | |
| 2214 | + | |
| 2215 | + | |
| 2216 | + | |
| 2217 | + | |
| 2218 | + | |
| 2219 | + | |
| 2220 | + | |
| 2221 | + | |
| 2222 | + | |
| 2223 | + | |
| 2224 | + | |
| 2225 | + | |
| 2226 | + | |
| 2227 | + | |
| 2228 | + | |
| 2229 | + | |
2201 | 2230 | | |
2202 | 2231 | | |
2203 | 2232 | | |
| |||
0 commit comments