xref: /freebsd/contrib/unbound/sldns/pkthdr.h (revision b37f6c9805edb4b89f0a8c2b78f78a3dcfc0647b)
1 /*
2  * pkthdr.h - packet header from wire conversion routines
3  *
4  * a Net::DNS like library for C
5  *
6  * (c) NLnet Labs, 2005-2006
7  *
8  * See the file LICENSE for the license
9  */
10 
11 /**
12  * \file
13  *
14  * Contains functions that translate dns data from the wire format (as sent
15  * by servers and clients) to the internal structures for the packet header.
16  */
17 
18 #ifndef LDNS_PKTHDR_H
19 #define LDNS_PKTHDR_H
20 
21 #ifdef __cplusplus
22 extern "C" {
23 #endif
24 
25 /* The length of the header */
26 #define	LDNS_HEADER_SIZE	12
27 
28 /* First octet of flags */
29 #define	LDNS_RD_MASK		0x01U
30 #define	LDNS_RD_SHIFT	0
31 #define	LDNS_RD_WIRE(wirebuf)	(*(wirebuf+2) & LDNS_RD_MASK)
32 #define	LDNS_RD_SET(wirebuf)	(*(wirebuf+2) |= LDNS_RD_MASK)
33 #define	LDNS_RD_CLR(wirebuf)	(*(wirebuf+2) &= ~LDNS_RD_MASK)
34 
35 #define LDNS_TC_MASK		0x02U
36 #define LDNS_TC_SHIFT	1
37 #define	LDNS_TC_WIRE(wirebuf)	(*(wirebuf+2) & LDNS_TC_MASK)
38 #define	LDNS_TC_SET(wirebuf)	(*(wirebuf+2) |= LDNS_TC_MASK)
39 #define	LDNS_TC_CLR(wirebuf)	(*(wirebuf+2) &= ~LDNS_TC_MASK)
40 
41 #define	LDNS_AA_MASK		0x04U
42 #define	LDNS_AA_SHIFT	2
43 #define	LDNS_AA_WIRE(wirebuf)	(*(wirebuf+2) & LDNS_AA_MASK)
44 #define	LDNS_AA_SET(wirebuf)	(*(wirebuf+2) |= LDNS_AA_MASK)
45 #define	LDNS_AA_CLR(wirebuf)	(*(wirebuf+2) &= ~LDNS_AA_MASK)
46 
47 #define	LDNS_OPCODE_MASK	0x78U
48 #define	LDNS_OPCODE_SHIFT	3
49 #define	LDNS_OPCODE_WIRE(wirebuf)	((*(wirebuf+2) & LDNS_OPCODE_MASK) >> LDNS_OPCODE_SHIFT)
50 #define	LDNS_OPCODE_SET(wirebuf, opcode) \
51 	(*(wirebuf+2) = ((*(wirebuf+2)) & ~LDNS_OPCODE_MASK) | ((opcode) << LDNS_OPCODE_SHIFT))
52 
53 #define	LDNS_QR_MASK		0x80U
54 #define	LDNS_QR_SHIFT	7
55 #define	LDNS_QR_WIRE(wirebuf)	(*(wirebuf+2) & LDNS_QR_MASK)
56 #define	LDNS_QR_SET(wirebuf)	(*(wirebuf+2) |= LDNS_QR_MASK)
57 #define	LDNS_QR_CLR(wirebuf)	(*(wirebuf+2) &= ~LDNS_QR_MASK)
58 
59 /* Second octet of flags */
60 #define	LDNS_RCODE_MASK	0x0fU
61 #define	LDNS_RCODE_SHIFT	0
62 #define	LDNS_RCODE_WIRE(wirebuf)	(*(wirebuf+3) & LDNS_RCODE_MASK)
63 #define	LDNS_RCODE_SET(wirebuf, rcode) \
64 	(*(wirebuf+3) = ((*(wirebuf+3)) & ~LDNS_RCODE_MASK) | (rcode))
65 
66 #define	LDNS_CD_MASK		0x10U
67 #define	LDNS_CD_SHIFT	4
68 #define	LDNS_CD_WIRE(wirebuf)	(*(wirebuf+3) & LDNS_CD_MASK)
69 #define	LDNS_CD_SET(wirebuf)	(*(wirebuf+3) |= LDNS_CD_MASK)
70 #define	LDNS_CD_CLR(wirebuf)	(*(wirebuf+3) &= ~LDNS_CD_MASK)
71 
72 #define	LDNS_AD_MASK		0x20U
73 #define	LDNS_AD_SHIFT	5
74 #define	LDNS_AD_WIRE(wirebuf)	(*(wirebuf+3) & LDNS_AD_MASK)
75 #define	LDNS_AD_SET(wirebuf)	(*(wirebuf+3) |= LDNS_AD_MASK)
76 #define	LDNS_AD_CLR(wirebuf)	(*(wirebuf+3) &= ~LDNS_AD_MASK)
77 
78 #define	LDNS_Z_MASK		0x40U
79 #define	LDNS_Z_SHIFT		6
80 #define	LDNS_Z_WIRE(wirebuf)	(*(wirebuf+3) & LDNS_Z_MASK)
81 #define	LDNS_Z_SET(wirebuf)	(*(wirebuf+3) |= LDNS_Z_MASK)
82 #define	LDNS_Z_CLR(wirebuf)	(*(wirebuf+3) &= ~LDNS_Z_MASK)
83 
84 #define	LDNS_RA_MASK		0x80U
85 #define	LDNS_RA_SHIFT	7
86 #define	LDNS_RA_WIRE(wirebuf)	(*(wirebuf+3) & LDNS_RA_MASK)
87 #define	LDNS_RA_SET(wirebuf)	(*(wirebuf+3) |= LDNS_RA_MASK)
88 #define	LDNS_RA_CLR(wirebuf)	(*(wirebuf+3) &= ~LDNS_RA_MASK)
89 
90 /* Query ID */
91 #define	LDNS_ID_WIRE(wirebuf)		(sldns_read_uint16(wirebuf))
92 #define	LDNS_ID_SET(wirebuf, id)	(sldns_write_uint16(wirebuf, id))
93 
94 /* Counter of the question section */
95 #define LDNS_QDCOUNT_OFF		4
96 /*
97 #define	QDCOUNT(wirebuf)		(ntohs(*(uint16_t *)(wirebuf+QDCOUNT_OFF)))
98 */
99 #define	LDNS_QDCOUNT(wirebuf)		(sldns_read_uint16(wirebuf+LDNS_QDCOUNT_OFF))
100 
101 /* Counter of the answer section */
102 #define LDNS_ANCOUNT_OFF		6
103 #define	LDNS_ANCOUNT(wirebuf)		(sldns_read_uint16(wirebuf+LDNS_ANCOUNT_OFF))
104 
105 /* Counter of the authority section */
106 #define LDNS_NSCOUNT_OFF		8
107 #define	LDNS_NSCOUNT(wirebuf)		(sldns_read_uint16(wirebuf+LDNS_NSCOUNT_OFF))
108 
109 /* Counter of the additional section */
110 #define LDNS_ARCOUNT_OFF		10
111 #define	LDNS_ARCOUNT(wirebuf)		(sldns_read_uint16(wirebuf+LDNS_ARCOUNT_OFF))
112 
113 /**
114  * The sections of a packet
115  */
116 enum sldns_enum_pkt_section {
117         LDNS_SECTION_QUESTION = 0,
118         LDNS_SECTION_ANSWER = 1,
119         LDNS_SECTION_AUTHORITY = 2,
120         LDNS_SECTION_ADDITIONAL = 3,
121         /** bogus section, if not interested */
122         LDNS_SECTION_ANY = 4,
123         /** used to get all non-question rrs from a packet */
124         LDNS_SECTION_ANY_NOQUESTION = 5
125 };
126 typedef enum sldns_enum_pkt_section sldns_pkt_section;
127 
128 /* opcodes for pkt's */
129 enum sldns_enum_pkt_opcode {
130         LDNS_PACKET_QUERY = 0,
131         LDNS_PACKET_IQUERY = 1,
132         LDNS_PACKET_STATUS = 2, /* there is no 3?? DNS is weird */
133         LDNS_PACKET_NOTIFY = 4,
134         LDNS_PACKET_UPDATE = 5
135 };
136 typedef enum sldns_enum_pkt_opcode sldns_pkt_opcode;
137 
138 /* rcodes for pkts */
139 enum sldns_enum_pkt_rcode {
140         LDNS_RCODE_NOERROR = 0,
141         LDNS_RCODE_FORMERR = 1,
142         LDNS_RCODE_SERVFAIL = 2,
143         LDNS_RCODE_NXDOMAIN = 3,
144         LDNS_RCODE_NOTIMPL = 4,
145         LDNS_RCODE_REFUSED = 5,
146         LDNS_RCODE_YXDOMAIN = 6,
147         LDNS_RCODE_YXRRSET = 7,
148         LDNS_RCODE_NXRRSET = 8,
149         LDNS_RCODE_NOTAUTH = 9,
150         LDNS_RCODE_NOTZONE = 10
151 };
152 typedef enum sldns_enum_pkt_rcode sldns_pkt_rcode;
153 
154 #ifdef __cplusplus
155 }
156 #endif
157 
158 #endif /* LDNS_PKTHDR_H */
159