source: EcnlProtoTool/trunk/asp3_dcre/tinet/netapp/ping6.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: 5.9 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: ping6.c 270 2017-02-09 04:03:47Z coas-nagasima $
44 */
45
46/*
47 * ping6 -- ICMPv6 ECHO メッセージを送信する。
48 */
49
50#ifdef TARGET_KERNEL_ASP
51
52#include <kernel.h>
53#include <sil.h>
54#include <t_syslog.h>
55
56#endif /* of #ifdef TARGET_KERNEL_ASP */
57
58#ifdef TARGET_KERNEL_JSP
59
60#include <s_services.h>
61#include <t_services.h>
62
63#endif /* of #ifdef TARGET_KERNEL_JSP */
64
65#include <tinet_defs.h>
66#include <tinet_config.h>
67
68#include <net/if.h>
69#include <net/if_ppp.h>
70#include <net/if_loop.h>
71#include <net/ethernet.h>
72#include <net/ppp_var.h>
73#include <net/ppp_ipcp.h>
74#include <net/net.h>
75#include <net/net_buf.h>
76#include <net/net_timer.h>
77#include <net/net_count.h>
78
79#include <netinet/in.h>
80#include <netinet/in_var.h>
81
82#include <netinet6/in6.h>
83#include <netinet6/in6_var.h>
84#include <netinet6/nd6.h>
85
86#include <netinet/ip6.h>
87#include <netinet6/ip6_var.h>
88#include <netinet/icmp6.h>
89
90#include <net/if6_var.h>
91
92#ifdef USE_PING
93
94/*
95 * 変数
96 */
97
98static uint16_t send_icmp6_id = 0;
99static uint16_t curr_icmp6_id;
100static uint16_t curr_icmp6_size;
101static uint16_t reply_count;
102static SYSTIM icmp6_start_time;
103
104/*
105 * icmp6_reply_timeout -- ICMP6 REPLY タイムアウト処理
106 */
107
108static void
109icmp6_reply_timeout (void *arg)
110{
111 if (reply_count == 0)
112 syslog(LOG_NOTICE, "[PING6] request timeout.");
113 }
114
115/*
116 * icmp6_echo_reply -- ICMP6 ECHO REPLY メッセージを処理する。
117 */
118
119void
120icmp6_echo_reply (T_NET_BUF *input, uint_t ihoff)
121{
122 T_IP6_HDR *ip6h;
123 SYSTIM time;
124
125 syscall(get_tim(&time));
126 ip6h = GET_IP6_HDR(input);
127
128 syslog(LOG_NOTICE, "[PING6] reply: %5d [ms] from: %s",
129 (time - icmp6_start_time) * 1000 / SYSTIM_HZ,
130 ipv62str(NULL, &ip6h->src));
131 reply_count ++;
132 }
133
134/*
135 * ping6 -- ICMP ECHO メッセージを送信する。
136 */
137
138void
139ping6 (T_IN6_ADDR *addr, uint_t tmo, uint_t size)
140{
141 T_IFNET *ifp = IF_GET_IFNET();
142 T_ICMP6_HDR *icmp6h;
143 T_NET_BUF *output;
144 T_IN6_IFADDR *ia;
145 int_t ix;
146 uint16_t ipflags = 0;
147 uint8_t *sdu;
148
149 /*
150 * 宛å…
151ˆã‚¢ãƒ‰ãƒ¬ã‚¹ã«ãµã•ã‚ã—い送信å…
152ƒã‚¢ãƒ‰ãƒ¬ã‚¹ã‚’、
153 * ネットワークインタフェースから探索して利用する。
154 */
155 if ((ia = in6_ifawithifp(ifp, addr)) == NULL)
156 return;
157
158 if (IN6_IS_ADDR_MULTICAST(addr))
159 ipflags = IPV6_OUT_SET_HOP_LIMIT(IPV6_OUT_FLG_HOP_LIMIT, IPV6_DEFHLIM);
160
161 /* 送信用の IP データグラムを獲得する。*/
162 if (in6_get_datagram(&output, ICMP6_HDR_SIZE + size, 0,
163 addr, &ia->addr, IPPROTO_ICMPV6,
164 IPV6_DEFHLIM, NBA_SEARCH_ASCENT, TMO_FEVR) != E_OK)
165 return;
166
167 /* ICMP ヘッダを設定する。*/
168 icmp6h = GET_ICMP6_HDR(output, IF_IP6_ICMP6_HDR_OFFSET);
169 icmp6h->type = ICMP6_ECHO_REQUEST;
170 icmp6h->code = 0;
171 icmp6h->icmp6_id = htons(send_icmp6_id);
172 icmp6h->icmp6_seq= 0;
173
174 /* データを設定する。*/
175 sdu = GET_ICMP6_SDU(output, IF_IP6_ICMP6_HDR_OFFSET) + size;
176 for (ix = size; ix -- > 0; )
177 *-- sdu = ('0' + send_icmp6_id + ix) & 0xff;
178
179 /* チェックサムを計算する。*/
180 icmp6h->sum = 0;
181 icmp6h->sum = in6_cksum(output, IPPROTO_ICMPV6,
182 (uint8_t*)icmp6h - output->buf, ICMP6_HDR_SIZE + size);
183
184 /* 応答チェック用の変数を設定する。*/
185 curr_icmp6_id = send_icmp6_id ++;
186 curr_icmp6_size = size;
187
188 reply_count = 0;
189
190 syslog(LOG_NOTICE, "[PING6] send: TMO:%d, SIZE:%d, to: %s, from %s",
191 tmo, size,
192 ipv62str(NULL, addr), ipv62str(NULL, &ia->addr));
193
194 /* 送信後、現在の時間を記憶し、タイムアウトを設定する。*/
195 ip6_output(output, ipflags, TMO_FEVR);
196 NET_COUNT_MIB(icmp6_ifstat.ipv6IfIcmpOutMsgs, 1);
197 NET_COUNT_MIB(icmp6_ifstat.ipv6IfIcmpOutEchos, 1);
198
199 syscall(get_tim(&icmp6_start_time));
200 timeout(icmp6_reply_timeout, NULL, tmo * NET_TIMER_HZ);
201
202 }
203
204#endif /* of #ifdef USE_PING */
Note: See TracBrowser for help on using the repository browser.