source: azure_iot_hub/trunk/asp3_dcre/tinet/netinet6/in6.c@ 388

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

Azure IoT Hub Device C SDK を使ったサンプルの追加

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-csrc
File size: 15.4 KB
Line 
1/*
2 * TINET (TCP/IP Protocol Stack)
3 *
4 * Copyright (C) 2001-2017 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 388 2019-05-22 11:25:18Z 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_endian.h>
141#include <net/net_buf.h>
142#include <net/net_timer.h>
143#include <net/net_count.h>
144
145#include <netinet/in.h>
146#include <netinet/in_var.h>
147
148#include <netinet6/in6.h>
149#include <netinet6/in6_var.h>
150#include <netinet6/nd6.h>
151#include <netinet6/in6_ifattach.h>
152
153#include <net/if_var.h>
154
155#ifdef _IP6_CFG
156
157/*
158 * å…
159¨åŸŸå¤‰æ•°
160 */
161
162const T_IN6_ADDR in6_addr_unspecified =
163 IPV6_ADDR_UNSPECIFIED_INIT;
164
165const T_IN6_ADDR in6_addr_linklocal_allnodes =
166 IPV6_ADDR_LINKLOCAL_ALLNODES_INIT;
167
168const T_IN6_ADDR in6_addr_linklocal_allrouters =
169 IPV6_ADDR_LINKLOCAL_ALLROUTERS_INIT;
170
171/*
172 * in6_addmulti -- マルチキャストアドレスを登録する。
173 */
174
175static ER
176in6_addmulti (T_IFNET *ifp, T_IN6_ADDR *maddr)
177{
178 ER error = E_OK;
179
180 if ((error = if_addmulti(ifp, maddr, AT_INET6)) != E_OK)
181 return error;
182
183 return error;
184 }
185
186/*
187 * in6_ifinit -- インタフェースにアドレス情
188報を設定し、初期化する。
189 */
190
191static ER
192in6_ifinit (T_IFNET *ifp, T_IN6_IFADDR *ia, const T_IN6_ADDR *addr, uint_t prefix_len)
193{
194 /* アドレスとプレフィックス長を設定する。*/
195 ia->addr = *addr;
196 ia->prefix_len = prefix_len;
197
198 /* フラグを初期化する。*/
199 ia->flags = 0;
200
201 /*
202 * 初めてアドレスが設定されたとき、インタフェース独自の初期化を行う。
203 */
204
205 return E_OK;
206 }
207
208/*
209 * in6_ifainit -- インタフェースアドレス構造体の初期化
210 */
211
212void
213in6_ifainit (void)
214{
215 T_IN6_IFADDR *ia = NULL;
216 T_IFNET *ifp = IF_GET_IFNET();
217 int_t ix;
218
219 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; ) {
220 ia = &ifp->in6_ifaddrs[ix];
221 memset(ia, sizeof(T_IN6_IFADDR), 0);
222 ia->router_index = IN6_RTR_IX_UNREACH;
223 ia->prefix_index = ND6_PREFIX_IX_INVALID;
224 }
225 }
226
227/*
228 * in6_if2idlen -- インタフェース ID 長を返す。
229 */
230
231int_t
232in6_if2idlen (T_IFNET *ifp)
233{
234#if IF_TYPE == IFT_ETHER
235 return 64;
236#else
237 return 64;
238#endif
239 }
240
241/*
242 * in6_addr2ifaix -- アドレスからインタフェースアドレス情
243報のインデックスに変換する。
244 */
245
246int_t
247in6_addr2ifaix (const T_IN6_ADDR *addr)
248{
249 T_IFNET *ifp = IF_GET_IFNET();
250 T_IN6_IFADDR *ia;
251 int_t ix;
252
253 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; ) {
254 ia = &ifp->in6_ifaddrs[ix];
255 if ((ia->flags & IN6_IFF_DEFINED) != 0 &&
256 in6_are_prefix_equal(addr, &ia->addr, ia->prefix_len))
257 return ix;
258 }
259
260 return IPV6_IFADDR_IX_INVALID;
261 }
262
263/*
264 * in6_addr2maix -- アドレスからマルチキャストアドレスのインデックスに変換する。
265 */
266
267int_t
268in6_addr2maix (const T_IN6_ADDR *addr)
269{
270 if (addr->s6_addr8[0] == 0xff) {
271 if (addr->s6_addr8[1] == 0x02) {
272 if (addr->s6_addr8[11] == 0x01 && addr->s6_addr8[12] == 0xff)
273 return IPV6_MADDR_IX_SOL_NODE;
274 else
275 return IPV6_MADDR_IX_LL_ALL_NODE;
276 }
277 else
278 return IPV6_MADDR_IX_EXTRA;
279 }
280 else
281 return IPV6_MADDR_IX_EXTRA;
282 }
283
284/*
285 * in6_update_ifa -- インタフェースのアドレス情
286報を更新する。
287 */
288
289ER
290in6_update_ifa (T_IFNET *ifp, T_IN6_IFADDR *ia, const T_IN6_ADDR *addr,
291 uint_t prefix_len, uint32_t vltime, uint32_t pltime,
292 int_t router_index, int_t prefix_index, uint_t flags)
293{
294 T_IN6_ADDR llsol;
295 ER error = E_OK;
296 SYSTIM now;
297
298 /* 引数をチェックする。*/
299 if (addr == NULL)
300 return E_PAR;
301
302 /*
303 * 有効時間をチェックする。
304 * vltime (有効時間) と pltime (推奨有効時間) の単位は [s]。
305 */
306 syscall(get_tim(&now));
307 now /= SYSTIM_HZ;
308
309 if (((vltime != ND6_INFINITE_LIFETIME) && (vltime + now < now)) || vltime == 0)
310 return E_PAR;
311
312 if ((pltime != ND6_INFINITE_LIFETIME) && (pltime + now < now))
313 return E_PAR;
314
315 /* インタフェースを初期化する。*/
316 if ((error = in6_ifinit(ifp, ia, addr, prefix_len)) != E_OK)
317 return error;
318
319 if (IN6_IS_ADDR_LINKLOCAL(addr)) {
320
321 /* 要請マルチキャストアドレスを登録する。*/
322 llsol.s6_addr32[0] = IPV6_ADDR_INT32_MLL;
323 llsol.s6_addr32[1] = 0x00000000;
324 llsol.s6_addr32[2] = IPV6_ADDR_INT32_ONE;
325 llsol.s6_addr32[3] = addr->s6_addr32[3];
326 llsol.s6_addr8[12] = 0xff;
327 if ((error = in6_addmulti(ifp, &llsol)) != E_OK)
328 return error;
329
330 /* å…
331¨ãƒŽãƒ¼ãƒ‰ãƒ»ãƒªãƒ³ã‚¯ãƒ­ãƒ¼ã‚«ãƒ«ãƒ»ãƒžãƒ«ãƒã‚­ãƒ£ã‚¹ãƒˆã‚¢ãƒ‰ãƒ¬ã‚¹ã‚’登録する。*/
332 llsol.s6_addr32[2] = 0x00000000;
333 llsol.s6_addr32[3] = IPV6_ADDR_INT32_ONE;
334 if ((error = in6_addmulti(ifp, &llsol)) != E_OK)
335 return error;
336
337 }
338
339 /* ルータインデックスを設定する。*/
340 ia->router_index = router_index;
341
342 /* プレフィックスインデックスを設定する。*/
343 ia->prefix_index = prefix_index;
344
345 /* フラグを設定する。*/
346 ia->flags = flags & ~(IN6_IFF_DUPLICATED | IN6_IFF_NODAD);
347 ia->flags |= IN6_IFF_DEFINED;
348
349 /*
350 * アドレス有効時間を設定する。
351 * vltime (有効時間) と pltime (推奨有効時間) の単位は [s]。
352 */
353 syscall(get_tim(&now));
354 now /= SYSTIM_HZ;
355
356 ia->lifetime.vltime = vltime;
357 if (vltime != ND6_INFINITE_LIFETIME)
358 ia->lifetime.expire = now + vltime;
359 else
360 ia->lifetime.expire = 0;
361
362 ia->lifetime.pltime = pltime;
363 if (pltime != ND6_INFINITE_LIFETIME)
364 ia->lifetime.preferred = now + pltime;
365 else
366 ia->lifetime.preferred = 0;
367
368 /* 近隣探索の初期設定を行う。*/
369 nd6_ifattach(ifp);
370
371 /* 重複アドレス検出を行う。*/
372 if ((flags & IN6_IFF_NODAD) == 0) {
373 ia->flags |= IN6_IFF_TENTATIVE;
374 nd6_dad_start(ifp, ia, NULL);
375 }
376
377 return error;
378 }
379
380/*
381 * in6ifa_ifpwithix -- インデックス番号から、ネットワークインタフェースに
382 * 割り当てられているアドレスを探索する。
383 */
384
385T_IN6_IFADDR *
386in6ifa_ifpwithix (T_IFNET *ifp, int_t ix)
387{
388 return ix < NUM_IN6_IFADDR_ENTRY? &ifp->in6_ifaddrs[ix] : NULL;
389 }
390
391/*
392 * in6ifa_ifpwithrtrix -- ルータのインデックス番号から、ネットワークインタフェースに
393 * 割り当てられているアドレスを探索する。
394 */
395
396T_IN6_IFADDR *
397in6ifa_ifpwithrtrix (T_IFNET *ifp, int_t router_index)
398{
399 int_t ix;
400
401 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; )
402 if (ifp->in6_ifaddrs[ix].router_index == router_index)
403 return &ifp->in6_ifaddrs[ix];
404 return NULL;
405 }
406
407/*
408 * in6_ifawithifp -- 宛å…
409ˆã‚¢ãƒ‰ãƒ¬ã‚¹ã«ãµã•ã‚ã—い送信å…
410ƒã‚¢ãƒ‰ãƒ¬ã‚¹æƒ…
411報を、
412 * ネットワークインタフェースから探索する。
413 */
414
415T_IN6_IFADDR *
416in6_ifawithifp (T_IFNET *ifp, const T_IN6_ADDR *dst)
417{
418 uint_t scope;
419 int_t ix;
420
421 /* 宛å…
422ˆã‚¢ãƒ‰ãƒ¬ã‚¹ã¨åŒã˜ã‚¹ã‚³ãƒ¼ãƒ—のアドレスを返す。*/
423 if ((ix = in6_addr2ifaix(dst)) != IPV6_IFADDR_IX_INVALID)
424 return &ifp->in6_ifaddrs[ix];
425 else if ((ix = in6_addr2maix(dst)) == IPV6_MADDR_IX_SOL_NODE ||
426 ix == IPV6_MADDR_IX_LL_ALL_NODE)
427 return &ifp->in6_ifaddrs[IPV6_IFADDR_IX_LINKLOCAL];
428 else {
429 scope = in6_addrscope(dst);
430 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; ) {
431 if ((ifp->in6_ifaddrs[ix].flags & IN6_IFF_DEFINED) &&
432 (ifp->in6_ifaddrs[ix].flags & IN6_IFF_DETACHED) == 0 &&
433 in6_addrscope(&ifp->in6_ifaddrs[ix].addr) == scope) {
434 return &ifp->in6_ifaddrs[ix];
435 }
436 }
437 return NULL;
438 }
439 }
440
441/*
442 * in6_addrwithifp -- 宛å…
443ˆã‚¢ãƒ‰ãƒ¬ã‚¹ã«ãµã•ã‚ã—い送信å…
444ƒã‚¢ãƒ‰ãƒ¬ã‚¹ã‚’、
445 * ネットワークインタフェースから探索する。
446 */
447
448const T_IN6_ADDR *
449in6_addrwithifp (T_IFNET *ifp, T_IN6_ADDR *src, const T_IN6_ADDR *dst)
450{
451 T_IN6_IFADDR *ifaddr;
452
453 if ((ifaddr = in6_ifawithifp(ifp, dst)) == NULL)
454 return NULL;
455 else {
456 *src = ifaddr->addr;
457 return src;
458 }
459 }
460
461/*
462 * in6_if_up -- インタフェース起動後の重複アドレス検出を行う。
463 */
464
465void
466in6_if_up (T_IFNET *ifp)
467{
468#if 0 /* 保留 */
469 int_t dad_delay, ix;
470#endif /* of #if 0 */
471
472 in6_ifattach(ifp);
473
474#if 0 /* 保留 */
475 /* 重複アドレス検出を行う。*/
476 dad_delay = 0;
477 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; )
478 if ((ifp->in6_ifaddrs[ix].flags & IN6_IFF_DEFINED) &&
479 (ifp->in6_ifaddrs[ix].flags & IN6_IFF_TENTATIVE))
480 nd6_dad_start(ifp, &ifp->in6_ifaddrs[ix], &dad_delay);
481#endif /* of #if 0 */
482
483#if NUM_ND6_RTR_SOL_RETRY > 0
484
485 /* ルータ要請を出力する。*/
486 nd6_rtrsol_ctl();
487
488#endif /* of #if NUM_ND6_RTR_SOL_RETRY > 0 */
489 }
490
491/*
492 * in6_are_prefix_equal -- プレフィックスが同一か調べる。
493 */
494
495bool_t
496in6_are_prefix_equal (const T_IN6_ADDR *addr, const T_IN6_ADDR *prefix, uint_t prefix_len)
497{
498 uint_t bitlen, bytelen;
499
500 bytelen = prefix_len / 8;
501 if (memcmp(&addr->s6_addr, &prefix->s6_addr, bytelen))
502 return false;
503
504 bitlen = prefix_len % 8;
505 if ( addr->s6_addr[bytelen] >> (8 - bitlen) !=
506 prefix->s6_addr[bytelen] >> (8 - bitlen))
507 return false;
508
509 return true;
510 }
511
512/*
513 * in6_ifaddr_timer -- ネットワークインタフェースのアドレスの管理タイマー
514 */
515
516void
517in6_ifaddr_timer (T_IFNET *ifp)
518{
519 T_IN6_IFADDR *ia;
520 SYSTIM now;
521 int_t ix;
522
523 syscall(get_tim(&now));
524 for (ix = NUM_IN6_IFADDR_ENTRY; ix -- > 0; ) {
525 ia = &ifp->in6_ifaddrs[ix];
526
527 if ((ia->flags & IN6_IFF_DEFINED) == 0)
528 ;
529 else if (IFA6_IS_INVALID(ia, now)) {
530
531 /*
532 * 有効時間を過ぎたので削除する。
533 */
534 ia->flags &= ~IN6_IFF_DEFINED;
535 }
536
537 else if (IFA6_IS_DEPRECATED(ia, now)) {
538
539 /*
540 * 推奨有効時間を過ぎたので非推奨にする。
541 */
542 ia->flags |= IN6_IFF_DEPRECATED;
543 }
544 }
545 }
546
547#endif /* of #ifdef _IP6_CFG */
Note: See TracBrowser for help on using the repository browser.