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