Commit 6dfb1d5
Fix TSAN race condition in FileLogger2 with condition_variable
Use proper condition_variable synchronization to ensure the writer
thread is fully ready before the constructor returns. This prevents
race conditions where callbacks fire before the thread is initialized.
Previous atomic-based approach still had TSAN warnings because the
callback could start executing while the constructor was blocked
waiting for the condition variable, causing a double-lock scenario.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>1 parent de0d2e9 commit 6dfb1d5
1 file changed
+17
-8
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
27 | 27 | | |
28 | 28 | | |
29 | 29 | | |
30 | | - | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
31 | 35 | | |
32 | 36 | | |
33 | 37 | | |
| |||
72 | 76 | | |
73 | 77 | | |
74 | 78 | | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
75 | 86 | | |
76 | 87 | | |
77 | 88 | | |
| |||
85 | 96 | | |
86 | 97 | | |
87 | 98 | | |
88 | | - | |
89 | | - | |
90 | | - | |
91 | | - | |
92 | | - | |
93 | | - | |
94 | 99 | | |
95 | 100 | | |
96 | 101 | | |
| |||
110 | 115 | | |
111 | 116 | | |
112 | 117 | | |
113 | | - | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
114 | 123 | | |
115 | 124 | | |
116 | 125 | | |
| |||
0 commit comments