]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/resolve/resolved-dns-packet.h
missing.h: add IFLA_MACVLAN_FLAGS
[thirdparty/systemd.git] / src / resolve / resolved-dns-packet.h
CommitLineData
74b2466e
LP
1/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3#pragma once
4
5/***
6 This file is part of systemd.
7
8 Copyright 2014 Lennart Poettering
9
10 systemd is free software; you can redistribute it and/or modify it
11 under the terms of the GNU Lesser General Public License as published by
12 the Free Software Foundation; either version 2.1 of the License, or
13 (at your option) any later version.
14
15 systemd is distributed in the hope that it will be useful, but
16 WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 Lesser General Public License for more details.
19
20 You should have received a copy of the GNU Lesser General Public License
21 along with systemd; If not, see <http://www.gnu.org/licenses/>.
22 ***/
23
24typedef struct DnsPacketHeader DnsPacketHeader;
25typedef struct DnsPacket DnsPacket;
26
27#include <inttypes.h>
28
29#include "macro.h"
30#include "sparse-endian.h"
31#include "hashmap.h"
32#include "resolved-dns-rr.h"
33
34struct DnsPacketHeader {
35 uint16_t id;
36 be16_t flags;
37 be16_t qdcount;
38 be16_t ancount;
39 be16_t nscount;
40 be16_t arcount;
41};
42
43#define DNS_PACKET_HEADER_SIZE sizeof(DnsPacketHeader)
c73ce96b
LP
44
45/* The various DNS protocols deviate in how large a packet can grow,
46 but the TCP transport has a 16bit size field, hence that appears to
47 be the maximum. */
48#define DNS_PACKET_SIZE_MAX 0xFFFF
74b2466e
LP
49#define DNS_PACKET_SIZE_START 512
50
51struct DnsPacket {
52 int n_ref;
c73ce96b 53 int ifindex;
74b2466e
LP
54 size_t size, allocated, rindex;
55 Hashmap *names; /* For name compression */
56 void *data;
74b2466e
LP
57};
58
59static inline uint8_t* DNS_PACKET_DATA(DnsPacket *p) {
60 if (_unlikely_(!p))
61 return NULL;
62
63 if (p->data)
64 return p->data;
65
66 return ((uint8_t*) p) + ALIGN(sizeof(DnsPacket));
67}
68
69#define DNS_PACKET_HEADER(p) ((DnsPacketHeader*) DNS_PACKET_DATA(p))
3cb10d3a
LP
70#define DNS_PACKET_ID(p) DNS_PACKET_HEADER(p)->id
71#define DNS_PACKET_QR(p) ((be16toh(DNS_PACKET_HEADER(p)->flags) >> 15) & 1)
72#define DNS_PACKET_OPCODE(p) ((be16toh(DNS_PACKET_HEADER(p)->flags) >> 11) & 15)
73#define DNS_PACKET_RCODE(p) (be16toh(DNS_PACKET_HEADER(p)->flags) & 15)
ad867662 74#define DNS_PACKET_TC(p) ((be16toh(DNS_PACKET_HEADER(p)->flags) >> 9) & 1)
3cb10d3a
LP
75#define DNS_PACKET_QDCOUNT(p) be16toh(DNS_PACKET_HEADER(p)->qdcount)
76#define DNS_PACKET_ANCOUNT(p) be16toh(DNS_PACKET_HEADER(p)->ancount)
77#define DNS_PACKET_NSCOUNT(p) be16toh(DNS_PACKET_HEADER(p)->nscount)
78#define DNS_PACKET_ARCOUNT(p) be16toh(DNS_PACKET_HEADER(p)->arcount)
79
80#define DNS_PACKET_MAKE_FLAGS(qr, opcode, aa, tc, rd, ra, ad, cd, rcode) \
81 (((uint16_t) !!qr << 15) | \
82 ((uint16_t) (opcode & 15) << 11) | \
83 ((uint16_t) !!aa << 10) | \
84 ((uint16_t) !!tc << 9) | \
85 ((uint16_t) !!rd << 8) | \
86 ((uint16_t) !!ra << 7) | \
87 ((uint16_t) !!ad << 5) | \
88 ((uint16_t) !!cd << 4) | \
89 ((uint16_t) (rcode & 15)))
90
74b2466e
LP
91
92int dns_packet_new(DnsPacket **p, size_t mtu);
93int dns_packet_new_query(DnsPacket **p, size_t mtu);
94
95DnsPacket *dns_packet_ref(DnsPacket *p);
96DnsPacket *dns_packet_unref(DnsPacket *p);
97
98DEFINE_TRIVIAL_CLEANUP_FUNC(DnsPacket*, dns_packet_unref);
99
100int dns_packet_validate(DnsPacket *p);
101int dns_packet_validate_reply(DnsPacket *p);
102
103int dns_packet_append_uint8(DnsPacket *p, uint8_t v, size_t *start);
104int dns_packet_append_uint16(DnsPacket *p, uint16_t v, size_t *start);
105int dns_packet_append_string(DnsPacket *p, const char *s, size_t *start);
106int dns_packet_append_label(DnsPacket *p, const char *s, size_t l, size_t *start);
107int dns_packet_append_name(DnsPacket *p, const char *name, size_t *start);
108int dns_packet_append_key(DnsPacket *p, const DnsResourceKey *k, size_t *start);
109
110int dns_packet_read(DnsPacket *p, size_t sz, const void **ret, size_t *start);
111int dns_packet_read_uint8(DnsPacket *p, uint8_t *ret, size_t *start);
112int dns_packet_read_uint16(DnsPacket *p, uint16_t *ret, size_t *start);
113int dns_packet_read_uint32(DnsPacket *p, uint32_t *ret, size_t *start);
114int dns_packet_read_string(DnsPacket *p, char **ret, size_t *start);
115int dns_packet_read_name(DnsPacket *p, char **ret, size_t *start);
116int dns_packet_read_key(DnsPacket *p, DnsResourceKey *ret, size_t *start);
117int dns_packet_read_rr(DnsPacket *p, DnsResourceRecord **ret, size_t *start);
118
119int dns_packet_skip_question(DnsPacket *p);
120
74b2466e
LP
121enum {
122 DNS_RCODE_SUCCESS = 0,
123 DNS_RCODE_FORMERR = 1,
124 DNS_RCODE_SERVFAIL = 2,
125 DNS_RCODE_NXDOMAIN = 3,
126 DNS_RCODE_NOTIMP = 4,
127 DNS_RCODE_REFUSED = 5,
128 DNS_RCODE_YXDOMAIN = 6,
129 DNS_RCODE_YXRRSET = 7,
130 DNS_RCODE_NXRRSET = 8,
131 DNS_RCODE_NOTAUTH = 9,
132 DNS_RCODE_NOTZONE = 10,
133 DNS_RCODE_BADVERS = 16,
134 DNS_RCODE_BADSIG = 16, /* duplicate value! */
135 DNS_RCODE_BADKEY = 17,
136 DNS_RCODE_BADTIME = 18,
137 DNS_RCODE_BADMODE = 19,
138 DNS_RCODE_BADNAME = 20,
139 DNS_RCODE_BADALG = 21,
140 DNS_RCODE_BADTRUNC = 22,
141 _DNS_RCODE_MAX_DEFINED
142};
143
144const char* dns_rcode_to_string(int i) _const_;
145int dns_rcode_from_string(const char *s) _pure_;