Commit 523eec5
committed
core: sleep_abortable propagates custom abort exception when already aborted
sleep_abortable(dur, abort_source&) had two abort paths that disagreed
on the failure exception. Aborting during the sleep propagated a custom
exception set via request_abort_ex, but if the source was already
aborted before sleep_abortable subscribed, subscribe() returned a
disengaged optional and the fast path always fabricated a fresh
sleep_aborted, discarding the custom exception. The resulting exception
depended on a race with the subscribe call.
Make the already-aborted fast path mirror the during-sleep path:
propagate the caller-supplied exception when one was given, otherwise
fall back to sleep_aborted. abort_source::get_default_exception() now
returns a stable shared exception_ptr, which a plain request_abort()
stores; sleep_abortable distinguishes a caller-supplied exception by
comparing the stored abort exception against it by identity. A plain
request_abort() still yields sleep_aborted as before.
This relies on comparing exception_ptr identity, so abort_source is
changed to return its default exception_ptr derived from a common
thread_local initial value.
Closes scylladb#34521 parent 58d9b63 commit 523eec5
4 files changed
Lines changed: 42 additions & 5 deletions
File tree
- include/seastar/core
- src/core
- tests/unit
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
213 | 213 | | |
214 | 214 | | |
215 | 215 | | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
216 | 222 | | |
217 | | - | |
| 223 | + | |
| 224 | + | |
218 | 225 | | |
219 | 226 | | |
220 | 227 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
77 | 77 | | |
78 | 78 | | |
79 | 79 | | |
80 | | - | |
81 | | - | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
82 | 86 | | |
83 | 87 | | |
84 | 88 | | |
85 | | - | |
| 89 | + | |
86 | 90 | | |
87 | 91 | | |
88 | 92 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
111 | 111 | | |
112 | 112 | | |
113 | 113 | | |
114 | | - | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
115 | 124 | | |
116 | 125 | | |
117 | 126 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
201 | 201 | | |
202 | 202 | | |
203 | 203 | | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
204 | 221 | | |
205 | 222 | | |
206 | 223 | | |
| |||
0 commit comments