41e90e22e2
1370: stm32/i2c: fix races when using dma. r=Dirbaio a=xoviat This change addresses two races: 1. It removes the `chunks_transferred` state variable that is modified inside the interrupt. Analysis of the code reveals that the only time the waker can be woken is when `chunks_transferred` is incremented. Therefore, waking is enough to signal the `poll_fn` that the `chunks_transferred` has incremented. Moving to `remaining_len` clarifies the code, since there is no need to track how many chunks are remaining. 2. It moves the start of the transfer until after the waker is registered, which could theoretically occur if the clock speed is very low, but probably never would even if this wasn't fixed. There is another race that I noticed: between writes the waker may not yet be registered. In that case, the code would simply be stuck and the `poll_fn` would never be woken. There is no way to resolve this without broadening the scope of the analysis, and this will likely never occur. Co-authored-by: xoviat <xoviat@users.noreply.github.com> |
||
---|---|---|
.. | ||
adc | ||
can | ||
crc | ||
dma | ||
eth | ||
flash | ||
i2c | ||
pwm | ||
qspi | ||
rcc | ||
rtc | ||
sdmmc | ||
spi | ||
subghz | ||
timer | ||
usart | ||
usb | ||
usb_otg | ||
wdg | ||
dac.rs | ||
dcmi.rs | ||
exti.rs | ||
fmc.rs | ||
fmt.rs | ||
gpio.rs | ||
interrupt.rs | ||
lib.rs | ||
rng.rs | ||
time.rs | ||
time_driver.rs | ||
traits.rs |