OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-3.0/] [packages/] [net/] [bsd_tcpip/] [current/] [include/] [netinet6/] [nd6.h] - Blame information for rev 786

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 786 skrzyp
//==========================================================================
2
//
3
//      include/netinet6/nd6.h
4
//
5
//==========================================================================
6
// ####BSDCOPYRIGHTBEGIN####                                    
7
// -------------------------------------------                  
8
// This file is part of eCos, the Embedded Configurable Operating System.
9
//
10
// Portions of this software may have been derived from FreeBSD 
11
// or other sources, and if so are covered by the appropriate copyright
12
// and license included herein.                                 
13
//
14
// Portions created by the Free Software Foundation are         
15
// Copyright (C) 2002 Free Software Foundation, Inc.            
16
// -------------------------------------------                  
17
// ####BSDCOPYRIGHTEND####                                      
18
//==========================================================================
19
 
20
/*      $KAME: nd6.h,v 1.76 2001/12/18 02:10:31 itojun Exp $    */
21
 
22
/*
23
 * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
24
 * All rights reserved.
25
 *
26
 * Redistribution and use in source and binary forms, with or without
27
 * modification, are permitted provided that the following conditions
28
 * are met:
29
 * 1. Redistributions of source code must retain the above copyright
30
 *    notice, this list of conditions and the following disclaimer.
31
 * 2. Redistributions in binary form must reproduce the above copyright
32
 *    notice, this list of conditions and the following disclaimer in the
33
 *    documentation and/or other materials provided with the distribution.
34
 * 3. Neither the name of the project nor the names of its contributors
35
 *    may be used to endorse or promote products derived from this software
36
 *    without specific prior written permission.
37
 *
38
 * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
39
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
40
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
41
 * ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
42
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
43
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
44
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
45
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
46
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
47
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
48
 * SUCH DAMAGE.
49
 */
50
 
51
#ifndef _NETINET6_ND6_H_
52
#define _NETINET6_ND6_H_
53
 
54
/* see net/route.h, or net/if_inarp.h */
55
#ifndef RTF_ANNOUNCE
56
#define RTF_ANNOUNCE    RTF_PROTO2
57
#endif
58
 
59
#include <sys/queue.h>
60
 
61
struct  llinfo_nd6 {
62
        struct  llinfo_nd6 *ln_next;
63
        struct  llinfo_nd6 *ln_prev;
64
        struct  rtentry *ln_rt;
65
        struct  mbuf *ln_hold;  /* last packet until resolved/timeout */
66
        long    ln_asked;       /* number of queries already sent for this addr */
67
        u_long  ln_expire;      /* lifetime for NDP state transition */
68
        short   ln_state;       /* reachability state */
69
        short   ln_router;      /* 2^0: ND6 router bit */
70
        int     ln_byhint;      /* # of times we made it reachable by UL hint */
71
};
72
 
73
#define ND6_LLINFO_NOSTATE      -2
74
/*
75
 * We don't need the WAITDELETE state any more, but we keep the definition
76
 * in a comment line instead of removing it. This is necessary to avoid
77
 * unintentionally reusing the value for another purpose, which might
78
 * affect backward compatibility with old applications.
79
 * (20000711 jinmei@kame.net)
80
 */
81
/* #define ND6_LLINFO_WAITDELETE        -1 */
82
#define ND6_LLINFO_INCOMPLETE   0
83
#define ND6_LLINFO_REACHABLE    1
84
#define ND6_LLINFO_STALE        2
85
#define ND6_LLINFO_DELAY        3
86
#define ND6_LLINFO_PROBE        4
87
 
88
#define ND6_IS_LLINFO_PROBREACH(n) ((n)->ln_state > ND6_LLINFO_INCOMPLETE)
89
 
90
struct nd_ifinfo {
91
        u_int32_t linkmtu;              /* LinkMTU */
92
        u_int32_t maxmtu;               /* Upper bound of LinkMTU */
93
        u_int32_t basereachable;        /* BaseReachableTime */
94
        u_int32_t reachable;            /* Reachable Time */
95
        u_int32_t retrans;              /* Retrans Timer */
96
        u_int32_t flags;                /* Flags */
97
        int recalctm;                   /* BaseReacable re-calculation timer */
98
        u_int8_t chlim;                 /* CurHopLimit */
99
        u_int8_t receivedra;
100
        /* the following 3 members are for privacy extension for addrconf */
101
        u_int8_t randomseed0[8]; /* upper 64 bits of MD5 digest */
102
        u_int8_t randomseed1[8]; /* lower 64 bits (usually the EUI64 IFID) */
103
        u_int8_t randomid[8];   /* current random ID */
104
};
105
 
