Commit 9e2a5c9
committed
modbus: Fix buffer overrun in RTU RX handler
It's possible for uart_buf_ctr to decrement after checking it due to TX interrupts. This can cause the unsigned packet length to overflow when subtracted by 4, which makes memcpy and crc16_ansi overflow the UART buffer. The counter is just loaded into a local variable to prevent further modification.
Partially fixes #910881 parent 1380739 commit 9e2a5c9
1 file changed
+6
-5
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
287 | 287 | | |
288 | 288 | | |
289 | 289 | | |
| 290 | + | |
290 | 291 | | |
291 | 292 | | |
292 | | - | |
293 | | - | |
| 293 | + | |
| 294 | + | |
294 | 295 | | |
295 | 296 | | |
296 | 297 | | |
| |||
299 | 300 | | |
300 | 301 | | |
301 | 302 | | |
302 | | - | |
| 303 | + | |
303 | 304 | | |
304 | | - | |
| 305 | + | |
305 | 306 | | |
306 | 307 | | |
307 | 308 | | |
308 | 309 | | |
309 | 310 | | |
310 | 311 | | |
311 | | - | |
| 312 | + | |
312 | 313 | | |
313 | 314 | | |
314 | 315 | | |
| |||
0 commit comments