diff options
author | Willem de Bruijn <willemb@google.com> | 2018-11-25 03:09:26 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2018-11-25 03:22:21 +0100 |
commit | 358be656406dce296fafeac7a913ba33e9a66971 (patch) | |
tree | 11dcd5c0e1ebe476284d310dd60299be0ef5fae8 /tools/testing/selftests/net/.gitignore | |
parent | net: qualcomm: rmnet: move null check on dev before dereferecing it (diff) | |
download | linux-358be656406dce296fafeac7a913ba33e9a66971.tar.xz linux-358be656406dce296fafeac7a913ba33e9a66971.zip |
selftests/net: add txring_overwrite
Packet sockets with PACKET_TX_RING send skbs with user data in frags.
Before commit 5cd8d46ea156 ("packet: copy user buffers before orphan
or clone") ring slots could be released prematurely, possibly allowing
a process to overwrite data still in flight.
This test opens two packet sockets, one to send and one to read.
The sender has a tx ring of one slot. It sends two packets with
different payload, then reads both and verifies their payload.
Before the above commit, both receive calls return the same data as
the send calls use the same buffer. From the commit, the clone
needed for looping onto a packet socket triggers an skb_copy_ubufs
to create a private copy. The separate sends each arrive correctly.
Signed-off-by: Willem de Bruijn <willemb@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'tools/testing/selftests/net/.gitignore')
-rw-r--r-- | tools/testing/selftests/net/.gitignore | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/tools/testing/selftests/net/.gitignore b/tools/testing/selftests/net/.gitignore index 8cf22b3c2563..7f57b916e6b2 100644 --- a/tools/testing/selftests/net/.gitignore +++ b/tools/testing/selftests/net/.gitignore @@ -14,4 +14,5 @@ udpgso_bench_rx udpgso_bench_tx tcp_inq tls +txring_overwrite ip_defrag |