106
#define ND6_IFF_PERFORMNUD      0x1
107
#define ND6_IFF_ACCEPT_RTADV    0x2
108
#define ND6_IFF_PREFER_SOURCE   0x4 /* XXX: not related to ND. */
109
 
110
struct in6_nbrinfo {
111
        char ifname[IFNAMSIZ];  /* if name, e.g. "en0" */
112
        struct in6_addr addr;   /* IPv6 address of the neighbor */
113
        long    asked;          /* number of queries already sent for this addr */
114
        int     isrouter;       /* if it acts as a router */
115
        int     state;          /* reachability state */
116
        int     expire;         /* lifetime for NDP state transition */
117
};
118
 
119
#define DRLSTSIZ 10
120
#define PRLSTSIZ 10
121
struct  in6_drlist {
122
        char ifname[IFNAMSIZ];
123
        struct {
124
                struct  in6_addr rtaddr;
125
                u_char  flags;
126
                u_short rtlifetime;
127
                u_long  expire;
128
                u_short if_index;
129
        } defrouter[DRLSTSIZ];
130
};
131
 
132
struct  in6_defrouter {
133
        struct  sockaddr_in6 rtaddr;
134
        u_char  flags;
135
        u_short rtlifetime;
136
        u_long  expire;
137
        u_short if_index;
138
};
139
 
140
#ifdef _KERNEL
141
struct  in6_oprlist {
142
        char ifname[IFNAMSIZ];
143
        struct {
144
                struct  in6_addr prefix;
145
                struct prf_ra raflags;
146
                u_char  prefixlen;
147
                u_char  origin;
148
                u_long vltime;
149
                u_long pltime;
150
                u_long expire;
151
                u_short if_index;
152
                u_short advrtrs; /* number of advertisement routers */
153
                struct  in6_addr advrtr[DRLSTSIZ]; /* XXX: explicit limit */
154
        } prefix[PRLSTSIZ];
155
};
156
#endif
157
 
158
struct  in6_prlist {
159
        char ifname[IFNAMSIZ];
160
        struct {
161
                struct  in6_addr prefix;
162
                struct prf_ra raflags;
163
                u_char  prefixlen;
164
                u_char  origin;
165
                u_int32_t vltime;
166
                u_int32_t pltime;
167
                time_t expire;
168
                u_short if_index;
169
                u_short advrtrs; /* number of advertisement routers */
170
                struct  in6_addr advrtr[DRLSTSIZ]; /* XXX: explicit limit */
171
        } prefix[PRLSTSIZ];
172
};
173
 
174
struct in6_prefix {
175
        struct  sockaddr_in6 prefix;
176
        struct prf_ra raflags;
177
        u_char  prefixlen;
178
        u_char  origin;
179
        u_int32_t vltime;
180
        u_int32_t pltime;
181
        time_t expire;
182
        u_int32_t flags;
183
        int refcnt;
184
        u_short if_index;
185
        u_short advrtrs; /* number of advertisement routers */
186
        /* struct sockaddr_in6 advrtr[] */
187
};
188
 
189
#ifdef _KERNEL
190
struct  in6_ondireq {
191
        char ifname[IFNAMSIZ];
192
        struct {
193
                u_int32_t linkmtu;      /* LinkMTU */
194
                u_int32_t maxmtu;       /* Upper bound of LinkMTU */
195
                u_int32_t basereachable; /* BaseReachableTime */
196
                u_int32_t reachable;    /* Reachable Time */
197
                u_int32_t retrans;      /* Retrans Timer */
198
                u_int32_t flags;        /* Flags */
199
                int recalctm;           /* BaseReacable re-calculation timer */
200
                u_int8_t chlim;         /* CurHopLimit */
201
                u_int8_t receivedra;
202
        } ndi;
203
};
204
#endif
205
 
