xref: /freebsd/share/dtrace/mbuf.d (revision 9f44a47fd07924afc035991af15d84e6585dea4f)
1 /*
2  * Copyright (c) 2016 George V. Neville-Neil
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24  * SUCH DAMAGE.
25  *
26  * $FreeBSD$
27  *
28  * Translators and flags for the mbuf structure.  FreeBSD specific code.
29  */
30 
31 #pragma D depends_on module kernel
32 
33 /*
34  * mbuf flags of global significance and layer crossing.
35  * Those of only protocol/layer specific significance are to be mapped
36  * to M_PROTO[1-12] and cleared at layer handoff boundaries.
37  * NB: Limited to the lower 24 bits.
38  */
39 
40 #pragma D binding "1.6.3" M_EXT
41 inline int M_EXT =	0x00000001; /* has associated external storage */
42 #pragma D binding "1.6.3" M_PKTHDR
43 inline int M_PKTHDR =	0x00000002; /* start of record */
44 #pragma D binding "1.6.3" M_EOR
45 inline int M_EOR =	0x00000004; /* end of record */
46 #pragma D binding "1.6.3" M_RDONLY
47 inline int M_RDONLY =	0x00000008; /* associated data is marked read-only */
48 #pragma D binding "1.6.3" M_BCAST
49 inline int M_BCAST =	0x00000010; /* send/received as link-level broadcast */
50 #pragma D binding "1.6.3" M_MCAST
51 inline int M_MCAST =	0x00000020; /* send/received as link-level multicast */
52 #pragma D binding "1.6.3" M_PROMISC
53 inline int M_PROMISC =	0x00000040; /* packet was not for us */
54 #pragma D binding "1.6.3" M_VLANTAG
55 inline int M_VLANTAG =	0x00000080; /* ether_vtag is valid */
56 #pragma D binding "1.13" M_EXTPG
57 inline int M_EXTPG =	0x00000100; /* has array of unmapped pages and TLS */
58 #pragma D binding "1.6.3" M_NOFREE
59 inline int M_NOFREE =	0x00000200; /* do not free mbuf, embedded in cluster */
60 #pragma D binding "1.13" M_TSTMP
61 inline int M_TSTMP =	0x00000400; /* rcv_tstmp field is valid */
62 #pragma D binding "1.13" M_TSTMP_HPREC
63 inline int M_TSTMP_HPREC = 0x00000800; /* rcv_tstmp is high-prec */
64 #pragma D binding "1.13" M_TSTMP_LRO
65 inline int M_TSTMP_LRO = 0x00001000; /* Time LRO pushed in pkt is valid */
66 
67 #pragma D binding "1.13" M_PROTO1
68 inline int M_PROTO1 =	0x00002000; /* protocol-specific */
69 #pragma D binding "1.13" M_PROTO2
70 inline int M_PROTO2 =	0x00004000; /* protocol-specific */
71 #pragma D binding "1.13" M_PROTO3
72 inline int M_PROTO3 =	0x00008000; /* protocol-specific */
73 #pragma D binding "1.13" M_PROTO4
74 inline int M_PROTO4 =	0x00010000; /* protocol-specific */
75 #pragma D binding "1.13" M_PROTO5
76 inline int M_PROTO5 =	0x00020000; /* protocol-specific */
77 #pragma D binding "1.13" M_PROTO6
78 inline int M_PROTO6 =	0x00040000; /* protocol-specific */
79 #pragma D binding "1.13" M_PROTO7
80 inline int M_PROTO7 =	0x00080000; /* protocol-specific */
81 #pragma D binding "1.13" M_PROTO8
82 inline int M_PROTO8 =	0x00100000; /* protocol-specific */
83 #pragma D binding "1.13" M_PROTO9
84 inline int M_PROTO9 =	0x00200000; /* protocol-specific */
85 #pragma D binding "1.13" M_PROTO10
86 inline int M_PROTO10 =	0x00400000; /* protocol-specific */
87 #pragma D binding "1.13" M_PROTO11
88 inline int M_PROTO11 =	0x00800000; /* protocol-specific */
89 
90 #pragma D binding "1.13" mbufflags_string
91 inline string mbufflags_string[uint32_t flags] =
92     flags & M_EXT ? "M_EXT" :
93     flags & M_PKTHDR ? "M_PKTHDR" :
94     flags & M_EOR  ? "M_EOR" :
95     flags & M_RDONLY  ? "M_RDONLY" :
96     flags & M_BCAST  ? "M_BCAST" :
97     flags & M_MCAST 	? "M_MCAST" :
98     flags & M_PROMISC 	? "M_PROMISC" :
99     flags & M_VLANTAG 	? "M_VLANTAG" :
100     flags & M_EXTPG 	? "M_EXTPG" :
101     flags & M_NOFREE	? "M_NOFREE" :
102     flags & M_TSTMP	? "M_TSTMP" :
103     flags & M_TSTMP_HPREC ? "M_TSTMP_HPREC" :
104     flags & M_TSTMP_LRO ? "M_TSTMP_LRO" :
105     flags & M_PROTO1  ? "M_PROTO1" :
106     flags & M_PROTO2 ? "M_PROTO2" :
107     flags & M_PROTO3 ? "M_PROTO3" :
108     flags & M_PROTO4 ? "M_PROTO4" :
109     flags & M_PROTO5 ? "M_PROTO5" :
110     flags & M_PROTO6 ? "M_PROTO6" :
111     flags & M_PROTO7 ? "M_PROTO7" :
112     flags & M_PROTO8 ? "M_PROTO8" :
113     flags & M_PROTO9 ? "M_PROTO9" :
114     flags & M_PROTO10 ? "M_PROTO10" :
115     flags & M_PROTO11 ? "M_PROTO11" :
116     "none" ;
117 
118 typedef struct mbufinfo {
119 	uintptr_t mbuf_addr;
120 	caddr_t m_data;
121 	int32_t m_len;
122 	uint8_t m_type;
123 	uint32_t m_flags;
124 } mbufinfo_t;
125 
126 translator mbufinfo_t < struct mbuf *p > {
127 	mbuf_addr = (uintptr_t)p;
128 	m_data = p->m_data;
129 	m_len = p->m_len;
130 	m_type = p->m_type & 0xff000000;
131 	m_flags = p->m_type & 0x00ffffff;
132 };
133