| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef _LINUX_ICMPV6_H | 
 | 2 | #define _LINUX_ICMPV6_H | 
 | 3 |  | 
 | 4 | #include <asm/byteorder.h> | 
 | 5 |  | 
 | 6 | struct icmp6hdr { | 
 | 7 |  | 
 | 8 | 	__u8		icmp6_type; | 
 | 9 | 	__u8		icmp6_code; | 
| Al Viro | 9981a0e | 2006-11-14 21:24:30 -0800 | [diff] [blame] | 10 | 	__sum16		icmp6_cksum; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 |  | 
 | 12 |  | 
 | 13 | 	union { | 
| Al Viro | a27ee7a | 2006-11-08 00:21:21 -0800 | [diff] [blame] | 14 | 		__be32			un_data32[1]; | 
 | 15 | 		__be16			un_data16[2]; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 16 | 		__u8			un_data8[4]; | 
 | 17 |  | 
 | 18 | 		struct icmpv6_echo { | 
| Al Viro | a27ee7a | 2006-11-08 00:21:21 -0800 | [diff] [blame] | 19 | 			__be16		identifier; | 
 | 20 | 			__be16		sequence; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 21 | 		} u_echo; | 
 | 22 |  | 
 | 23 |                 struct icmpv6_nd_advt { | 
 | 24 | #if defined(__LITTLE_ENDIAN_BITFIELD) | 
 | 25 |                         __u32		reserved:5, | 
 | 26 |                         		override:1, | 
 | 27 |                         		solicited:1, | 
 | 28 |                         		router:1, | 
 | 29 | 					reserved2:24; | 
 | 30 | #elif defined(__BIG_ENDIAN_BITFIELD) | 
 | 31 |                         __u32		router:1, | 
 | 32 | 					solicited:1, | 
 | 33 |                         		override:1, | 
 | 34 |                         		reserved:29; | 
 | 35 | #else | 
 | 36 | #error	"Please fix <asm/byteorder.h>" | 
 | 37 | #endif						 | 
 | 38 |                 } u_nd_advt; | 
 | 39 |  | 
 | 40 |                 struct icmpv6_nd_ra { | 
 | 41 | 			__u8		hop_limit; | 
 | 42 | #if defined(__LITTLE_ENDIAN_BITFIELD) | 
| YOSHIFUJI Hideaki | ebacaaa | 2006-03-20 17:04:53 -0800 | [diff] [blame] | 43 | 			__u8		reserved:4, | 
 | 44 | 					router_pref:2, | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 45 | 					other:1, | 
 | 46 | 					managed:1; | 
 | 47 |  | 
 | 48 | #elif defined(__BIG_ENDIAN_BITFIELD) | 
 | 49 | 			__u8		managed:1, | 
 | 50 | 					other:1, | 
| YOSHIFUJI Hideaki | ebacaaa | 2006-03-20 17:04:53 -0800 | [diff] [blame] | 51 | 					router_pref:2, | 
 | 52 | 					reserved:4; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 53 | #else | 
 | 54 | #error	"Please fix <asm/byteorder.h>" | 
 | 55 | #endif | 
| Al Viro | a27ee7a | 2006-11-08 00:21:21 -0800 | [diff] [blame] | 56 | 			__be16		rt_lifetime; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 57 |                 } u_nd_ra; | 
 | 58 |  | 
 | 59 | 	} icmp6_dataun; | 
 | 60 |  | 
 | 61 | #define icmp6_identifier	icmp6_dataun.u_echo.identifier | 
 | 62 | #define icmp6_sequence		icmp6_dataun.u_echo.sequence | 
 | 63 | #define icmp6_pointer		icmp6_dataun.un_data32[0] | 
 | 64 | #define icmp6_mtu		icmp6_dataun.un_data32[0] | 
 | 65 | #define icmp6_unused		icmp6_dataun.un_data32[0] | 
 | 66 | #define icmp6_maxdelay		icmp6_dataun.un_data16[0] | 
 | 67 | #define icmp6_router		icmp6_dataun.u_nd_advt.router | 
 | 68 | #define icmp6_solicited		icmp6_dataun.u_nd_advt.solicited | 
 | 69 | #define icmp6_override		icmp6_dataun.u_nd_advt.override | 
 | 70 | #define icmp6_ndiscreserved	icmp6_dataun.u_nd_advt.reserved | 
 | 71 | #define icmp6_hop_limit		icmp6_dataun.u_nd_ra.hop_limit | 
 | 72 | #define icmp6_addrconf_managed	icmp6_dataun.u_nd_ra.managed | 
 | 73 | #define icmp6_addrconf_other	icmp6_dataun.u_nd_ra.other | 
 | 74 | #define icmp6_rt_lifetime	icmp6_dataun.u_nd_ra.rt_lifetime | 
| YOSHIFUJI Hideaki | ebacaaa | 2006-03-20 17:04:53 -0800 | [diff] [blame] | 75 | #define icmp6_router_pref	icmp6_dataun.u_nd_ra.router_pref | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 76 | }; | 
 | 77 |  | 
| Arnaldo Carvalho de Melo | cc70ab2 | 2007-03-13 14:03:22 -0300 | [diff] [blame] | 78 | #ifdef __KERNEL__ | 
 | 79 | #include <linux/skbuff.h> | 
 | 80 |  | 
 | 81 | static inline struct icmp6hdr *icmp6_hdr(const struct sk_buff *skb) | 
 | 82 | { | 
| Arnaldo Carvalho de Melo | 9c70220 | 2007-04-25 18:04:18 -0700 | [diff] [blame] | 83 | 	return (struct icmp6hdr *)skb_transport_header(skb); | 
| Arnaldo Carvalho de Melo | cc70ab2 | 2007-03-13 14:03:22 -0300 | [diff] [blame] | 84 | } | 
 | 85 | #endif | 
 | 86 |  | 
| YOSHIFUJI Hideaki | ebacaaa | 2006-03-20 17:04:53 -0800 | [diff] [blame] | 87 | #define ICMPV6_ROUTER_PREF_LOW		0x3 | 
 | 88 | #define ICMPV6_ROUTER_PREF_MEDIUM	0x0 | 
 | 89 | #define ICMPV6_ROUTER_PREF_HIGH		0x1 | 
 | 90 | #define ICMPV6_ROUTER_PREF_INVALID	0x2 | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 91 |  | 
 | 92 | #define ICMPV6_DEST_UNREACH		1 | 
 | 93 | #define ICMPV6_PKT_TOOBIG		2 | 
 | 94 | #define ICMPV6_TIME_EXCEED		3 | 
 | 95 | #define ICMPV6_PARAMPROB		4 | 
 | 96 |  | 
 | 97 | #define ICMPV6_INFOMSG_MASK		0x80 | 
 | 98 |  | 
 | 99 | #define ICMPV6_ECHO_REQUEST		128 | 
 | 100 | #define ICMPV6_ECHO_REPLY		129 | 
 | 101 | #define ICMPV6_MGM_QUERY		130 | 
 | 102 | #define ICMPV6_MGM_REPORT       	131 | 
 | 103 | #define ICMPV6_MGM_REDUCTION    	132 | 
 | 104 |  | 
 | 105 | #define ICMPV6_NI_QUERY			139 | 
 | 106 | #define ICMPV6_NI_REPLY			140 | 
 | 107 |  | 
 | 108 | #define ICMPV6_MLD2_REPORT		143 | 
 | 109 |  | 
 | 110 | #define ICMPV6_DHAAD_REQUEST		144 | 
 | 111 | #define ICMPV6_DHAAD_REPLY		145 | 
 | 112 | #define ICMPV6_MOBILE_PREFIX_SOL	146 | 
 | 113 | #define ICMPV6_MOBILE_PREFIX_ADV	147 | 
 | 114 |  | 
 | 115 | /* | 
 | 116 |  *	Codes for Destination Unreachable | 
 | 117 |  */ | 
 | 118 | #define ICMPV6_NOROUTE			0 | 
 | 119 | #define ICMPV6_ADM_PROHIBITED		1 | 
 | 120 | #define ICMPV6_NOT_NEIGHBOUR		2 | 
 | 121 | #define ICMPV6_ADDR_UNREACH		3 | 
 | 122 | #define ICMPV6_PORT_UNREACH		4 | 
 | 123 |  | 
 | 124 | /* | 
 | 125 |  *	Codes for Time Exceeded | 
 | 126 |  */ | 
 | 127 | #define ICMPV6_EXC_HOPLIMIT		0 | 
 | 128 | #define ICMPV6_EXC_FRAGTIME		1 | 
 | 129 |  | 
 | 130 | /* | 
 | 131 |  *	Codes for Parameter Problem | 
 | 132 |  */ | 
 | 133 | #define ICMPV6_HDR_FIELD		0 | 
 | 134 | #define ICMPV6_UNK_NEXTHDR		1 | 
 | 135 | #define ICMPV6_UNK_OPTION		2 | 
 | 136 |  | 
 | 137 | /* | 
 | 138 |  *	constants for (set|get)sockopt | 
 | 139 |  */ | 
 | 140 |  | 
 | 141 | #define ICMPV6_FILTER			1 | 
 | 142 |  | 
 | 143 | /* | 
 | 144 |  *	ICMPV6 filter | 
 | 145 |  */ | 
 | 146 |  | 
 | 147 | #define ICMPV6_FILTER_BLOCK		1 | 
 | 148 | #define ICMPV6_FILTER_PASS		2 | 
 | 149 | #define ICMPV6_FILTER_BLOCKOTHERS	3 | 
 | 150 | #define ICMPV6_FILTER_PASSONLY		4 | 
 | 151 |  | 
 | 152 | struct icmp6_filter { | 
 | 153 | 	__u32		data[8]; | 
 | 154 | }; | 
 | 155 |  | 
 | 156 | /* | 
 | 157 |  *	Definitions for MLDv2 | 
 | 158 |  */ | 
 | 159 | #define MLD2_MODE_IS_INCLUDE	1 | 
 | 160 | #define MLD2_MODE_IS_EXCLUDE	2 | 
 | 161 | #define MLD2_CHANGE_TO_INCLUDE	3 | 
 | 162 | #define MLD2_CHANGE_TO_EXCLUDE	4 | 
 | 163 | #define MLD2_ALLOW_NEW_SOURCES	5 | 
 | 164 | #define MLD2_BLOCK_OLD_SOURCES	6 | 
 | 165 |  | 
 | 166 | #define MLD2_ALL_MCR_INIT { { { 0xff,0x02,0,0,0,0,0,0,0,0,0,0,0,0,0,0x16 } } } | 
 | 167 |  | 
 | 168 | #ifdef __KERNEL__ | 
 | 169 |  | 
 | 170 | #include <linux/netdevice.h> | 
 | 171 | #include <linux/skbuff.h> | 
 | 172 |  | 
 | 173 |  | 
 | 174 | extern void				icmpv6_send(struct sk_buff *skb, | 
 | 175 | 						    int type, int code, | 
 | 176 | 						    __u32 info,  | 
 | 177 | 						    struct net_device *dev); | 
 | 178 |  | 
 | 179 | extern int				icmpv6_init(struct net_proto_family *ops); | 
 | 180 | extern int				icmpv6_err_convert(int type, int code, | 
 | 181 | 							   int *err); | 
 | 182 | extern void				icmpv6_cleanup(void); | 
 | 183 | extern void				icmpv6_param_prob(struct sk_buff *skb, | 
 | 184 | 							  int code, int pos); | 
 | 185 | #endif | 
 | 186 |  | 
 | 187 | #endif |