206
struct  in6_ndireq {
207
        char ifname[IFNAMSIZ];
208
        struct nd_ifinfo ndi;
209
};
210
 
211
struct  in6_ndifreq {
212
        char ifname[IFNAMSIZ];
213
        u_long ifindex;
214
};
215
 
216
/* Prefix status */
217
#define NDPRF_ONLINK            0x1
218
#define NDPRF_DETACHED          0x2
219
#define NDPRF_HOME              0x4
220
 
221
/* protocol constants */
222
#define MAX_RTR_SOLICITATION_DELAY      1       /* 1sec */
223
#define RTR_SOLICITATION_INTERVAL       4       /* 4sec */
224
#define MAX_RTR_SOLICITATIONS           3
225
 
226
#define ND6_INFINITE_LIFETIME           0xffffffff
227
 
228
#ifdef _KERNEL
229
/* node constants */
230
#define MAX_REACHABLE_TIME              3600000 /* msec */
231
#define REACHABLE_TIME                  30000   /* msec */
232
#define RETRANS_TIMER                   1000    /* msec */
233
#define MIN_RANDOM_FACTOR               512     /* 1024 * 0.5 */
234
#define MAX_RANDOM_FACTOR               1536    /* 1024 * 1.5 */
235
#define DEF_TEMP_VALID_LIFETIME         604800  /* 1 week */
236
#define DEF_TEMP_PREFERRED_LIFETIME     86400   /* 1 day */
237
#define TEMPADDR_REGEN_ADVANCE          5       /* sec */
238
#define MAX_TEMP_DESYNC_FACTOR          600     /* 10 min */
239
#define ND_COMPUTE_RTIME(x) \
240
                (((MIN_RANDOM_FACTOR * (x >> 10)) + (random() & \
241
                ((MAX_RANDOM_FACTOR - MIN_RANDOM_FACTOR) * (x >> 10)))) /1000)
242
 
243
TAILQ_HEAD(nd_drhead, nd_defrouter);
244
struct  nd_defrouter {
245
        TAILQ_ENTRY(nd_defrouter) dr_entry;
246
        struct  in6_addr rtaddr;
247
        u_char  flags;          /* flags on RA message */
248
        u_short rtlifetime;
249
        u_long  expire;
250
        u_long  advint;         /* Mobile IPv6 addition (milliseconds) */
251
        u_long  advint_expire;  /* Mobile IPv6 addition */
252
        int     advints_lost;   /* Mobile IPv6 addition */
253
        struct  ifnet *ifp;
254
        int     installed;      /* is installed into kernel routing table */
255
};
256
 
257
struct nd_prefix {
258
        struct ifnet *ndpr_ifp;
259
        LIST_ENTRY(nd_prefix) ndpr_entry;
260
        struct sockaddr_in6 ndpr_prefix;        /* prefix */
261
        struct in6_addr ndpr_mask; /* netmask derived from the prefix */
262
 
263
        u_int32_t ndpr_vltime;  /* advertised valid lifetime */
264
        u_int32_t ndpr_pltime;  /* advertised preferred lifetime */
265
 
266
        time_t ndpr_expire;     /* expiration time of the prefix */
267
        time_t ndpr_preferred;  /* preferred time of the prefix */
268
        time_t ndpr_lastupdate; /* reception time of last advertisement */
269
 
270
        struct prf_ra ndpr_flags;
271
        u_int32_t ndpr_stateflags; /* actual state flags */
272
        /* list of routers that advertise the prefix: */
273
        LIST_HEAD(pr_rtrhead, nd_pfxrouter) ndpr_advrtrs;
274
        u_char  ndpr_plen;
275
        int     ndpr_refcnt;    /* reference couter from addresses */
276
};
277
 
278
#define ndpr_next               ndpr_entry.le_next
279
 
280
#define ndpr_raf                ndpr_flags
281
#define ndpr_raf_onlink         ndpr_flags.onlink
282
#define ndpr_raf_auto           ndpr_flags.autonomous
283
#define ndpr_raf_router         ndpr_flags.router
284
 
285
/*
286
 * Message format for use in obtaining information about prefixes
287
 * from inet6 sysctl function
288
 */
