xref: /aosp_15_r20/external/strace/nlattr.h (revision cf84ac9a129d8ea9952db616b4e9b904c4bdde56)
1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 2016 Fabien Siron <[email protected]>
3*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 2017 JingPiao Chen <[email protected]>
4*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 2016-2018 The strace developers.
5*cf84ac9aSAndroid Build Coastguard Worker  * All rights reserved.
6*cf84ac9aSAndroid Build Coastguard Worker  *
7*cf84ac9aSAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
8*cf84ac9aSAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
9*cf84ac9aSAndroid Build Coastguard Worker  * are met:
10*cf84ac9aSAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the above copyright
11*cf84ac9aSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
12*cf84ac9aSAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright
13*cf84ac9aSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in the
14*cf84ac9aSAndroid Build Coastguard Worker  *    documentation and/or other materials provided with the distribution.
15*cf84ac9aSAndroid Build Coastguard Worker  * 3. The name of the author may not be used to endorse or promote products
16*cf84ac9aSAndroid Build Coastguard Worker  *    derived from this software without specific prior written permission.
17*cf84ac9aSAndroid Build Coastguard Worker  *
18*cf84ac9aSAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19*cf84ac9aSAndroid Build Coastguard Worker  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20*cf84ac9aSAndroid Build Coastguard Worker  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21*cf84ac9aSAndroid Build Coastguard Worker  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22*cf84ac9aSAndroid Build Coastguard Worker  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23*cf84ac9aSAndroid Build Coastguard Worker  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24*cf84ac9aSAndroid Build Coastguard Worker  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25*cf84ac9aSAndroid Build Coastguard Worker  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26*cf84ac9aSAndroid Build Coastguard Worker  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27*cf84ac9aSAndroid Build Coastguard Worker  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*cf84ac9aSAndroid Build Coastguard Worker  */
29*cf84ac9aSAndroid Build Coastguard Worker 
30*cf84ac9aSAndroid Build Coastguard Worker #ifndef STRACE_NLATTR_H
31*cf84ac9aSAndroid Build Coastguard Worker #define STRACE_NLATTR_H
32*cf84ac9aSAndroid Build Coastguard Worker 
33*cf84ac9aSAndroid Build Coastguard Worker #include "xlat.h"
34*cf84ac9aSAndroid Build Coastguard Worker 
35*cf84ac9aSAndroid Build Coastguard Worker struct decode_nla_xlat_opts {
36*cf84ac9aSAndroid Build Coastguard Worker 	const struct xlat *xlat;
37*cf84ac9aSAndroid Build Coastguard Worker 	size_t xlat_size; /* is not needed for XT_NORMAL */
38*cf84ac9aSAndroid Build Coastguard Worker 	const char *dflt;
39*cf84ac9aSAndroid Build Coastguard Worker 	enum xlat_type xt;
40*cf84ac9aSAndroid Build Coastguard Worker 	enum xlat_style style;
41*cf84ac9aSAndroid Build Coastguard Worker 	const char *prefix;
42*cf84ac9aSAndroid Build Coastguard Worker 	const char *suffix;
43*cf84ac9aSAndroid Build Coastguard Worker 	uint64_t (*process_fn)(uint64_t val);
44*cf84ac9aSAndroid Build Coastguard Worker 	size_t size;
45*cf84ac9aSAndroid Build Coastguard Worker };
46*cf84ac9aSAndroid Build Coastguard Worker 
47*cf84ac9aSAndroid Build Coastguard Worker /*
48*cf84ac9aSAndroid Build Coastguard Worker  * Used for IFLA_LINKINFO decoding.  Since there are no other indicators
49*cf84ac9aSAndroid Build Coastguard Worker  * regarding the nature of data except for previously provided string
50*cf84ac9aSAndroid Build Coastguard Worker  * in an IFLA_LINKINFO_KIND attribute, we have to store it in order to pass
51*cf84ac9aSAndroid Build Coastguard Worker  * between calls as an opaque data.
52*cf84ac9aSAndroid Build Coastguard Worker  */
53*cf84ac9aSAndroid Build Coastguard Worker struct ifla_linkinfo_ctx {
54*cf84ac9aSAndroid Build Coastguard Worker 	char kind[16];
55*cf84ac9aSAndroid Build Coastguard Worker };
56*cf84ac9aSAndroid Build Coastguard Worker 
57*cf84ac9aSAndroid Build Coastguard Worker typedef bool (*nla_decoder_t)(struct tcb *, kernel_ulong_t addr,
58*cf84ac9aSAndroid Build Coastguard Worker 			      unsigned int len, const void *opaque_data);
59*cf84ac9aSAndroid Build Coastguard Worker 
60*cf84ac9aSAndroid Build Coastguard Worker /**
61*cf84ac9aSAndroid Build Coastguard Worker  * The case of non-NULL decoders and zero size is handled in a special way:
62*cf84ac9aSAndroid Build Coastguard Worker  * the zeroth decoder is always called with nla_type being passed as opaque
63*cf84ac9aSAndroid Build Coastguard Worker  * data.
64*cf84ac9aSAndroid Build Coastguard Worker  */
65*cf84ac9aSAndroid Build Coastguard Worker extern void
66*cf84ac9aSAndroid Build Coastguard Worker decode_nlattr(struct tcb *,
67*cf84ac9aSAndroid Build Coastguard Worker 	      kernel_ulong_t addr,
68*cf84ac9aSAndroid Build Coastguard Worker 	      unsigned int len,
69*cf84ac9aSAndroid Build Coastguard Worker 	      const struct xlat *,
70*cf84ac9aSAndroid Build Coastguard Worker 	      const char *dflt,
71*cf84ac9aSAndroid Build Coastguard Worker 	      const nla_decoder_t *decoders,
72*cf84ac9aSAndroid Build Coastguard Worker 	      unsigned int size,
73*cf84ac9aSAndroid Build Coastguard Worker 	      const void *opaque_data);
74*cf84ac9aSAndroid Build Coastguard Worker 
75*cf84ac9aSAndroid Build Coastguard Worker #define DECL_NLA(name)					\
76*cf84ac9aSAndroid Build Coastguard Worker extern bool						\
77*cf84ac9aSAndroid Build Coastguard Worker decode_nla_ ## name(struct tcb *, kernel_ulong_t addr,	\
78*cf84ac9aSAndroid Build Coastguard Worker 		    unsigned int len, const void *)	\
79*cf84ac9aSAndroid Build Coastguard Worker /* End of DECL_NLA definition. */
80*cf84ac9aSAndroid Build Coastguard Worker 
81*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(x8);
82*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(x16);
83*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(x32);
84*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(x64);
85*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(u8);
86*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(u16);
87*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(u32);
88*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(u64);
89*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(s8);
90*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(s16);
91*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(s32);
92*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(s64);
93*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(be16);
94*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(be64);
95*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(xval);
96*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(flags);
97*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(str);
98*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(strn);
99*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(fd);
100*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(uid);
101*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(gid);
102*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(ifindex);
103*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(ether_proto);
104*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(ip_proto);
105*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(in_addr);
106*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(in6_addr);
107*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(meminfo);
108*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(rt_class);
109*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(rt_proto);
110*cf84ac9aSAndroid Build Coastguard Worker DECL_NLA(tc_stats);
111*cf84ac9aSAndroid Build Coastguard Worker 
112*cf84ac9aSAndroid Build Coastguard Worker #endif /* !STRACE_NLATTR_H */
113