net: fix psock_fanout on sparc64
authorWillem de Bruijn <willemb@google.com>
Thu, 21 Mar 2013 18:10:03 +0000 (14:10 -0400)
committerDavid S. Miller <davem@davemloft.net>
Thu, 21 Mar 2013 18:31:36 +0000 (14:31 -0400)
The packetsocket fanout test uses a packet ring. Use TPACKET_V2
instead of TPACKET_V1 to work around a known 32/64 bit issue in
the older ring that manifests on sparc64.

Signed-off-by: Willem de Bruijn <willemb@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
tools/testing/selftests/net/psock_fanout.c

index 226e5e33105aaa68d788cc37c53435807822a1a0..59bd6367af71051d3606da879416fcff132f4773 100644 (file)
@@ -182,7 +182,13 @@ static char *sock_fanout_open_ring(int fd)
                .tp_frame_nr   = RING_NUM_FRAMES,
        };
        char *ring;
+       int val = TPACKET_V2;
 
+       if (setsockopt(fd, SOL_PACKET, PACKET_VERSION, (void *) &val,
+                      sizeof(val))) {
+               perror("packetsock ring setsockopt version");
+               exit(1);
+       }
        if (setsockopt(fd, SOL_PACKET, PACKET_RX_RING, (void *) &req,
                       sizeof(req))) {
                perror("packetsock ring setsockopt");
@@ -201,7 +207,7 @@ static char *sock_fanout_open_ring(int fd)
 
 static int sock_fanout_read_ring(int fd, void *ring)
 {
-       struct tpacket_hdr *header = ring;
+       struct tpacket2_hdr *header = ring;
        int count = 0;
 
        while (header->tp_status & TP_STATUS_USER && count < RING_NUM_FRAMES) {