289
struct inet6_ndpr_msghdr {
290
        u_short inpm_msglen;    /* to skip over non-understood messages */
291
        u_char  inpm_version;   /* future binary compatibility */
292
        u_char  inpm_type;      /* message type */
293
        struct in6_addr inpm_prefix;
294
        u_long  prm_vltim;
295
        u_long  prm_pltime;
296
        u_long  prm_expire;
297
        u_long  prm_preferred;
298
        struct in6_prflags prm_flags;
299
        u_short prm_index;      /* index for associated ifp */
300
        u_char  prm_plen;       /* length of prefix in bits */
301
};
302
 
303
#define prm_raf_onlink          prm_flags.prf_ra.onlink
304
#define prm_raf_auto            prm_flags.prf_ra.autonomous
305
 
306
#define prm_statef_onlink       prm_flags.prf_state.onlink
307
 
308
#define prm_rrf_decrvalid       prm_flags.prf_rr.decrvalid
309
#define prm_rrf_decrprefd       prm_flags.prf_rr.decrprefd
310
 
311
#define ifpr2ndpr(ifpr) ((struct nd_prefix *)(ifpr))
312
#define ndpr2ifpr(ndpr) ((struct ifprefix *)(ndpr))
313
 
314
struct nd_pfxrouter {
315
        LIST_ENTRY(nd_pfxrouter) pfr_entry;
316
#define pfr_next pfr_entry.le_next
317
        struct nd_defrouter *router;
318
};
319
 
320
LIST_HEAD(nd_prhead, nd_prefix);
321
 
322
/* nd6.c */
323
extern int nd6_prune;
324
extern int nd6_delay;
325
extern int nd6_umaxtries;
326
extern int nd6_mmaxtries;
327
extern int nd6_useloopback;
328
extern int nd6_maxnudhint;
329
extern int nd6_gctimer;
330
extern struct llinfo_nd6 llinfo_nd6;
331
extern struct nd_ifinfo *nd_ifinfo;
332
extern struct nd_drhead nd_defrouter;
333
extern struct nd_prhead nd_prefix;
334
extern int nd6_debug;
335
 
336
#define nd6log(x)       do { if (nd6_debug) log x; } while (0)
337
 
338
extern struct callout nd6_timer_ch;
339
 
340
/* nd6_rtr.c */
341
extern int nd6_defifindex;
342
extern int ip6_desync_factor;   /* seconds */
343
extern u_int32_t ip6_temp_preferred_lifetime; /* seconds */
344
extern u_int32_t ip6_temp_valid_lifetime; /* seconds */
345
extern int ip6_temp_regen_advance; /* seconds */
346
 
347
union nd_opts {
348
        struct nd_opt_hdr *nd_opt_array[13];    /* max = target address list */
349
        struct {
350
                struct nd_opt_hdr *zero;
351
                struct nd_opt_hdr *src_lladdr;
352
                struct nd_opt_hdr *tgt_lladdr;
353
                struct nd_opt_prefix_info *pi_beg; /* multiple opts, start */
354
                struct nd_opt_rd_hdr *rh;
355
                struct nd_opt_mtu *mtu;
356
                struct nd_opt_hdr *six;
357
                struct nd_opt_advinterval *adv;
358
                struct nd_opt_homeagent_info *hai;
359
                struct nd_opt_hdr *src_addrlist;
360
                struct nd_opt_hdr *tgt_addrlist;
361
                struct nd_opt_hdr *search;      /* multiple opts */
362
                struct nd_opt_hdr *last;        /* multiple opts */
363
                int done;
364
                struct nd_opt_prefix_info *pi_end;/* multiple opts, end */
365
        } nd_opt_each;
366
};
367
#define nd_opts_src_lladdr      nd_opt_each.src_lladdr
368
#define nd_opts_tgt_lladdr      nd_opt_each.tgt_lladdr
369
#define nd_opts_pi              nd_opt_each.pi_beg
370
#define nd_opts_pi_end          nd_opt_each.pi_end
371
#define nd_opts_rh              nd_opt_each.rh
372
#define nd_opts_mtu             nd_opt_each.mtu
373
#define nd_opts_adv             nd_opt_each.adv
374
#define nd_opts_hai             nd_opt_each.hai
375
#define nd_opts_src_addrlist    nd_opt_each.src_addrlist
376
#define nd_opts_tgt_addrlist    nd_opt_each.tgt_addrlist
377
#define nd_opts_search          nd_opt_each.search
378
#define nd_opts_last            nd_opt_each.last
379
#define nd_opts_done            nd_opt_each.done
380
 
