[INET]: Move bind_hash from tcp_sk to inet_sk
[linux-2.6.git] / include / linux / ip.h
1 /*
2  * INET         An implementation of the TCP/IP protocol suite for the LINUX
3  *              operating system.  INET is implemented using the  BSD Socket
4  *              interface as the means of communication with the user level.
5  *
6  *              Definitions for the IP protocol.
7  *
8  * Version:     @(#)ip.h        1.0.2   04/28/93
9  *
10  * Authors:     Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
11  *
12  *              This program is free software; you can redistribute it and/or
13  *              modify it under the terms of the GNU General Public License
14  *              as published by the Free Software Foundation; either version
15  *              2 of the License, or (at your option) any later version.
16  */
17 #ifndef _LINUX_IP_H
18 #define _LINUX_IP_H
19 #include <asm/byteorder.h>
20
21 #define IPTOS_TOS_MASK          0x1E
22 #define IPTOS_TOS(tos)          ((tos)&IPTOS_TOS_MASK)
23 #define IPTOS_LOWDELAY          0x10
24 #define IPTOS_THROUGHPUT        0x08
25 #define IPTOS_RELIABILITY       0x04
26 #define IPTOS_MINCOST           0x02
27
28 #define IPTOS_PREC_MASK         0xE0
29 #define IPTOS_PREC(tos)         ((tos)&IPTOS_PREC_MASK)
30 #define IPTOS_PREC_NETCONTROL           0xe0
31 #define IPTOS_PREC_INTERNETCONTROL      0xc0
32 #define IPTOS_PREC_CRITIC_ECP           0xa0
33 #define IPTOS_PREC_FLASHOVERRIDE        0x80
34 #define IPTOS_PREC_FLASH                0x60
35 #define IPTOS_PREC_IMMEDIATE            0x40
36 #define IPTOS_PREC_PRIORITY             0x20
37 #define IPTOS_PREC_ROUTINE              0x00
38
39
40 /* IP options */
41 #define IPOPT_COPY              0x80
42 #define IPOPT_CLASS_MASK        0x60
43 #define IPOPT_NUMBER_MASK       0x1f
44
45 #define IPOPT_COPIED(o)         ((o)&IPOPT_COPY)
46 #define IPOPT_CLASS(o)          ((o)&IPOPT_CLASS_MASK)
47 #define IPOPT_NUMBER(o)         ((o)&IPOPT_NUMBER_MASK)
48
49 #define IPOPT_CONTROL           0x00
50 #define IPOPT_RESERVED1         0x20
51 #define IPOPT_MEASUREMENT       0x40
52 #define IPOPT_RESERVED2         0x60
53
54 #define IPOPT_END       (0 |IPOPT_CONTROL)
55 #define IPOPT_NOOP      (1 |IPOPT_CONTROL)
56 #define IPOPT_SEC       (2 |IPOPT_CONTROL|IPOPT_COPY)
57 #define IPOPT_LSRR      (3 |IPOPT_CONTROL|IPOPT_COPY)
58 #define IPOPT_TIMESTAMP (4 |IPOPT_MEASUREMENT)
59 #define IPOPT_RR        (7 |IPOPT_CONTROL)
60 #define IPOPT_SID       (8 |IPOPT_CONTROL|IPOPT_COPY)
61 #define IPOPT_SSRR      (9 |IPOPT_CONTROL|IPOPT_COPY)
62 #define IPOPT_RA        (20|IPOPT_CONTROL|IPOPT_COPY)
63
64 #define IPVERSION       4
65 #define MAXTTL          255
66 #define IPDEFTTL        64
67
68 #define IPOPT_OPTVAL 0
69 #define IPOPT_OLEN   1
70 #define IPOPT_OFFSET 2
71 #define IPOPT_MINOFF 4
72 #define MAX_IPOPTLEN 40
73 #define IPOPT_NOP IPOPT_NOOP
74 #define IPOPT_EOL IPOPT_END
75 #define IPOPT_TS  IPOPT_TIMESTAMP
76
77 #define IPOPT_TS_TSONLY         0               /* timestamps only */
78 #define IPOPT_TS_TSANDADDR      1               /* timestamps and addresses */
79 #define IPOPT_TS_PRESPEC        3               /* specified modules only */
80
81 #ifdef __KERNEL__
82 #include <linux/config.h>
83 #include <linux/types.h>
84 #include <net/request_sock.h>
85 #include <net/sock.h>
86 #include <linux/igmp.h>
87 #include <net/flow.h>
88
89 struct ip_options {
90   __u32         faddr;                          /* Saved first hop address */
91   unsigned char optlen;
92   unsigned char srr;
93   unsigned char rr;
94   unsigned char ts;
95   unsigned char is_setbyuser:1,                 /* Set by setsockopt?                   */
96                 is_data:1,                      /* Options in __data, rather than skb   */
97                 is_strictroute:1,               /* Strict source route                  */
98                 srr_is_hit:1,                   /* Packet destination addr was our one  */
99                 is_changed:1,                   /* IP checksum more not valid           */      
100                 rr_needaddr:1,                  /* Need to record addr of outgoing dev  */
101                 ts_needtime:1,                  /* Need to record timestamp             */
102                 ts_needaddr:1;                  /* Need to record addr of outgoing dev  */
103   unsigned char router_alert;
104   unsigned char __pad1;
105   unsigned char __pad2;
106   unsigned char __data[0];
107 };
108
109 #define optlength(opt) (sizeof(struct ip_options) + opt->optlen)
110
111 struct inet_request_sock {
112         struct request_sock     req;
113         u32                     loc_addr;
114         u32                     rmt_addr;
115         u16                     rmt_port;
116         u16                     snd_wscale : 4, 
117                                 rcv_wscale : 4, 
118                                 tstamp_ok  : 1,
119                                 sack_ok    : 1,
120                                 wscale_ok  : 1,
121                                 ecn_ok     : 1,
122                                 acked      : 1;
123         struct ip_options       *opt;
124 };
125
126 static inline struct inet_request_sock *inet_rsk(const struct request_sock *sk)
127 {
128         return (struct inet_request_sock *)sk;
129 }
130
131 struct inet_bind_bucket;
132 struct ipv6_pinfo;
133
134 struct inet_sock {
135         /* sk and pinet6 has to be the first two members of inet_sock */
136         struct sock             sk;
137 #if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
138         struct ipv6_pinfo       *pinet6;
139 #endif
140         /* Socket demultiplex comparisons on incoming packets. */
141         __u32                   daddr;          /* Foreign IPv4 addr */
142         __u32                   rcv_saddr;      /* Bound local IPv4 addr */
143         __u16                   dport;          /* Destination port */
144         __u16                   num;            /* Local port */
145         __u32                   saddr;          /* Sending source */
146         __s16                   uc_ttl;         /* Unicast TTL */
147         __u16                   cmsg_flags;
148         struct ip_options       *opt;
149         __u16                   sport;          /* Source port */
150         __u16                   id;             /* ID counter for DF pkts */
151         __u8                    tos;            /* TOS */
152         __u8                    mc_ttl;         /* Multicasting TTL */
153         __u8                    pmtudisc;
154         unsigned                recverr : 1,
155                                 freebind : 1,
156                                 hdrincl : 1,
157                                 mc_loop : 1;
158         int                     mc_index;       /* Multicast device index */
159         __u32                   mc_addr;
160         struct ip_mc_socklist   *mc_list;       /* Group array */
161         struct inet_bind_bucket *bind_hash;
162         /*
163          * Following members are used to retain the infomation to build
164          * an ip header on each ip fragmentation while the socket is corked.
165          */
166         struct {
167                 unsigned int            flags;
168                 unsigned int            fragsize;
169                 struct ip_options       *opt;
170                 struct rtable           *rt;
171                 int                     length; /* Total length of all frames */
172                 u32                     addr;
173                 struct flowi            fl;
174         } cork;
175 };
176
177 #define IPCORK_OPT      1       /* ip-options has been held in ipcork.opt */
178 #define IPCORK_ALLFRAG  2       /* always fragment (for ipv6 for now) */
179
180 static inline struct inet_sock *inet_sk(const struct sock *sk)
181 {
182         return (struct inet_sock *)sk;
183 }
184
185 static inline void __inet_sk_copy_descendant(struct sock *sk_to,
186                                              const struct sock *sk_from,
187                                              const int ancestor_size)
188 {
189         memcpy(inet_sk(sk_to) + 1, inet_sk(sk_from) + 1,
190                sk_from->sk_prot->obj_size - ancestor_size);
191 }
192 #if !(defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE))
193 static inline void inet_sk_copy_descendant(struct sock *sk_to,
194                                            const struct sock *sk_from)
195 {
196         __inet_sk_copy_descendant(sk_to, sk_from, sizeof(struct inet_sock));
197 }
198 #endif
199 #endif
200
201 extern int inet_sk_rebuild_header(struct sock *sk);
202
203 struct iphdr {
204 #if defined(__LITTLE_ENDIAN_BITFIELD)
205         __u8    ihl:4,
206                 version:4;
207 #elif defined (__BIG_ENDIAN_BITFIELD)
208         __u8    version:4,
209                 ihl:4;
210 #else
211 #error  "Please fix <asm/byteorder.h>"
212 #endif
213         __u8    tos;
214         __u16   tot_len;
215         __u16   id;
216         __u16   frag_off;
217         __u8    ttl;
218         __u8    protocol;
219         __u16   check;
220         __u32   saddr;
221         __u32   daddr;
222         /*The options start here. */
223 };
224
225 struct ip_auth_hdr {
226         __u8  nexthdr;
227         __u8  hdrlen;           /* This one is measured in 32 bit units! */
228         __u16 reserved;
229         __u32 spi;
230         __u32 seq_no;           /* Sequence number */
231         __u8  auth_data[0];     /* Variable len but >=4. Mind the 64 bit alignment! */
232 };
233
234 struct ip_esp_hdr {
235         __u32 spi;
236         __u32 seq_no;           /* Sequence number */
237         __u8  enc_data[0];      /* Variable len but >=8. Mind the 64 bit alignment! */
238 };
239
240 struct ip_comp_hdr {
241         __u8 nexthdr;
242         __u8 flags;
243         __u16 cpi;
244 };
245
246 #endif  /* _LINUX_IP_H */