1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2017 JingPiao Chen <[email protected]>
3*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2017-2018 The strace developers.
4*cf84ac9aSAndroid Build Coastguard Worker * All rights reserved.
5*cf84ac9aSAndroid Build Coastguard Worker *
6*cf84ac9aSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
7*cf84ac9aSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions
8*cf84ac9aSAndroid Build Coastguard Worker * are met:
9*cf84ac9aSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright
10*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
11*cf84ac9aSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
12*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
13*cf84ac9aSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
14*cf84ac9aSAndroid Build Coastguard Worker * 3. The name of the author may not be used to endorse or promote products
15*cf84ac9aSAndroid Build Coastguard Worker * derived from this software without specific prior written permission.
16*cf84ac9aSAndroid Build Coastguard Worker *
17*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18*cf84ac9aSAndroid Build Coastguard Worker * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19*cf84ac9aSAndroid Build Coastguard Worker * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20*cf84ac9aSAndroid Build Coastguard Worker * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21*cf84ac9aSAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22*cf84ac9aSAndroid Build Coastguard Worker * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23*cf84ac9aSAndroid Build Coastguard Worker * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24*cf84ac9aSAndroid Build Coastguard Worker * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25*cf84ac9aSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27*cf84ac9aSAndroid Build Coastguard Worker */
28*cf84ac9aSAndroid Build Coastguard Worker
29*cf84ac9aSAndroid Build Coastguard Worker #include "tests.h"
30*cf84ac9aSAndroid Build Coastguard Worker
31*cf84ac9aSAndroid Build Coastguard Worker #include <stdio.h>
32*cf84ac9aSAndroid Build Coastguard Worker #include <string.h>
33*cf84ac9aSAndroid Build Coastguard Worker #include <stdint.h>
34*cf84ac9aSAndroid Build Coastguard Worker #include <net/if.h>
35*cf84ac9aSAndroid Build Coastguard Worker #include "test_nlattr.h"
36*cf84ac9aSAndroid Build Coastguard Worker #include <sys/socket.h>
37*cf84ac9aSAndroid Build Coastguard Worker #include <linux/filter.h>
38*cf84ac9aSAndroid Build Coastguard Worker #include <linux/packet_diag.h>
39*cf84ac9aSAndroid Build Coastguard Worker #include <linux/rtnetlink.h>
40*cf84ac9aSAndroid Build Coastguard Worker #include <linux/sock_diag.h>
41*cf84ac9aSAndroid Build Coastguard Worker
42*cf84ac9aSAndroid Build Coastguard Worker static void
init_packet_diag_msg(struct nlmsghdr * const nlh,const unsigned int msg_len)43*cf84ac9aSAndroid Build Coastguard Worker init_packet_diag_msg(struct nlmsghdr *const nlh, const unsigned int msg_len)
44*cf84ac9aSAndroid Build Coastguard Worker {
45*cf84ac9aSAndroid Build Coastguard Worker SET_STRUCT(struct nlmsghdr, nlh,
46*cf84ac9aSAndroid Build Coastguard Worker .nlmsg_len = msg_len,
47*cf84ac9aSAndroid Build Coastguard Worker .nlmsg_type = SOCK_DIAG_BY_FAMILY,
48*cf84ac9aSAndroid Build Coastguard Worker .nlmsg_flags = NLM_F_DUMP
49*cf84ac9aSAndroid Build Coastguard Worker );
50*cf84ac9aSAndroid Build Coastguard Worker
51*cf84ac9aSAndroid Build Coastguard Worker struct packet_diag_msg *const msg = NLMSG_DATA(nlh);
52*cf84ac9aSAndroid Build Coastguard Worker SET_STRUCT(struct packet_diag_msg, msg,
53*cf84ac9aSAndroid Build Coastguard Worker .pdiag_family = AF_PACKET,
54*cf84ac9aSAndroid Build Coastguard Worker .pdiag_type = SOCK_STREAM,
55*cf84ac9aSAndroid Build Coastguard Worker .pdiag_num = 3,
56*cf84ac9aSAndroid Build Coastguard Worker );
57*cf84ac9aSAndroid Build Coastguard Worker }
58*cf84ac9aSAndroid Build Coastguard Worker
59*cf84ac9aSAndroid Build Coastguard Worker static void
print_packet_diag_msg(const unsigned int msg_len)60*cf84ac9aSAndroid Build Coastguard Worker print_packet_diag_msg(const unsigned int msg_len)
61*cf84ac9aSAndroid Build Coastguard Worker {
62*cf84ac9aSAndroid Build Coastguard Worker printf("{len=%u, type=SOCK_DIAG_BY_FAMILY"
63*cf84ac9aSAndroid Build Coastguard Worker ", flags=NLM_F_DUMP, seq=0, pid=0}"
64*cf84ac9aSAndroid Build Coastguard Worker ", {pdiag_family=AF_PACKET"
65*cf84ac9aSAndroid Build Coastguard Worker ", pdiag_type=SOCK_STREAM, pdiag_num=ETH_P_ALL"
66*cf84ac9aSAndroid Build Coastguard Worker ", pdiag_ino=0, pdiag_cookie=[0, 0]}",
67*cf84ac9aSAndroid Build Coastguard Worker msg_len);
68*cf84ac9aSAndroid Build Coastguard Worker }
69*cf84ac9aSAndroid Build Coastguard Worker
70*cf84ac9aSAndroid Build Coastguard Worker static void
print_packet_diag_mclist(const struct packet_diag_mclist * const dml,size_t i)71*cf84ac9aSAndroid Build Coastguard Worker print_packet_diag_mclist(const struct packet_diag_mclist *const dml, size_t i)
72*cf84ac9aSAndroid Build Coastguard Worker {
73*cf84ac9aSAndroid Build Coastguard Worker printf("{pdmc_index=" IFINDEX_LO_STR);
74*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *dml, pdmc_count);
75*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *dml, pdmc_type);
76*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *dml, pdmc_alen);
77*cf84ac9aSAndroid Build Coastguard Worker printf(", pdmc_addr=");
78*cf84ac9aSAndroid Build Coastguard Worker print_quoted_hex(dml->pdmc_addr, dml->pdmc_alen);
79*cf84ac9aSAndroid Build Coastguard Worker printf("}");
80*cf84ac9aSAndroid Build Coastguard Worker }
81*cf84ac9aSAndroid Build Coastguard Worker
82*cf84ac9aSAndroid Build Coastguard Worker static const struct sock_filter filter[] = {
83*cf84ac9aSAndroid Build Coastguard Worker BPF_STMT(BPF_LD|BPF_B|BPF_ABS, SKF_AD_OFF+SKF_AD_PKTTYPE),
84*cf84ac9aSAndroid Build Coastguard Worker BPF_STMT(BPF_RET|BPF_K, 0x2a)
85*cf84ac9aSAndroid Build Coastguard Worker };
86*cf84ac9aSAndroid Build Coastguard Worker
87*cf84ac9aSAndroid Build Coastguard Worker static void
print_sock_filter(const struct sock_filter * const f,size_t i)88*cf84ac9aSAndroid Build Coastguard Worker print_sock_filter(const struct sock_filter *const f, size_t i)
89*cf84ac9aSAndroid Build Coastguard Worker {
90*cf84ac9aSAndroid Build Coastguard Worker if (f == filter)
91*cf84ac9aSAndroid Build Coastguard Worker printf("BPF_STMT(BPF_LD|BPF_B|BPF_ABS"
92*cf84ac9aSAndroid Build Coastguard Worker ", SKF_AD_OFF+SKF_AD_PKTTYPE)");
93*cf84ac9aSAndroid Build Coastguard Worker else
94*cf84ac9aSAndroid Build Coastguard Worker printf("BPF_STMT(BPF_RET|BPF_K, 0x2a)");
95*cf84ac9aSAndroid Build Coastguard Worker }
96*cf84ac9aSAndroid Build Coastguard Worker
97*cf84ac9aSAndroid Build Coastguard Worker int
main(void)98*cf84ac9aSAndroid Build Coastguard Worker main(void)
99*cf84ac9aSAndroid Build Coastguard Worker {
100*cf84ac9aSAndroid Build Coastguard Worker skip_if_unavailable("/proc/self/fd/");
101*cf84ac9aSAndroid Build Coastguard Worker
102*cf84ac9aSAndroid Build Coastguard Worker struct packet_diag_info pinfo = {
103*cf84ac9aSAndroid Build Coastguard Worker .pdi_index = ifindex_lo(),
104*cf84ac9aSAndroid Build Coastguard Worker .pdi_version = 2,
105*cf84ac9aSAndroid Build Coastguard Worker .pdi_reserve = 0xcfaacdaf,
106*cf84ac9aSAndroid Build Coastguard Worker .pdi_copy_thresh = 0xdabacdaf,
107*cf84ac9aSAndroid Build Coastguard Worker .pdi_tstamp = 0xeafbaadf,
108*cf84ac9aSAndroid Build Coastguard Worker .pdi_flags = PDI_RUNNING
109*cf84ac9aSAndroid Build Coastguard Worker };
110*cf84ac9aSAndroid Build Coastguard Worker const struct packet_diag_mclist dml[] = {
111*cf84ac9aSAndroid Build Coastguard Worker {
112*cf84ac9aSAndroid Build Coastguard Worker .pdmc_index = ifindex_lo(),
113*cf84ac9aSAndroid Build Coastguard Worker .pdmc_count = 0xabcdaefc,
114*cf84ac9aSAndroid Build Coastguard Worker .pdmc_type = 0xcdaf,
115*cf84ac9aSAndroid Build Coastguard Worker .pdmc_alen = 4,
116*cf84ac9aSAndroid Build Coastguard Worker .pdmc_addr = "1234"
117*cf84ac9aSAndroid Build Coastguard Worker },
118*cf84ac9aSAndroid Build Coastguard Worker {
119*cf84ac9aSAndroid Build Coastguard Worker .pdmc_index = ifindex_lo(),
120*cf84ac9aSAndroid Build Coastguard Worker .pdmc_count = 0xdaefeafc,
121*cf84ac9aSAndroid Build Coastguard Worker .pdmc_type = 0xadef,
122*cf84ac9aSAndroid Build Coastguard Worker .pdmc_alen = 4,
123*cf84ac9aSAndroid Build Coastguard Worker .pdmc_addr = "5678"
124*cf84ac9aSAndroid Build Coastguard Worker }
125*cf84ac9aSAndroid Build Coastguard Worker };
126*cf84ac9aSAndroid Build Coastguard Worker static const struct packet_diag_ring pdr = {
127*cf84ac9aSAndroid Build Coastguard Worker .pdr_block_size = 0xabcdafed,
128*cf84ac9aSAndroid Build Coastguard Worker .pdr_block_nr = 0xbcadefae,
129*cf84ac9aSAndroid Build Coastguard Worker .pdr_frame_size = 0xcabdfeac,
130*cf84ac9aSAndroid Build Coastguard Worker .pdr_frame_nr = 0xdeaeadef,
131*cf84ac9aSAndroid Build Coastguard Worker .pdr_retire_tmo = 0xedbafeac,
132*cf84ac9aSAndroid Build Coastguard Worker .pdr_sizeof_priv = 0xfeadeacd,
133*cf84ac9aSAndroid Build Coastguard Worker .pdr_features = 0xadebadea
134*cf84ac9aSAndroid Build Coastguard Worker };
135*cf84ac9aSAndroid Build Coastguard Worker
136*cf84ac9aSAndroid Build Coastguard Worker int fd = create_nl_socket(NETLINK_SOCK_DIAG);
137*cf84ac9aSAndroid Build Coastguard Worker const unsigned int hdrlen = sizeof(struct packet_diag_msg);
138*cf84ac9aSAndroid Build Coastguard Worker void *const nlh0 = midtail_alloc(NLMSG_SPACE(hdrlen),
139*cf84ac9aSAndroid Build Coastguard Worker NLA_HDRLEN + sizeof(dml));
140*cf84ac9aSAndroid Build Coastguard Worker
141*cf84ac9aSAndroid Build Coastguard Worker static char pattern[4096];
142*cf84ac9aSAndroid Build Coastguard Worker fill_memory_ex(pattern, sizeof(pattern), 'a', 'z' - 'a' + 1);
143*cf84ac9aSAndroid Build Coastguard Worker
144*cf84ac9aSAndroid Build Coastguard Worker TEST_NLATTR_OBJECT(fd, nlh0, hdrlen,
145*cf84ac9aSAndroid Build Coastguard Worker init_packet_diag_msg, print_packet_diag_msg,
146*cf84ac9aSAndroid Build Coastguard Worker PACKET_DIAG_INFO, pattern, pinfo,
147*cf84ac9aSAndroid Build Coastguard Worker printf("{pdi_index=%s", IFINDEX_LO_STR);
148*cf84ac9aSAndroid Build Coastguard Worker printf(", pdi_version=TPACKET_V3");
149*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", pinfo, pdi_reserve);
150*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", pinfo, pdi_copy_thresh);
151*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", pinfo, pdi_tstamp);
152*cf84ac9aSAndroid Build Coastguard Worker printf(", pdi_flags=PDI_RUNNING}"));
153*cf84ac9aSAndroid Build Coastguard Worker
154*cf84ac9aSAndroid Build Coastguard Worker TEST_NLATTR_ARRAY(fd, nlh0, hdrlen,
155*cf84ac9aSAndroid Build Coastguard Worker init_packet_diag_msg, print_packet_diag_msg,
156*cf84ac9aSAndroid Build Coastguard Worker PACKET_DIAG_MCLIST, pattern, dml,
157*cf84ac9aSAndroid Build Coastguard Worker print_packet_diag_mclist);
158*cf84ac9aSAndroid Build Coastguard Worker
159*cf84ac9aSAndroid Build Coastguard Worker TEST_NLATTR_OBJECT(fd, nlh0, hdrlen,
160*cf84ac9aSAndroid Build Coastguard Worker init_packet_diag_msg, print_packet_diag_msg,
161*cf84ac9aSAndroid Build Coastguard Worker PACKET_DIAG_RX_RING, pattern, pdr,
162*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U("{", pdr, pdr_block_size);
163*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", pdr, pdr_block_nr);
164*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", pdr, pdr_frame_size);
165*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", pdr, pdr_frame_nr);
166*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", pdr, pdr_retire_tmo);
167*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", pdr, pdr_sizeof_priv);
168*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", pdr, pdr_features);
169*cf84ac9aSAndroid Build Coastguard Worker printf("}"));
170*cf84ac9aSAndroid Build Coastguard Worker
171*cf84ac9aSAndroid Build Coastguard Worker TEST_NLATTR_ARRAY(fd, nlh0, hdrlen,
172*cf84ac9aSAndroid Build Coastguard Worker init_packet_diag_msg, print_packet_diag_msg,
173*cf84ac9aSAndroid Build Coastguard Worker PACKET_DIAG_FILTER, pattern, filter,
174*cf84ac9aSAndroid Build Coastguard Worker print_sock_filter);
175*cf84ac9aSAndroid Build Coastguard Worker
176*cf84ac9aSAndroid Build Coastguard Worker printf("+++ exited with 0 +++\n");
177*cf84ac9aSAndroid Build Coastguard Worker return 0;
178*cf84ac9aSAndroid Build Coastguard Worker }
179