Commit 85087bb
authored
Fix use-after-free triggered by fast actor reaping when the cycle detector is active (#4616)
The logic in the actor run and the cycle detector work together to
enable fast reaping of actors with rc == 0. This relies on atomics
and protecting the relevant areas of logic with critical sections.
This logic unfortunately suffered from a use-after-free bug due to
a race between the cycle detector receiving the block message and
destroying the actor and the actor cycle detector critical flag
being release as identified in #4614 which could sometimes lead
to memory corruption.
This commit changes things to remove the need to protect the
logic with critical sections. It achieves this by ensuring that
an actor with rc == 0 that the cycle detector knows about will
never be rescheduled again even if the cycle detector happens to
send it a message and the cycle detector is free to reap the actor
when it receives the block message. The cycle detector ensures that
the actor's message queue is empty or that the only messages
pending are the expected ones from the cycle detector so it can
safely destroy the actor.
Resolves #46141 parent b5b9520 commit 85087bb
4 files changed
+52
-107
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
712 | 712 | | |
713 | 713 | | |
714 | 714 | | |
715 | | - | |
716 | | - | |
717 | | - | |
| 715 | + | |
| 716 | + | |
| 717 | + | |
| 718 | + | |
| 719 | + | |
| 720 | + | |
718 | 721 | | |
719 | | - | |
720 | | - | |
721 | | - | |
722 | | - | |
723 | | - | |
724 | | - | |
725 | | - | |
726 | | - | |
727 | | - | |
728 | | - | |
729 | | - | |
730 | | - | |
731 | | - | |
732 | | - | |
733 | | - | |
734 | | - | |
735 | | - | |
736 | | - | |
737 | | - | |
738 | | - | |
739 | | - | |
740 | | - | |
741 | | - | |
742 | | - | |
743 | | - | |
744 | | - | |
745 | | - | |
746 | | - | |
747 | | - | |
748 | | - | |
749 | | - | |
750 | | - | |
751 | | - | |
752 | | - | |
753 | | - | |
754 | | - | |
755 | | - | |
756 | | - | |
757 | | - | |
758 | | - | |
759 | | - | |
760 | | - | |
761 | | - | |
762 | | - | |
763 | | - | |
764 | | - | |
765 | | - | |
766 | | - | |
| 722 | + | |
| 723 | + | |
| 724 | + | |
| 725 | + | |
| 726 | + | |
| 727 | + | |
| 728 | + | |
| 729 | + | |
| 730 | + | |
| 731 | + | |
| 732 | + | |
| 733 | + | |
| 734 | + | |
| 735 | + | |
| 736 | + | |
| 737 | + | |
767 | 738 | | |
768 | 739 | | |
769 | 740 | | |
770 | 741 | | |
771 | 742 | | |
772 | 743 | | |
773 | | - | |
774 | | - | |
775 | | - | |
776 | | - | |
777 | | - | |
778 | | - | |
779 | | - | |
| 744 | + | |
| 745 | + | |
780 | 746 | | |
781 | 747 | | |
782 | 748 | | |
| |||
1328 | 1294 | | |
1329 | 1295 | | |
1330 | 1296 | | |
1331 | | - | |
1332 | | - | |
1333 | | - | |
1334 | | - | |
1335 | | - | |
1336 | | - | |
1337 | | - | |
1338 | | - | |
1339 | | - | |
1340 | | - | |
1341 | | - | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
56 | 56 | | |
57 | 57 | | |
58 | 58 | | |
59 | | - | |
60 | | - | |
61 | 59 | | |
62 | 60 | | |
63 | 61 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
640 | 640 | | |
641 | 641 | | |
642 | 642 | | |
643 | | - | |
644 | | - | |
645 | | - | |
646 | | - | |
647 | | - | |
648 | | - | |
649 | | - | |
650 | | - | |
651 | | - | |
652 | | - | |
653 | | - | |
654 | | - | |
655 | | - | |
656 | | - | |
657 | | - | |
658 | | - | |
659 | | - | |
| 643 | + | |
660 | 644 | | |
661 | 645 | | |
662 | 646 | | |
| |||
808 | 792 | | |
809 | 793 | | |
810 | 794 | | |
811 | | - | |
812 | | - | |
813 | | - | |
814 | | - | |
815 | | - | |
816 | | - | |
817 | | - | |
818 | | - | |
819 | | - | |
820 | | - | |
821 | | - | |
822 | | - | |
823 | | - | |
824 | | - | |
825 | | - | |
826 | | - | |
827 | | - | |
| 795 | + | |
828 | 796 | | |
829 | 797 | | |
830 | 798 | | |
| |||
902 | 870 | | |
903 | 871 | | |
904 | 872 | | |
905 | | - | |
906 | | - | |
| 873 | + | |
| 874 | + | |
| 875 | + | |
| 876 | + | |
| 877 | + | |
| 878 | + | |
| 879 | + | |
| 880 | + | |
| 881 | + | |
| 882 | + | |
| 883 | + | |
| 884 | + | |
| 885 | + | |
| 886 | + | |
| 887 | + | |
| 888 | + | |
| 889 | + | |
| 890 | + | |
| 891 | + | |
| 892 | + | |
907 | 893 | | |
908 | 894 | | |
| 895 | + | |
909 | 896 | | |
910 | 897 | | |
911 | 898 | | |
| |||
0 commit comments