source: EcnlProtoTool/trunk/asp3_dcre/tinet/netinet6/in6.c@ 270

Last change on this file since 270 was 270, checked in by coas-nagasima, 7 years ago

mruby版ECNLプロトタイピング・ツールを追加

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-csrc
File size: 14.8 KB
Line 
1/*
2 * TINET (TCP/IP Protocol Stack)
3 *
4 * Copyright (C) 2001-2009 by Dep. of Computer Science and Engineering
5 * Tomakomai National College of Technology, JAPAN
6 *
7 * 上記著作権者
8は,以下の (1)~(4) の条件か,Free Software Foundation
9 * によってå…
10¬è¡¨ã•ã‚Œã¦ã„ã‚‹ GNU General Public License の Version 2 に記
11 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
12 * を改変したものを含む.以下同じ)を使用・複製・改変・再é…
13å¸ƒï¼ˆä»¥ä¸‹ï¼Œ
14 * 利用と呼ぶ)することを無償で許諾する.
15 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
16 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
17 * スコード中に含まれていること.
18 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
19 * 用できる形で再é…
20å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
21å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
22 * 者
23マニュアルなど)に,上記の著作権表示,この利用条件および下記
24 * の無保証規定を掲載すること.
25 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
26 * 用できない形で再é…
27å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®æ¡ä»¶ã‚’満たすこと.
28 * (a) 再é…
29å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
30マニュアルなど)に,上記の著
31 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
32 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
33 * 害からも,上記著作権者
34およびTOPPERSプロジェクトをå…
35è²¬ã™ã‚‹ã“と.
36 *
37 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
38お
39 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
40 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
41 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
42 *
43 * @(#) $Id: in6.c 270 2017-02-09 04:03:47Z coas-nagasima $
44 */
45
46/* $FreeBSD: src/sys/netinet6/in6.c,v 1.21 2002/04/19 04:46:22 suz Exp $ */
47/* $KAME: in6.c,v 1.259 2002/01/21 11:37:50 keiichi Exp $ */
48
49/*
50 * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
51 * All rights reserved.
52 *
53 * Redistribution and use in source and binary forms, with or without
54 * modification, are permitted provided that the following conditions
55 * are met:
56 * 1. Redistributions of source code must retain the above copyright
57 * notice, this list of conditions and the following disclaimer.
58 * 2. Redistributions in binary form must reproduce the above copyright
59 * notice, this list of conditions and the following disclaimer in the
60 * documentation and/or other materials provided with the distribution.
61 * 3. Neither the name of the project nor the names of its contributors
62 * may be used to endorse or promote products derived from this software
63 * without specific prior written permission.
64 *
65 * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
66 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
67 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
68 * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
69 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
70 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
71 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
72 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
73 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
74 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
75 * SUCH DAMAGE.
76 */
77
78/*
79 * Copyright (c) 1982, 1986, 1991, 1993
80 * The Regents of the University of California. All rights reserved.
81 *
82 * Redistribution and use in source and binary forms, with or without
83 * modification, are permitted provided that the following conditions
84 * are met:
85 * 1. Redistributions of source code must retain the above copyright
86 * notice, this list of conditions and the following disclaimer.
87 * 2. Redistributions in binary form must reproduce the above copyright
88 * notice, this list of conditions and the following disclaimer in the
89 * documentation and/or other materials provided with the distribution.
90 * 3. All advertising materials mentioning features or use of this software
91 * must display the following acknowledgement:
92 * This product includes software developed by the University of
93 * California, Berkeley and its contributors.
94 * 4. Neither the name of the University nor the names of its contributors
95 * may be used to endorse or promote products derived from this software
96 * without specific prior written permission.
97 *
98 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
99 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
100 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
101 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
102 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
103 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
104 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
105 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
106 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
107 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
108 * SUCH DAMAGE.
109 *
110 * @(#)in.c 8.2 (Berkeley) 11/15/93
111 */
112
113#include <string.h>
114
115#ifdef TARGET_KERNEL_ASP
116
117#include <kernel.h>
118#include <sil.h>
119
120#endif /* of #ifdef TARGET_KERNEL_ASP */
121
122#ifdef TARGET_KERNEL_JSP
123
124#include <s_services.h>
125#include <t_services.h>
126#include "kernel_id.h"
127
128#endif /* of #ifdef TARGET_KERNEL_JSP */
129
130#include <tinet_defs.h>
131#include <tinet_config.h>
132
133#include <net/if.h>
134#include <net/if_types.h>
135#include <net/if_ppp.h>
136#include <net/if_loop.h>
137#include <net/ethernet.h>
138#include <net/ppp_ipcp.h>
139#include <net/net.h>
140#include <net/net_buf.h>
141#include <net/net_timer.h>
142#include <net/net_count.h>
143
144#include <netinet6/in6.h>
145#include <netinet6/in6_var.h>
146#include <netinet6/nd6.h>
147#include <netinet6/in6_ifattach.h>
148
149#include <net/if6_var.h>
150
151#ifdef SUPPORT_INET6
152
153/*
154 * å…
155¨åŸŸå¤‰æ•°
156 */
157
158T_IN6_ADDR in6_addr_unspecified =
159 IPV6_ADDR_UNSPECIFIED_INIT;
160
161T_IN6_ADDR in6_addr_linklocal_allnodes =
162 IPV6_ADDR_LINKLOCAL_ALLNODES_INIT;
163
164T_IN6_ADDR in6_addr_linklocal_allrouters =
165 IPV6_ADDR_LINKLOCAL_ALLROUTERS_INIT;
166
167/*
168 * in6_addmulti -- マルチキャストアドレスを登録する。
169 */
170
171static ER
172in6_addmulti (T_IFNET *ifp, T_IN6_ADDR *maddr)
173{
174 ER error = E_OK;
175
176 if ((error = if_addmulti(ifp, maddr, AT_INET6)) != E_OK)
177 return error;
178
179 return error;
180 }
181
182/*
183 * in6_ifinit -- インタフェースにアドレス情
184報を設定し、初期化する。
185 */
186
187static ER
188in6_ifinit (T_IFNET *ifp, T_IN6_IFADDR *ia, T_IN6_ADDR *addr, uint_t prefix_len)
189{
190 /* アドレスとプレフィックス長を設定する。*/
191 ia->addr = *addr;
192 ia->prefix_len = prefix_len;
193
194 /* フラグを初期化する。*/
195 ia->flags = 0;
196
197 /*
198 * 初めてアドレスが設定されたとき、インタフェース独自の初期化を行う。
199 */
200
201 return E_OK;
202 }
203
204/*
205 * in6_ifainit -- インタフェースアドレス構造体の初期化
206 */
207
208void
209in6_ifainit (void)
210{
211 T_IN6_IFADDR *ia = NULL;
212 T_IFNET *ifp = IF_GET_IFNET();
213 int_t ix;
214
215 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; ) {
216 ia = &ifp->in_ifaddrs[ix];
217 memset(ia, sizeof(T_IN6_IFADDR), 0);
218 ia->router_index = IN6_RTR_IX_UNREACH;
219 ia->prefix_index = ND6_PREFIX_IX_INVALID;
220 }
221 }
222
223/*
224 * in6_if2idlen -- インタフェース ID 長を返す。
225 */
226
227int_t
228in6_if2idlen (T_IFNET *ifp)
229{
230#if IF_TYPE == IFT_ETHER
231 return 64;
232#else
233 return 64;
234#endif
235 }
236
237/*
238 * in6_addr2ifaix -- アドレスからインタフェースアドレス情
239報のインデックスに変換する。
240 */
241
242int_t
243in6_addr2ifaix (T_IN6_ADDR *addr)
244{
245 T_IFNET *ifp = IF_GET_IFNET();
246 T_IN6_IFADDR *ia;
247 int_t ix;
248
249 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; ) {
250 ia = &ifp->in_ifaddrs[ix];
251 if ((ia->flags & IN6_IFF_DEFINED) != 0 &&
252 in6_are_prefix_equal(addr, &ia->addr, ia->prefix_len))
253 return ix;
254 }
255
256 return IPV6_IFADDR_IX_INVALID;
257 }
258
259/*
260 * in6_addr2maix -- アドレスからマルチキャストアドレスのインデックスに変換する。
261 */
262
263int_t
264in6_addr2maix (T_IN6_ADDR *addr)
265{
266 if (addr->s6_addr8[0] == 0xff) {
267 if (addr->s6_addr8[1] == 0x02) {
268 if (addr->s6_addr8[11] == 0x01 && addr->s6_addr8[12] == 0xff)
269 return IPV6_MADDR_IX_SOL_NODE;
270 else
271 return IPV6_MADDR_IX_LL_ALL_NODE;
272 }
273 else
274 return IPV6_MADDR_IX_EXTRA;
275 }
276 else
277 return IPV6_MADDR_IX_EXTRA;
278 }
279
280/*
281 * in6_update_ifa -- インタフェースのアドレス情
282報を更新する。
283 */
284
285ER
286in6_update_ifa (T_IFNET *ifp, T_IN6_IFADDR *ia, T_IN6_ADDR *addr,
287 uint_t prefix_len, uint32_t vltime, uint32_t pltime,
288 int_t router_index, int_t prefix_index, uint_t flags)
289{
290 T_IN6_ADDR llsol;
291 ER error = E_OK;
292 SYSTIM now;
293
294 /* 引数をチェックする。*/
295 if (addr == NULL)
296 return E_PAR;
297
298 /*
299 * 有効時間をチェックする。
300 * vltime (有効時間) と pltime (推奨有効時間) の単位は [s]。
301 */
302 syscall(get_tim(&now));
303 now /= SYSTIM_HZ;
304
305 if (((vltime != ND6_INFINITE_LIFETIME) && (vltime + now < now)) || vltime == 0)
306 return E_PAR;
307
308 if ((pltime != ND6_INFINITE_LIFETIME) && (pltime + now < now))
309 return E_PAR;
310
311 /* インタフェースを初期化する。*/
312 if ((error = in6_ifinit(ifp, ia, addr, prefix_len)) != E_OK)
313 return error;
314
315 if (IN6_IS_ADDR_LINKLOCAL(addr)) {
316
317 /* 要請マルチキャストアドレスを登録する。*/
318 llsol.s6_addr32[0] = IPV6_ADDR_INT32_MLL;
319 llsol.s6_addr32[1] = 0x00000000;
320 llsol.s6_addr32[2] = IPV6_ADDR_INT32_ONE;
321 llsol.s6_addr32[3] = addr->s6_addr32[3];
322 llsol.s6_addr8[12] = 0xff;
323 if ((error = in6_addmulti(ifp, &llsol)) != E_OK)
324 return error;
325
326 /* å…
327¨ãƒŽãƒ¼ãƒ‰ãƒ»ãƒªãƒ³ã‚¯ãƒ­ãƒ¼ã‚«ãƒ«ãƒ»ãƒžãƒ«ãƒã‚­ãƒ£ã‚¹ãƒˆã‚¢ãƒ‰ãƒ¬ã‚¹ã‚’登録する。*/
328 llsol.s6_addr32[2] = 0x00000000;
329 llsol.s6_addr32[3] = IPV6_ADDR_INT32_ONE;
330 if ((error = in6_addmulti(ifp, &llsol)) != E_OK)
331 return error;
332
333 }
334
335 /* ルータインデックスを設定する。*/
336 ia->router_index = router_index;
337
338 /* プレフィックスインデックスを設定する。*/
339 ia->prefix_index = prefix_index;
340
341 /* フラグを設定する。*/
342 ia->flags = flags & ~(IN6_IFF_DUPLICATED | IN6_IFF_NODAD);
343 ia->flags |= IN6_IFF_DEFINED;
344
345 /*
346 * アドレス有効時間を設定する。
347 * vltime (有効時間) と pltime (推奨有効時間) の単位は [s]。
348 */
349 syscall(get_tim(&now));
350 now /= SYSTIM_HZ;
351
352 ia->lifetime.vltime = vltime;
353 if (vltime != ND6_INFINITE_LIFETIME)
354 ia->lifetime.expire = now + vltime;
355 else
356 ia->lifetime.expire = 0;
357
358 ia->lifetime.pltime = pltime;
359 if (pltime != ND6_INFINITE_LIFETIME)
360 ia->lifetime.preferred = now + pltime;
361 else
362 ia->lifetime.preferred = 0;
363
364 /* 近隣探索の初期設定を行う。*/
365 nd6_ifattach(ifp);
366
367 /* 重複アドレス検出を行う。*/
368 if ((flags & IN6_IFF_NODAD) == 0) {
369 ia->flags |= IN6_IFF_TENTATIVE;
370 nd6_dad_start(ifp, ia, NULL);
371 }
372
373 return error;
374 }
375
376/*
377 * in6ifa_ifpwithix -- インデックス番号から、ネットワークインタフェースに
378 * 割り当てられているアドレスを探索する。
379 */
380
381T_IN6_IFADDR *
382in6ifa_ifpwithix (T_IFNET *ifp, int_t ix)
383{
384 return ix < NUM_IN6_IFADDR_ENTRY? &ifp->in_ifaddrs[ix] : NULL;
385 }
386
387/*
388 * in6ifa_ifpwithrtrix -- ルータのインデックス番号から、ネットワークインタフェースに
389 * 割り当てられているアドレスを探索する。
390 */
391
392T_IN6_IFADDR *
393in6ifa_ifpwithrtrix (T_IFNET *ifp, int_t router_index)
394{
395 int_t ix;
396
397 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; )
398 if (ifp->in_ifaddrs[ix].router_index == router_index)
399 return &ifp->in_ifaddrs[ix];
400 return NULL;
401 }
402
403/*
404 * in6_ifawithifp -- 宛å…
405ˆã‚¢ãƒ‰ãƒ¬ã‚¹ã«ãµã•ã‚ã—い送信å…
406ƒã‚¢ãƒ‰ãƒ¬ã‚¹ã‚’、
407 * ネットワークインタフェースから探索する。
408 */
409
410T_IN6_IFADDR *
411in6_ifawithifp (T_IFNET *ifp, T_IN6_ADDR *dst)
412{
413 uint_t scope;
414 int_t ix;
415
416 /* 宛å…
417ˆã‚¢ãƒ‰ãƒ¬ã‚¹ã¨åŒã˜ã‚¹ã‚³ãƒ¼ãƒ—のアドレスを返す。*/
418 if ((ix = in6_addr2ifaix(dst)) != IPV6_IFADDR_IX_INVALID)
419 return &ifp->in_ifaddrs[ix];
420 else if ((ix = in6_addr2maix(dst)) == IPV6_MADDR_IX_SOL_NODE ||
421 ix == IPV6_MADDR_IX_LL_ALL_NODE)
422 return &ifp->in_ifaddrs[IPV6_IFADDR_IX_LINKLOCAL];
423 else {
424 scope = in6_addrscope(dst);
425 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; ) {
426 if ((ifp->in_ifaddrs[ix].flags & IN6_IFF_DEFINED) &&
427 (ifp->in_ifaddrs[ix].flags & IN6_IFF_DETACHED) == 0 &&
428 in6_addrscope(&ifp->in_ifaddrs[ix].addr) == scope) {
429 return &ifp->in_ifaddrs[ix];
430 }
431 }
432 return NULL;
433 }
434 }
435
436/*
437 * in6_if_up -- インタフェース起動後の重複アドレス検出を行う。
438 */
439
440void
441in6_if_up (T_IFNET *ifp)
442{
443#if 0 /* 保留 */
444 int_t dad_delay, ix;
445#endif /* of #if 0 */
446
447 in6_ifattach(ifp);
448
449#if 0 /* 保留 */
450 /* 重複アドレス検出を行う。*/
451 dad_delay = 0;
452 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; )
453 if ((ifp->in_ifaddrs[ix].flags & IN6_IFF_DEFINED) &&
454 (ifp->in_ifaddrs[ix].flags & IN6_IFF_TENTATIVE))
455 nd6_dad_start(ifp, &ifp->in_ifaddrs[ix], &dad_delay);
456#endif /* of #if 0 */
457
458#if NUM_ND6_RTR_SOL_RETRY > 0
459
460 /* ルータ要請を出力する。*/
461 nd6_rtrsol_ctl();
462
463#endif /* of #if NUM_ND6_RTR_SOL_RETRY > 0 */
464 }
465
466/*
467 * in6_are_prefix_equal -- プレフィックスが同一か調べる。
468 */
469
470bool_t
471in6_are_prefix_equal (T_IN6_ADDR *addr, T_IN6_ADDR *prefix, uint_t prefix_len)
472{
473 uint_t bitlen, bytelen;
474
475 bytelen = prefix_len / 8;
476 if (memcmp(&addr->s6_addr, &prefix->s6_addr, bytelen))
477 return false;
478
479 bitlen = prefix_len % 8;
480 if ( addr->s6_addr[bytelen] >> (8 - bitlen) !=
481 prefix->s6_addr[bytelen] >> (8 - bitlen))
482 return false;
483
484 return true;
485 }
486
487/*
488 * in6_ifaddr_timer -- ネットワークインタフェースのアドレスの管理タイマー
489 */
490
491void
492in6_ifaddr_timer (T_IFNET *ifp)
493{
494 T_IN6_IFADDR *ia;
495 SYSTIM now;
496 int_t ix;
497
498 syscall(get_tim(&now));
499 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; ) {
500 ia = &ifp->in_ifaddrs[ix];
501
502 if ((ia->flags & IN6_IFF_DEFINED) == 0)
503 ;
504 else if (IFA6_IS_INVALID(ia, now)) {
505
506 /*
507 * 有効時間を過ぎたので削除する。
508 */
509 ia->flags &= ~IN6_IFF_DEFINED;
510 }
511
512 else if (IFA6_IS_DEPRECATED(ia, now)) {
513
514 /*
515 * 推奨有効時間を過ぎたので非推奨にする。
516 */
517 ia->flags |= IN6_IFF_DEPRECATED;
518 }
519 }
520 }
521
522#endif /* of #ifdef SUPPORT_INET6 */
Note: See TracBrowser for help on using the repository browser.