1df6ad731Slogwang /* $FreeBSD$ */ 2df6ad731Slogwang /* $OpenBSD: ip_carp.h,v 1.8 2004/07/29 22:12:15 mcbride Exp $ */ 3df6ad731Slogwang 4*d4a07e70Sfengbojiang /*- 5*d4a07e70Sfengbojiang * SPDX-License-Identifier: BSD-2-Clause 6*d4a07e70Sfengbojiang * 7df6ad731Slogwang * Copyright (c) 2002 Michael Shalayeff. All rights reserved. 8df6ad731Slogwang * Copyright (c) 2003 Ryan McBride. All rights reserved. 9df6ad731Slogwang * 10df6ad731Slogwang * Redistribution and use in source and binary forms, with or without 11df6ad731Slogwang * modification, are permitted provided that the following conditions 12df6ad731Slogwang * are met: 13df6ad731Slogwang * 1. Redistributions of source code must retain the above copyright 14df6ad731Slogwang * notice, this list of conditions and the following disclaimer. 15df6ad731Slogwang * 2. Redistributions in binary form must reproduce the above copyright 16df6ad731Slogwang * notice, this list of conditions and the following disclaimer in the 17df6ad731Slogwang * documentation and/or other materials provided with the distribution. 18df6ad731Slogwang * 19df6ad731Slogwang * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 20df6ad731Slogwang * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 21df6ad731Slogwang * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 22df6ad731Slogwang * IN NO EVENT SHALL THE AUTHOR OR HIS RELATIVES BE LIABLE FOR ANY DIRECT, 23df6ad731Slogwang * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 24df6ad731Slogwang * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 25df6ad731Slogwang * SERVICES; LOSS OF MIND, USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26df6ad731Slogwang * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 27df6ad731Slogwang * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 28df6ad731Slogwang * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 29df6ad731Slogwang * THE POSSIBILITY OF SUCH DAMAGE. 30df6ad731Slogwang */ 31df6ad731Slogwang 32df6ad731Slogwang #ifndef _IP_CARP_H 33df6ad731Slogwang #define _IP_CARP_H 34df6ad731Slogwang 35df6ad731Slogwang /* 36df6ad731Slogwang * The CARP header layout is as follows: 37df6ad731Slogwang * 38df6ad731Slogwang * 0 1 2 3 39df6ad731Slogwang * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 40df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 41df6ad731Slogwang * |Version| Type | VirtualHostID | AdvSkew | Auth Len | 42df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 43df6ad731Slogwang * | Reserved | AdvBase | Checksum | 44df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 45df6ad731Slogwang * | Counter (1) | 46df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 47df6ad731Slogwang * | Counter (2) | 48df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 49df6ad731Slogwang * | SHA-1 HMAC (1) | 50df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 51df6ad731Slogwang * | SHA-1 HMAC (2) | 52df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 53df6ad731Slogwang * | SHA-1 HMAC (3) | 54df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 55df6ad731Slogwang * | SHA-1 HMAC (4) | 56df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 57df6ad731Slogwang * | SHA-1 HMAC (5) | 58df6ad731Slogwang * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 59df6ad731Slogwang * 60df6ad731Slogwang */ 61df6ad731Slogwang 62df6ad731Slogwang struct carp_header { 63df6ad731Slogwang #if BYTE_ORDER == LITTLE_ENDIAN 64df6ad731Slogwang u_int8_t carp_type:4, 65df6ad731Slogwang carp_version:4; 66df6ad731Slogwang #endif 67df6ad731Slogwang #if BYTE_ORDER == BIG_ENDIAN 68df6ad731Slogwang u_int8_t carp_version:4, 69df6ad731Slogwang carp_type:4; 70df6ad731Slogwang #endif 71df6ad731Slogwang u_int8_t carp_vhid; /* virtual host id */ 72df6ad731Slogwang u_int8_t carp_advskew; /* advertisement skew */ 73df6ad731Slogwang u_int8_t carp_authlen; /* size of counter+md, 32bit chunks */ 74df6ad731Slogwang u_int8_t carp_pad1; /* reserved */ 75df6ad731Slogwang u_int8_t carp_advbase; /* advertisement interval */ 76df6ad731Slogwang u_int16_t carp_cksum; 77df6ad731Slogwang u_int32_t carp_counter[2]; 78df6ad731Slogwang unsigned char carp_md[20]; /* SHA1 HMAC */ 791eaf0ac3Slogwang } __attribute__ ((packed)); 80df6ad731Slogwang 81df6ad731Slogwang #ifdef CTASSERT 82df6ad731Slogwang CTASSERT(sizeof(struct carp_header) == 36); 83df6ad731Slogwang #endif 84df6ad731Slogwang 85df6ad731Slogwang #define CARP_DFLTTL 255 86df6ad731Slogwang 87df6ad731Slogwang /* carp_version */ 88df6ad731Slogwang #define CARP_VERSION 2 89df6ad731Slogwang 90df6ad731Slogwang /* carp_type */ 91df6ad731Slogwang #define CARP_ADVERTISEMENT 0x01 92df6ad731Slogwang 93df6ad731Slogwang #define CARP_KEY_LEN 20 /* a sha1 hash of a passphrase */ 94df6ad731Slogwang 95df6ad731Slogwang /* carp_advbase */ 96df6ad731Slogwang #define CARP_DFLTINTV 1 97df6ad731Slogwang 98df6ad731Slogwang /* 99df6ad731Slogwang * Statistics. 100df6ad731Slogwang */ 101df6ad731Slogwang struct carpstats { 102df6ad731Slogwang uint64_t carps_ipackets; /* total input packets, IPv4 */ 103df6ad731Slogwang uint64_t carps_ipackets6; /* total input packets, IPv6 */ 104df6ad731Slogwang uint64_t carps_badif; /* wrong interface */ 105df6ad731Slogwang uint64_t carps_badttl; /* TTL is not CARP_DFLTTL */ 106df6ad731Slogwang uint64_t carps_hdrops; /* packets shorter than hdr */ 107df6ad731Slogwang uint64_t carps_badsum; /* bad checksum */ 108df6ad731Slogwang uint64_t carps_badver; /* bad (incl unsupp) version */ 109df6ad731Slogwang uint64_t carps_badlen; /* data length does not match */ 110df6ad731Slogwang uint64_t carps_badauth; /* bad authentication */ 111df6ad731Slogwang uint64_t carps_badvhid; /* bad VHID */ 112df6ad731Slogwang uint64_t carps_badaddrs; /* bad address list */ 113df6ad731Slogwang 114df6ad731Slogwang uint64_t carps_opackets; /* total output packets, IPv4 */ 115df6ad731Slogwang uint64_t carps_opackets6; /* total output packets, IPv6 */ 116df6ad731Slogwang uint64_t carps_onomem; /* no memory for an mbuf */ 117df6ad731Slogwang uint64_t carps_ostates; /* total state updates sent */ 118df6ad731Slogwang 119df6ad731Slogwang uint64_t carps_preempt; /* if enabled, preemptions */ 120df6ad731Slogwang }; 121df6ad731Slogwang 122df6ad731Slogwang /* 123df6ad731Slogwang * Configuration structure for SIOCSVH SIOCGVH 124df6ad731Slogwang */ 125df6ad731Slogwang struct carpreq { 126df6ad731Slogwang int carpr_count; 127df6ad731Slogwang int carpr_vhid; 128df6ad731Slogwang #define CARP_MAXVHID 255 129df6ad731Slogwang int carpr_state; 130df6ad731Slogwang #define CARP_STATES "INIT", "BACKUP", "MASTER" 131df6ad731Slogwang #define CARP_MAXSTATE 2 132df6ad731Slogwang int carpr_advskew; 133df6ad731Slogwang #define CARP_MAXSKEW 240 134df6ad731Slogwang int carpr_advbase; 135df6ad731Slogwang unsigned char carpr_key[CARP_KEY_LEN]; 136df6ad731Slogwang }; 137df6ad731Slogwang #define SIOCSVH _IOWR('i', 245, struct ifreq) 138df6ad731Slogwang #define SIOCGVH _IOWR('i', 246, struct ifreq) 139df6ad731Slogwang 140*d4a07e70Sfengbojiang #ifdef _KERNEL 141*d4a07e70Sfengbojiang int carp_ioctl(struct ifreq *, u_long, struct thread *); 142*d4a07e70Sfengbojiang int carp_attach(struct ifaddr *, int); 143*d4a07e70Sfengbojiang void carp_detach(struct ifaddr *, bool); 144*d4a07e70Sfengbojiang void carp_carpdev_state(struct ifnet *); 145*d4a07e70Sfengbojiang int carp_input(struct mbuf **, int *, int); 146*d4a07e70Sfengbojiang int carp6_input (struct mbuf **, int *, int); 147*d4a07e70Sfengbojiang int carp_output (struct ifnet *, struct mbuf *, 148*d4a07e70Sfengbojiang const struct sockaddr *); 149*d4a07e70Sfengbojiang int carp_master(struct ifaddr *); 150*d4a07e70Sfengbojiang int carp_iamatch(struct ifaddr *, uint8_t **); 151*d4a07e70Sfengbojiang struct ifaddr *carp_iamatch6(struct ifnet *, struct in6_addr *); 152*d4a07e70Sfengbojiang char * carp_macmatch6(struct ifnet *, struct mbuf *, const struct in6_addr *); 153*d4a07e70Sfengbojiang int carp_forus(struct ifnet *, u_char *); 154*d4a07e70Sfengbojiang 155*d4a07e70Sfengbojiang /* These are external networking stack hooks for CARP */ 156*d4a07e70Sfengbojiang /* net/if.c */ 157*d4a07e70Sfengbojiang extern int (*carp_ioctl_p)(struct ifreq *, u_long, struct thread *); 158*d4a07e70Sfengbojiang extern int (*carp_attach_p)(struct ifaddr *, int); 159*d4a07e70Sfengbojiang extern void (*carp_detach_p)(struct ifaddr *, bool); 160*d4a07e70Sfengbojiang extern void (*carp_linkstate_p)(struct ifnet *); 161*d4a07e70Sfengbojiang extern void (*carp_demote_adj_p)(int, char *); 162*d4a07e70Sfengbojiang extern int (*carp_master_p)(struct ifaddr *); 163*d4a07e70Sfengbojiang /* net/if_bridge.c net/if_ethersubr.c */ 164*d4a07e70Sfengbojiang extern int (*carp_forus_p)(struct ifnet *, u_char *); 165*d4a07e70Sfengbojiang /* net/if_ethersubr.c */ 166*d4a07e70Sfengbojiang extern int (*carp_output_p)(struct ifnet *, struct mbuf *, 167*d4a07e70Sfengbojiang const struct sockaddr *); 168*d4a07e70Sfengbojiang /* net/rtsock.c */ 169*d4a07e70Sfengbojiang extern int (*carp_get_vhid_p)(struct ifaddr *); 170*d4a07e70Sfengbojiang #ifdef INET 171*d4a07e70Sfengbojiang /* netinet/if_ether.c */ 172*d4a07e70Sfengbojiang extern int (*carp_iamatch_p)(struct ifaddr *, uint8_t **); 173*d4a07e70Sfengbojiang #endif 174*d4a07e70Sfengbojiang #ifdef INET6 175*d4a07e70Sfengbojiang /* netinet6/nd6_nbr.c */ 176*d4a07e70Sfengbojiang extern struct ifaddr *(*carp_iamatch6_p)(struct ifnet *, struct in6_addr *); 177*d4a07e70Sfengbojiang extern char * (*carp_macmatch6_p)(struct ifnet *, struct mbuf *, 178*d4a07e70Sfengbojiang const struct in6_addr *); 179*d4a07e70Sfengbojiang #endif 180*d4a07e70Sfengbojiang #endif 181df6ad731Slogwang #endif /* _IP_CARP_H */ 182