Changeset 321 for EcnlProtoTool/trunk/asp3_dcre/tinet/netinet/ip_input.c
- Timestamp:
- Aug 23, 2017, 9:27:43 AM (7 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
EcnlProtoTool/trunk/asp3_dcre/tinet/netinet/ip_input.c
- Property svn:keywords deleted
-
Property svn:mime-type
changed from
text/x-csrc
totext/x-csrc;charset=UTF-8
r270 r321 5 5 * Tomakomai National College of Technology, JAPAN 6 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 責ãããã¨ï¼ 7 * 上記著作権者は,以下の (1)~(4) の条件か,Free Software Foundation 8 * によって公表されている GNU General Public License の Version 2 に記 9 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア 10 * を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下, 11 * 利用と呼ぶ)することを無償で許諾する. 12 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作 13 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー 14 * スコード中に含まれていること. 15 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使 16 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用 17 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記 18 * の無保証規定を掲載すること. 19 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使 20 * 用できない形で再配布する場合には,次の条件を満たすこと. 21 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著 22 * 作権表示,この利用条件および下記の無保証規定を掲載すること. 23 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損 24 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること. 36 25 * 37 * æ¬ã½ããã¦ã§ã¢ã¯ï¼ç¡ä¿è¨¼ã§æä¾ããã¦ãããã®ã§ããï¼ä¸è¨èä½æ¨©è 38 ã 39 * ãã³TOPPERSããã¸ã§ã¯ãã¯ï¼æ¬ã½ããã¦ã§ã¢ã«é¢ãã¦ï¼ãã®é©ç¨å¯è½æ§ã 40 * å«ãã¦ï¼ãããªãä¿è¨¼ãè¡ããªãï¼ã¾ãï¼æ¬ã½ããã¦ã§ã¢ã®å©ç¨ã«ããç´ 41 * æ¥çã¾ãã¯éæ¥çã«çãããããªãæ害ã«é¢ãã¦ãï¼ãã®è²¬ä»»ãè² ããªãï¼ 26 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お 27 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も 28 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直 29 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない. 42 30 * 43 31 * @(#) $Id$ … … 136 124 137 125 /* 138 * å¤æ°126 * 変数 139 127 */ 140 128 … … 142 130 143 131 /* 144 * SNMP 㮠管çæ 145 å ±ãã¼ã¹ (MIB) 132 * SNMP の 管理情報ベース (MIB) 146 133 */ 147 134 … … 153 140 154 141 /* 155 * ãã¼ã¿ã°ã©ã åæ§æãã¥ã¼142 * データグラム再構成キュー 156 143 */ 157 144 … … 160 147 161 148 /* 162 * é¢æ°149 * 関数 163 150 */ 164 151 … … 167 154 168 155 /* 169 * ip_get_frag_queue -- ãã¼ã¿ã°ã©ã åæ§æãã¥ã¼ãç²å¾ããã156 * ip_get_frag_queue -- データグラム再構成キューを獲得する。 170 157 */ 171 158 … … 177 164 178 165 /* 179 * ip_freef -- ãã¼ã¿ã°ã©ã åæ§æãã¥ã¼ã解æ¾ããã166 * ip_freef -- データグラム再構成キューを解放する。 180 167 */ 181 168 … … 195 182 196 183 /* 197 * ip_frag_timer -- ãã¼ã¿ã°ã©ã åæ§æ管çã¿ã¤ã184 * ip_frag_timer -- データグラム再構成管理タイマ 198 185 */ 199 186 … … 218 205 219 206 /* 220 * ip_reass -- ãã¼ã¿ã°ã©ã ãåæ§æããã207 * ip_reass -- データグラムを再構成する。 221 208 */ 222 209 … … 242 229 243 230 /* 244 * ID ãIPã¢ãã¬ã¹ãä¸ä½ãããã³ã«ãç°ãªããã©ã°ã¡ã³ãããã¥ã¼ã«æãã°ç ´æ£ããã231 * ID、IPアドレス、上位プロトコルが異なるフラグメントがキューに有れば破棄する。 245 232 */ 246 233 frag = ip_frag_queue[ix]; … … 259 246 NET_COUNT_IP4(net_count_ip4[NC_IP4_FRAG_IN], 1); 260 247 261 /* æ°è¦ã® ID ãªããå®å 262 ã¢ãã¬ã¹ãä¿åãã¦ããã¥ã¼ã«ã¤ãªãã*/ 248 /* 新規の ID なら、宛先アドレスを保存して、キューにつなぐ。*/ 263 249 frag_dst [ix] = dst; 264 250 ip_frag_queue[ix] = input; … … 266 252 input = NULL; 267 253 268 /* åæ§æã¿ã¤ã ã¢ã¦ããè¨å®ããã*/254 /* 再構成タイムアウトを設定する。*/ 269 255 ip4h->ttl = IP4_FRAGTTL; 270 256 } 271 257 else { 272 258 273 /* æ£ããä½ç½®ã«æ¿å 274 ¥ããã*/ 259 /* 正しい位置に挿入する。*/ 275 260 prev = NULL; 276 261 while (frag != NULL && … … 289 274 input = NULL; 290 275 291 /* å 292 ¨ã¦ã®ãã©ã°ã¡ã³ããæã£ã¦ããã調ã¹ãã*/ 276 /* 全てのフラグメントが揃っているか調べる。*/ 293 277 off = 0; 294 278 for (frag = ip_frag_queue[ix]; frag != NULL; frag = GET_QIP4_HDR(frag)->next) { 295 279 if ((IP4_FLGOFF_OFF(GET_QIP4_HDR(frag)->flg_off) << 3) != off) { 296 /* éä¸ãæãã¦ãããçµäºããã*/280 /* 途中が抜けていたら終了する。*/ 297 281 syscall(sig_sem(SEM_IP4_FRAG_QUEUE)); 298 282 return NULL; … … 302 286 } 303 287 304 /* å 305 ¨ã¦ã®ãã©ã°ã¡ã³ããæã£ããåæ§æããã*/ 288 /* 全てのフラグメントが揃ったら再構成する。*/ 306 289 if ((GET_QIP4_HDR(prev)->flg_off & IP4_MF) == 0) { 307 290 308 /* ãããã¯ã¼ã¯ãããã¡ãç²å¾ããã*/291 /* ネットワークバッファを獲得する。*/ 309 292 if (tget_net_buf(&input, IF_IP4_HDR_SIZE + off, TMO_IP4_FRAG_GET_NET_BUF) == E_OK) { 310 293 NET_COUNT_IP4(net_count_ip4[NC_IP4_FRAG_IN_OK], 1); 311 294 NET_COUNT_MIB(ip_stats.ipReasmOKs, 1); 312 295 313 /* IPv4 ããããè¨å®ããã*/296 /* IPv4 ヘッダを設定する。*/ 314 297 frag = ip_frag_queue[ix]; 315 298 ip4h = GET_IP4_HDR(input); … … 321 304 ip4h->flg_off = ip4h->id = 0; 322 305 323 /* ãã¼ã¿ã°ã©ã ãåæ§æããã*/306 /* データグラムを再構成する。*/ 324 307 off = IP4_HDR_SIZE; 325 308 while (frag != NULL) { … … 335 318 NET_COUNT_MIB(ip_stats.ipReasmFails, 1); 336 319 } 337 /* ãã¥ã¼ã空ã«ããã*/320 /* キューを空にする。*/ 338 321 ip_freef(ix); 339 322 } … … 346 329 347 330 /* 348 * ip_init -- IP ã®åæå331 * ip_init -- IP の初期化 349 332 */ 350 333 … … 356 339 357 340 /* 358 * ip_remove_options -- IPv4 ãããã®ãªãã·ã§ã³ãåé¤ãã以éãåã«è©°ããã341 * ip_remove_options -- IPv4 ヘッダのオプションを削除し、以降を前に詰める。 359 342 */ 360 343 … … 378 361 379 362 /* 380 * ip_input -- IP ã®å 381 ¥åé¢æ° 363 * ip_input -- IP の入力関数 382 364 */ 383 365 384 366 #if defined(SUPPORT_IPSEC) 385 367 /* 386 * TODO: IPsec SPãæ¤ç´¢ãããã±ããããªã¸ã§ã¯ããããã©ããå¤å®ããå¦çãå®è£ 387 ãã 368 * TODO: IPsec SPを検索し、パケットをリジェクトするかどうか判定する処理を実装する 388 369 */ 389 370 #endif /* of defined(SUPPORT_IPSEC) */ … … 401 382 NET_COUNT_MIB(ip_stats.ipInReceives, 1); 402 383 403 /* IP ãããã®é·ãããã§ãã¯ããã*/384 /* IP ヘッダの長さをチェックする。*/ 404 385 if (input->len < IF_IP4_HDR_SIZE) { 405 386 NET_COUNT_IP4(net_count_ip4[NC_IP4_IN_ERR_SHORT], 1); … … 411 392 hlen = GET_IP4_HDR_SIZE(ip4h); 412 393 413 /* ãã¼ã¸ã§ã³ããã§ãã¯ããã*/394 /* バージョンをチェックする。*/ 414 395 if (IP4_VHL_V(ip4h->vhl) != IPV4_VERSION) { 415 396 NET_COUNT_IP4(net_count_ip4[NC_IP4_IN_ERR_VER], 1); … … 418 399 } 419 400 420 /* IP ãããã®é·ãããã§ãã¯ãããªãã·ã§ã³ã解æããã*/401 /* IP ヘッダの長さをチェックし、オプションを解析する。*/ 421 402 if (hlen > IP4_HDR_SIZE) { 422 403 NET_COUNT_IP4(net_count_ip4[NC_IP4_OPTS], 1); 423 /* %%% ãªãã·ã§ã³ã®è§£æ%%% */424 } 425 426 /* ãã¼ã¿ã°ã©ã é·ããã§ãã¯ããã*/404 /* %%% オプションの解析 %%% */ 405 } 406 407 /* データグラム長をチェックする。*/ 427 408 if (ntohs(ip4h->len) > input->len - IF_HDR_SIZE) { 428 409 NET_COUNT_IP4(net_count_ip4[NC_IP4_IN_ERR_SHORT], 1); … … 431 412 } 432 413 433 /* ãããã¯ã¼ã¯ãããã¡ã®é·ãããã¼ã¿ã°ã©ã é·ã«èª¿æ´ããã*/414 /* ネットワークバッファの長さをデータグラム長に調整する。*/ 434 415 input->len = (uint16_t)(ntohs(ip4h->len) + IF_HDR_SIZE); 435 416 436 /* ãã§ãã¯ãµã ããã§ãã¯ããã*/417 /* チェックサムをチェックする。*/ 437 418 if (in_cksum(ip4h, hlen) != 0) { 438 419 NET_COUNT_IP4(net_count_ip4[NC_IP4_IN_ERR_CKSUM], 1); … … 441 422 } 442 423 443 /* IP ãããã®é·ãããã§ãã¯ããä¸ä½ã ICMP 以å¤ã¯ãªãã·ã§ã³ãæ¶å»ããã*/424 /* IP ヘッダの長さをチェックし、上位が ICMP 以外はオプションを消去する。*/ 444 425 if (hlen > IP4_HDR_SIZE && ip4h->proto != IPPROTO_ICMP) { 445 426 memset((uint8_t*)ip4h + IP4_HDR_SIZE, 0, hlen - IP4_HDR_SIZE); 446 427 } 447 428 448 /* éä¿¡å 449 ã¢ãã¬ã¹ããã§ãã¯ããã*/ 429 /* 送信元アドレスをチェックする。*/ 450 430 src = ntohl(ip4h->src); 451 431 bc = (ifp->in_ifaddr.addr & ifp->in_ifaddr.mask) | ~ifp->in_ifaddr.mask; … … 469 449 #endif /* of #ifdef SUPPORT_LOOP */ 470 450 471 /* ãã¦å 472 ã¢ãã¬ã¹ããã§ãã¯ããã*/ 451 /* あて先アドレスをチェックする。*/ 473 452 dst = ntohl(ip4h->dst); 474 453 … … 476 455 477 456 /* 478 * DHCP_CFG ãå®ç¾©ããã¦ããã¨ãã¯ããã¼ã«ã«ã¢ãã¬ã¹ãæªå®ç¾©ã®479 * å ´åããã¼ã¿ã°ã©ã ãåä¿¡ããã457 * DHCP_CFG が定義されているときは、ローカルアドレスが未定義の 458 * 場合もデータグラムを受信する。 480 459 */ 481 460 … … 511 490 #ifdef IP4_CFG_FRAGMENT 512 491 513 /* åå²ããã¦ããããã§ãã¯ããã*/492 /* 分割されているかチェックする。*/ 514 493 if (ntohs(ip4h->flg_off) & (IP4_MF | IP4_OFFMASK)) { 515 494 if ((input = ip_reass(ip4h, input)) == NULL) … … 519 498 #else /* of #ifdef IP4_CFG_FRAGMENT */ 520 499 521 /* åå²ããã¦ããããã§ãã¯ããã*/500 /* 分割されているかチェックする。*/ 522 501 if (ntohs(ip4h->flg_off) & (IP4_MF | IP4_OFFMASK)) { 523 502 T_IN4_ADDR src; … … 537 516 538 517 #if defined(SUPPORT_IPSEC) 539 /* ããã§ipsec4_in_rejectãå®è¡ãã*/518 /* ここでipsec4_in_rejectを実行する */ 540 519 if ((ip4h->proto != IPPROTO_ESP) && ipsec4_in_reject (input)) { 541 520 goto buf_rel; … … 543 522 #endif /* of #if defined(SUPPORT_IPSEC) */ 544 523 545 /* ãããã³ã«ãé¸æãã*/524 /* プロトコルを選択する */ 546 525 switch (ip4h->proto) { 547 526 … … 580 559 NET_COUNT_MIB(ip_stats.ipInUnknownProtos, 1); 581 560 582 /* ãã¼ã«ã« IP ã¢ãã¬ã¹ã«å±ãããã¼ã¿ã°ã©ã ã®ã¿ ICMP ã¨ã©ã¼ãéç¥ããã*/561 /* ローカル IP アドレスに届いたデータグラムのみ ICMP エラーを通知する。*/ 583 562 if (dst == ifp->in_ifaddr.addr) { 584 563 T_IN4_ADDR src; … … 589 568 } 590 569 /* 591 * icmp_error ã§ã¯ããããã¯ã¼ã¯ãããã¡ input ãè¿å´ããªãã®ã§592 * éæ¾ãã¦ããçµäºããã570 * icmp_error では、ネットワークバッファ input を返却しないので 571 * 開放してから終了する。 593 572 */ 594 573 break;
Note:
See TracChangeset
for help on using the changeset viewer.