381
/* XXX: need nd6_var.h?? */
382
/* nd6.c */
383
void nd6_init __P((void));
384
void nd6_ifattach __P((struct ifnet *));
385
int nd6_is_addr_neighbor __P((struct sockaddr_in6 *, struct ifnet *));
386
void nd6_option_init __P((void *, int, union nd_opts *));
387
struct nd_opt_hdr *nd6_option __P((union nd_opts *));
388
int nd6_options __P((union nd_opts *));
389
struct  rtentry *nd6_lookup __P((struct in6_addr *, int, struct ifnet *));
390
void nd6_setmtu __P((struct ifnet *));
391
void nd6_timer __P((void *));
392
void nd6_purge __P((struct ifnet *));
393
void nd6_nud_hint __P((struct rtentry *, struct in6_addr *, int));
394
int nd6_resolve __P((struct ifnet *, struct rtentry *,
395
                     struct mbuf *, struct sockaddr *, u_char *));
396
void nd6_rtrequest __P((int, struct rtentry *, struct sockaddr *));
397
int nd6_ioctl __P((u_long, caddr_t, struct ifnet *));
398
struct rtentry *nd6_cache_lladdr __P((struct ifnet *, struct in6_addr *,
399
        char *, int, int, int));
400
int nd6_output __P((struct ifnet *, struct ifnet *, struct mbuf *,
401
                    struct sockaddr_in6 *, struct rtentry *));
402
int nd6_storelladdr __P((struct ifnet *, struct rtentry *, struct mbuf *,
403
                         struct sockaddr *, u_char *));
404
int nd6_need_cache __P((struct ifnet *));
405
 
406
/* nd6_nbr.c */
407
void nd6_na_input __P((struct mbuf *, int, int));
408
void nd6_na_output __P((struct ifnet *, const struct in6_addr *,
409
        const struct in6_addr *, u_long, int, struct sockaddr *));
410
void nd6_ns_input __P((struct mbuf *, int, int));
411
void nd6_ns_output __P((struct ifnet *, const struct in6_addr *,
412
        const struct in6_addr *, struct llinfo_nd6 *, int));
413
caddr_t nd6_ifptomac __P((struct ifnet *));
414
void nd6_dad_start __P((struct ifaddr *, int *));
415
void nd6_dad_stop __P((struct ifaddr *));
416
void nd6_dad_duplicated __P((struct ifaddr *));
417
 
418
/* nd6_rtr.c */
419
void nd6_rs_input __P((struct mbuf *, int, int));
420
void nd6_ra_input __P((struct mbuf *, int, int));
421
void prelist_del __P((struct nd_prefix *));
422
void defrouter_addreq __P((struct nd_defrouter *));
423
void defrouter_reset __P((void));
424
void defrouter_select __P((void));
425
void defrtrlist_del __P((struct nd_defrouter *));
426
void prelist_remove __P((struct nd_prefix *));
427
int prelist_update __P((struct nd_prefix *, struct nd_defrouter *,
428
                        struct mbuf *));
429
int nd6_prelist_add __P((struct nd_prefix *, struct nd_defrouter *,
430
                         struct nd_prefix **));
431
int nd6_prefix_onlink __P((struct nd_prefix *));
432
int nd6_prefix_offlink __P((struct nd_prefix *));
433
void pfxlist_onlink_check __P((void));
434
struct nd_defrouter *defrouter_lookup __P((struct in6_addr *,
435
                                           struct ifnet *));
436
struct nd_prefix *nd6_prefix_lookup __P((struct nd_prefix *));
437
int in6_init_prefix_ltimes __P((struct nd_prefix *ndpr));
438
void rt6_flush __P((struct in6_addr *, struct ifnet *));
439
int nd6_setdefaultiface __P((int));
440
int in6_tmpifadd __P((const struct in6_ifaddr *, int));
441
 
442
#endif /* _KERNEL */
443
 
444
#endif /* _NETINET6_ND6_H_ */

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.