xref: /minix3/external/bsd/dhcpcd/dist/ipv4.h (revision 9f20bfa6c4c442e2e798d91b11c2a5f8d6833a41)
1*9f20bfa6SDavid van Moolenbroek /* $NetBSD: ipv4.h,v 1.13 2015/08/21 10:39:00 roy Exp $ */
2*9f20bfa6SDavid van Moolenbroek 
3*9f20bfa6SDavid van Moolenbroek /*
4*9f20bfa6SDavid van Moolenbroek  * dhcpcd - DHCP client daemon
5*9f20bfa6SDavid van Moolenbroek  * Copyright (c) 2006-2015 Roy Marples <roy@marples.name>
6*9f20bfa6SDavid van Moolenbroek  * All rights reserved
7*9f20bfa6SDavid van Moolenbroek 
8*9f20bfa6SDavid van Moolenbroek  * Redistribution and use in source and binary forms, with or without
9*9f20bfa6SDavid van Moolenbroek  * modification, are permitted provided that the following conditions
10*9f20bfa6SDavid van Moolenbroek  * are met:
11*9f20bfa6SDavid van Moolenbroek  * 1. Redistributions of source code must retain the above copyright
12*9f20bfa6SDavid van Moolenbroek  *    notice, this list of conditions and the following disclaimer.
13*9f20bfa6SDavid van Moolenbroek  * 2. Redistributions in binary form must reproduce the above copyright
14*9f20bfa6SDavid van Moolenbroek  *    notice, this list of conditions and the following disclaimer in the
15*9f20bfa6SDavid van Moolenbroek  *    documentation and/or other materials provided with the distribution.
16*9f20bfa6SDavid van Moolenbroek  *
17*9f20bfa6SDavid van Moolenbroek  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
18*9f20bfa6SDavid van Moolenbroek  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19*9f20bfa6SDavid van Moolenbroek  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20*9f20bfa6SDavid van Moolenbroek  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
21*9f20bfa6SDavid van Moolenbroek  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22*9f20bfa6SDavid van Moolenbroek  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23*9f20bfa6SDavid van Moolenbroek  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24*9f20bfa6SDavid van Moolenbroek  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25*9f20bfa6SDavid van Moolenbroek  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26*9f20bfa6SDavid van Moolenbroek  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27*9f20bfa6SDavid van Moolenbroek  * SUCH DAMAGE.
28*9f20bfa6SDavid van Moolenbroek  */
29*9f20bfa6SDavid van Moolenbroek 
30*9f20bfa6SDavid van Moolenbroek #ifndef IPV4_H
31*9f20bfa6SDavid van Moolenbroek #define IPV4_H
32*9f20bfa6SDavid van Moolenbroek 
33*9f20bfa6SDavid van Moolenbroek #include "dhcpcd.h"
34*9f20bfa6SDavid van Moolenbroek 
35*9f20bfa6SDavid van Moolenbroek #ifdef IN_IFF_TENTATIVE
36*9f20bfa6SDavid van Moolenbroek #define IN_IFF_NOTUSEABLE \
37*9f20bfa6SDavid van Moolenbroek         (IN_IFF_TENTATIVE | IN_IFF_DUPLICATED | IN_IFF_DETACHED)
38*9f20bfa6SDavid van Moolenbroek #endif
39*9f20bfa6SDavid van Moolenbroek 
40*9f20bfa6SDavid van Moolenbroek /* Prefer our macro */
41*9f20bfa6SDavid van Moolenbroek #ifdef HTONL
42*9f20bfa6SDavid van Moolenbroek #undef HTONL
43*9f20bfa6SDavid van Moolenbroek #endif
44*9f20bfa6SDavid van Moolenbroek 
45*9f20bfa6SDavid van Moolenbroek #if BYTE_ORDER == BIG_ENDIAN
46*9f20bfa6SDavid van Moolenbroek #define HTONL(A) (A)
47*9f20bfa6SDavid van Moolenbroek #elif BYTE_ORDER == LITTLE_ENDIAN
48*9f20bfa6SDavid van Moolenbroek #define HTONL(A) \
49*9f20bfa6SDavid van Moolenbroek     ((((uint32_t)(A) & 0xff000000) >> 24) | \
50*9f20bfa6SDavid van Moolenbroek     (((uint32_t)(A) & 0x00ff0000) >> 8) | \
51*9f20bfa6SDavid van Moolenbroek     (((uint32_t)(A) & 0x0000ff00) << 8) | \
52*9f20bfa6SDavid van Moolenbroek     (((uint32_t)(A) & 0x000000ff) << 24))
53*9f20bfa6SDavid van Moolenbroek #else
54*9f20bfa6SDavid van Moolenbroek #error Endian unknown
55*9f20bfa6SDavid van Moolenbroek #endif /* BYTE_ORDER */
56*9f20bfa6SDavid van Moolenbroek 
57*9f20bfa6SDavid van Moolenbroek struct rt {
58*9f20bfa6SDavid van Moolenbroek 	TAILQ_ENTRY(rt) next;
59*9f20bfa6SDavid van Moolenbroek 	struct in_addr dest;
60*9f20bfa6SDavid van Moolenbroek 	struct in_addr net;
61*9f20bfa6SDavid van Moolenbroek 	struct in_addr gate;
62*9f20bfa6SDavid van Moolenbroek 	const struct interface *iface;
63*9f20bfa6SDavid van Moolenbroek #ifdef HAVE_ROUTE_METRIC
64*9f20bfa6SDavid van Moolenbroek 	unsigned int metric;
65*9f20bfa6SDavid van Moolenbroek #endif
66*9f20bfa6SDavid van Moolenbroek 	unsigned int mtu;
67*9f20bfa6SDavid van Moolenbroek 	struct in_addr src;
68*9f20bfa6SDavid van Moolenbroek 	unsigned int flags;
69*9f20bfa6SDavid van Moolenbroek 	unsigned int state;
70*9f20bfa6SDavid van Moolenbroek };
71*9f20bfa6SDavid van Moolenbroek TAILQ_HEAD(rt_head, rt);
72*9f20bfa6SDavid van Moolenbroek 
73*9f20bfa6SDavid van Moolenbroek struct ipv4_addr {
74*9f20bfa6SDavid van Moolenbroek 	TAILQ_ENTRY(ipv4_addr) next;
75*9f20bfa6SDavid van Moolenbroek 	struct in_addr addr;
76*9f20bfa6SDavid van Moolenbroek 	struct in_addr net;
77*9f20bfa6SDavid van Moolenbroek 	struct in_addr dst;
78*9f20bfa6SDavid van Moolenbroek 	struct interface *iface;
79*9f20bfa6SDavid van Moolenbroek 	int addr_flags;
80*9f20bfa6SDavid van Moolenbroek };
81*9f20bfa6SDavid van Moolenbroek TAILQ_HEAD(ipv4_addrhead, ipv4_addr);
82*9f20bfa6SDavid van Moolenbroek 
83*9f20bfa6SDavid van Moolenbroek struct ipv4_state {
84*9f20bfa6SDavid van Moolenbroek 	struct ipv4_addrhead addrs;
85*9f20bfa6SDavid van Moolenbroek 	struct rt_head routes;
86*9f20bfa6SDavid van Moolenbroek 
87*9f20bfa6SDavid van Moolenbroek #ifdef BSD
88*9f20bfa6SDavid van Moolenbroek 	/* Buffer for BPF */
89*9f20bfa6SDavid van Moolenbroek 	size_t buffer_size, buffer_len, buffer_pos;
90*9f20bfa6SDavid van Moolenbroek 	unsigned char *buffer;
91*9f20bfa6SDavid van Moolenbroek #endif
92*9f20bfa6SDavid van Moolenbroek };
93*9f20bfa6SDavid van Moolenbroek 
94*9f20bfa6SDavid van Moolenbroek #define IPV4_STATE(ifp)							       \
95*9f20bfa6SDavid van Moolenbroek 	((struct ipv4_state *)(ifp)->if_data[IF_DATA_IPV4])
96*9f20bfa6SDavid van Moolenbroek #define IPV4_CSTATE(ifp)						       \
97*9f20bfa6SDavid van Moolenbroek 	((const struct ipv4_state *)(ifp)->if_data[IF_DATA_IPV4])
98*9f20bfa6SDavid van Moolenbroek 
99*9f20bfa6SDavid van Moolenbroek #ifdef INET
100*9f20bfa6SDavid van Moolenbroek struct ipv4_state *ipv4_getstate(struct interface *);
101*9f20bfa6SDavid van Moolenbroek int ipv4_init(struct dhcpcd_ctx *);
102*9f20bfa6SDavid van Moolenbroek int ipv4_protocol_fd(const struct interface *, uint16_t);
103*9f20bfa6SDavid van Moolenbroek int ipv4_ifcmp(const struct interface *, const struct interface *);
104*9f20bfa6SDavid van Moolenbroek uint8_t inet_ntocidr(struct in_addr);
105*9f20bfa6SDavid van Moolenbroek int inet_cidrtoaddr(int, struct in_addr *);
106*9f20bfa6SDavid van Moolenbroek uint32_t ipv4_getnetmask(uint32_t);
107*9f20bfa6SDavid van Moolenbroek int ipv4_hasaddr(const struct interface *);
108*9f20bfa6SDavid van Moolenbroek 
109*9f20bfa6SDavid van Moolenbroek #define STATE_ADDED		0x01
110*9f20bfa6SDavid van Moolenbroek #define STATE_FAKE		0x02
111*9f20bfa6SDavid van Moolenbroek 
112*9f20bfa6SDavid van Moolenbroek void ipv4_buildroutes(struct dhcpcd_ctx *);
113*9f20bfa6SDavid van Moolenbroek int ipv4_deladdr(struct interface *, const struct in_addr *,
114*9f20bfa6SDavid van Moolenbroek     const struct in_addr *, int);
115*9f20bfa6SDavid van Moolenbroek int ipv4_preferanother(struct interface *);
116*9f20bfa6SDavid van Moolenbroek struct ipv4_addr *ipv4_addaddr(struct interface *,
117*9f20bfa6SDavid van Moolenbroek     const struct in_addr *, const struct in_addr *, const struct in_addr *);
118*9f20bfa6SDavid van Moolenbroek void ipv4_applyaddr(void *);
119*9f20bfa6SDavid van Moolenbroek int ipv4_handlert(struct dhcpcd_ctx *, int, struct rt *);
120*9f20bfa6SDavid van Moolenbroek void ipv4_freerts(struct rt_head *);
121*9f20bfa6SDavid van Moolenbroek 
122*9f20bfa6SDavid van Moolenbroek struct ipv4_addr *ipv4_iffindaddr(struct interface *,
123*9f20bfa6SDavid van Moolenbroek     const struct in_addr *, const struct in_addr *);
124*9f20bfa6SDavid van Moolenbroek struct ipv4_addr *ipv4_iffindlladdr(struct interface *);
125*9f20bfa6SDavid van Moolenbroek struct ipv4_addr *ipv4_findaddr(struct dhcpcd_ctx *, const struct in_addr *);
126*9f20bfa6SDavid van Moolenbroek void ipv4_handleifa(struct dhcpcd_ctx *, int, struct if_head *, const char *,
127*9f20bfa6SDavid van Moolenbroek     const struct in_addr *, const struct in_addr *, const struct in_addr *,
128*9f20bfa6SDavid van Moolenbroek     int);
129*9f20bfa6SDavid van Moolenbroek 
130*9f20bfa6SDavid van Moolenbroek void ipv4_freeroutes(struct rt_head *);
131*9f20bfa6SDavid van Moolenbroek 
132*9f20bfa6SDavid van Moolenbroek void ipv4_free(struct interface *);
133*9f20bfa6SDavid van Moolenbroek void ipv4_ctxfree(struct dhcpcd_ctx *);
134*9f20bfa6SDavid van Moolenbroek #else
135*9f20bfa6SDavid van Moolenbroek #define ipv4_init(a) (-1)
136*9f20bfa6SDavid van Moolenbroek #define ipv4_sortinterfaces(a) {}
137*9f20bfa6SDavid van Moolenbroek #define ipv4_applyaddr(a) {}
138*9f20bfa6SDavid van Moolenbroek #define ipv4_freeroutes(a) {}
139*9f20bfa6SDavid van Moolenbroek #define ipv4_free(a) {}
140*9f20bfa6SDavid van Moolenbroek #define ipv4_ctxfree(a) {}
141*9f20bfa6SDavid van Moolenbroek #define ipv4_hasaddr(a) (0)
142*9f20bfa6SDavid van Moolenbroek #define ipv4_preferanother(a) (0)
143*9f20bfa6SDavid van Moolenbroek #endif
144*9f20bfa6SDavid van Moolenbroek 
145*9f20bfa6SDavid van Moolenbroek #endif
146