diff options
| author | Ming Lei <[email protected]> | 2020-01-11 20:57:43 +0800 | 
|---|---|---|
| committer | Jens Axboe <[email protected]> | 2020-01-14 13:37:40 -0700 | 
| commit | 4a2f704eb2d831a2d73d7f4cdd54f45c49c3c353 (patch) | |
| tree | 8ff8c6a1e1c0311dba3b81a9482dc5ea87ed456f /include/linux/skb_array.h | |
| parent | e17016f6dcb047f91a8fc9f46bbf81a21d15ca73 (diff) | |
block: fix get_max_segment_size() overflow on 32bit arch
Commit 429120f3df2d starts to take account of segment's start dma address
when computing max segment size, and data type of 'unsigned long'
is used to do that. However, the segment mask may be 0xffffffff, so
the figured out segment size may be overflowed in case of zero physical
address on 32bit arch.
Fix the issue by returning queue_max_segment_size() directly when that
happens.
Fixes: 429120f3df2d ("block: fix splitting segments on boundary masks")
Reported-by: Guenter Roeck <[email protected]>
Tested-by: Guenter Roeck <[email protected]>
Cc: Christoph Hellwig <[email protected]>
Tested-by: Steven Rostedt (VMware) <[email protected]>
Signed-off-by: Ming Lei <[email protected]>
Signed-off-by: Jens Axboe <[email protected]>
Diffstat (limited to 'include/linux/skb_array.h')
0 files changed, 0 insertions, 0 deletions