diff options
author | Michael S. Tsirkin <[email protected]> | 2017-12-05 21:29:37 +0200 |
---|---|---|
committer | David S. Miller <[email protected]> | 2017-12-11 10:52:23 -0500 |
commit | a8ceb5dbfde1092b466936bca0ff3be127ecf38e (patch) | |
tree | 768483ddf27f70faa09ffe0f4a0c90a35119f249 /tools/perf/scripts/python/bin/netdev-times-record | |
parent | f0f1d0166b17e1fadaa1dfa99721a9abb97e65eb (diff) |
ptr_ring: add barriers
Users of ptr_ring expect that it's safe to give the
data structure a pointer and have it be available
to consumers, but that actually requires an smb_wmb
or a stronger barrier.
In absence of such barriers and on architectures that reorder writes,
consumer might read an un=initialized value from an skb pointer stored
in the skb array. This was observed causing crashes.
To fix, add memory barriers. The barrier we use is a wmb, the
assumption being that producers do not need to read the value so we do
not need to order these reads.
Reported-by: George Cherian <[email protected]>
Suggested-by: Jason Wang <[email protected]>
Signed-off-by: Michael S. Tsirkin <[email protected]>
Acked-by: Jason Wang <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/bin/netdev-times-record')
0 files changed, 0 insertions, 0 deletions