Changeset 389 for azure_iot_hub/trunk/asp3_dcre/tinet/netinet/ip_input.c
- Timestamp:
- May 22, 2019, 10:03:37 PM (5 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
azure_iot_hub/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
r388 r389 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$ … … 141 129 142 130 /* 143 * å¤æ°131 * 変数 144 132 */ 145 133 … … 147 135 148 136 /* 149 * SNMP 㮠管çæ 150 å ±ãã¼ã¹ (MIB) 137 * SNMP の 管理情報ベース (MIB) 151 138 */ 152 139 … … 158 145 159 146 /* 160 * ãã¼ã¿ã°ã©ã åæ§æãã¥ã¼147 * データグラム再構成キュー 161 148 */ 162 149 … … 165 152 166 153 /* 167 * é¢æ°154 * 関数 168 155 */ 169 156 … … 172 159 173 160 /* 174 * ip_get_frag_queue -- ãã¼ã¿ã°ã©ã åæ§æãã¥ã¼ãç²å¾ããã161 * ip_get_frag_queue -- データグラム再構成キューを獲得する。 175 162 */ 176 163 … … 182 169 183 170 /* 184 * ip_freef -- ãã¼ã¿ã°ã©ã åæ§æãã¥ã¼ã解æ¾ããã171 * ip_freef -- データグラム再構成キューを解放する。 185 172 */ 186 173 … … 200 187 201 188 /* 202 * ip_frag_timer -- ãã¼ã¿ã°ã©ã åæ§æ管çã¿ã¤ã189 * ip_frag_timer -- データグラム再構成管理タイマ 203 190 */ 204 191 … … 223 210 224 211 /* 225 * ip_reass -- ãã¼ã¿ã°ã©ã ãåæ§æããã212 * ip_reass -- データグラムを再構成する。 226 213 */ 227 214 … … 247 234 248 235 /* 249 * ID ãIPã¢ãã¬ã¹ãä¸ä½ãããã³ã«ãç°ãªããã©ã°ã¡ã³ãããã¥ã¼ã«æãã°ç ´æ£ããã236 * ID、IPアドレス、上位プロトコルが異なるフラグメントがキューに有れば破棄する。 250 237 */ 251 238 frag = ip_frag_queue[ix]; … … 264 251 NET_COUNT_IP4(net_count_ip4[NC_IP4_FRAG_IN], 1); 265 252 266 /* æ°è¦ã® ID ãªããå®å 267 ã¢ãã¬ã¹ãä¿åãã¦ããã¥ã¼ã«ã¤ãªãã*/ 253 /* 新規の ID なら、宛先アドレスを保存して、キューにつなぐ。*/ 268 254 frag_dst [ix] = dst; 269 255 ip_frag_queue[ix] = input; … … 271 257 input = NULL; 272 258 273 /* åæ§æã¿ã¤ã ã¢ã¦ããè¨å®ããã*/259 /* 再構成タイムアウトを設定する。*/ 274 260 ip4h->ttl = IP4_FRAGTTL; 275 261 } 276 262 else { 277 263 278 /* æ£ããä½ç½®ã«æ¿å 279 ¥ããã*/ 264 /* 正しい位置に挿入する。*/ 280 265 prev = NULL; 281 266 while (frag != NULL && … … 294 279 input = NULL; 295 280 296 /* å 297 ¨ã¦ã®ãã©ã°ã¡ã³ããæã£ã¦ããã調ã¹ãã*/ 281 /* 全てのフラグメントが揃っているか調べる。*/ 298 282 off = 0; 299 283 for (frag = ip_frag_queue[ix]; frag != NULL; frag = GET_QIP4_HDR(frag)->next) { 300 284 if ((IP4_FLGOFF_OFF(GET_QIP4_HDR(frag)->flg_off) << 3) != off) { 301 /* éä¸ãæãã¦ãããçµäºããã*/285 /* 途中が抜けていたら終了する。*/ 302 286 syscall(sig_sem(SEM_IP4_FRAG_QUEUE)); 303 287 return NULL; … … 307 291 } 308 292 309 /* å 310 ¨ã¦ã®ãã©ã°ã¡ã³ããæã£ããåæ§æããã*/ 293 /* 全てのフラグメントが揃ったら再構成する。*/ 311 294 if ((GET_QIP4_HDR(prev)->flg_off & IP4_MF) == 0) { 312 295 313 /* ãããã¯ã¼ã¯ãããã¡ãç²å¾ããã*/296 /* ネットワークバッファを獲得する。*/ 314 297 if (tget_net_buf(&input, IF_IP4_HDR_SIZE + off, TMO_IP4_FRAG_GET_NET_BUF) == E_OK) { 315 298 NET_COUNT_IP4(net_count_ip4[NC_IP4_FRAG_IN_OK], 1); 316 299 NET_COUNT_MIB(ip_stats.ipReasmOKs, 1); 317 300 318 /* IPv4 ããããè¨å®ããã*/301 /* IPv4 ヘッダを設定する。*/ 319 302 frag = ip_frag_queue[ix]; 320 303 ip4h = GET_IP4_HDR(input); … … 326 309 ip4h->flg_off = ip4h->id = 0; 327 310 328 /* ãã¼ã¿ã°ã©ã ãåæ§æããã*/311 /* データグラムを再構成する。*/ 329 312 off = IP4_HDR_SIZE; 330 313 while (frag != NULL) { … … 340 323 NET_COUNT_MIB(ip_stats.ipReasmFails, 1); 341 324 } 342 /* ãã¥ã¼ã空ã«ããã*/325 /* キューを空にする。*/ 343 326 ip_freef(ix); 344 327 } … … 351 334 352 335 /* 353 * ip_init -- IP ã®åæå336 * ip_init -- IP の初期化 354 337 */ 355 338 … … 361 344 362 345 /* 363 * ip_remove_options -- IPv4 ãããã®ãªãã·ã§ã³ãåé¤ãã以éãåã«è©°ããã346 * ip_remove_options -- IPv4 ヘッダのオプションを削除し、以降を前に詰める。 364 347 */ 365 348 … … 385 368 386 369 /* 387 * ip_input -- IP ã®å 388 ¥åé¢æ° 370 * ip_input -- IP の入力関数 389 371 */ 390 372 391 373 #if defined(SUPPORT_IPSEC) 392 374 /* 393 * TODO: IPsec SPãæ¤ç´¢ãããã±ããããªã¸ã§ã¯ããããã©ããå¤å®ããå¦çãå®è£ 394 ãã 375 * TODO: IPsec SPを検索し、パケットをリジェクトするかどうか判定する処理を実装する 395 376 */ 396 377 #endif /* of defined(SUPPORT_IPSEC) */ … … 408 389 NET_COUNT_MIB(ip_stats.ipInReceives, 1); 409 390 410 /* IP ãããã®é·ãããã§ãã¯ããã*/391 /* IP ヘッダの長さをチェックする。*/ 411 392 if (input->len < IF_IP4_HDR_SIZE) { 412 393 NET_COUNT_IP4(net_count_ip4[NC_IP4_IN_ERR_SHORT], 1); … … 418 399 hlen = GET_IP4_HDR_SIZE(input); 419 400 420 /* ãã¼ã¸ã§ã³ããã§ãã¯ããã*/401 /* バージョンをチェックする。*/ 421 402 if (IP4_VHL_V(ip4h->vhl) != IPV4_VERSION) { 422 403 NET_COUNT_IP4(net_count_ip4[NC_IP4_IN_ERR_VER], 1); … … 425 406 } 426 407 427 /* IP ãããã®é·ãããã§ãã¯ãããªãã·ã§ã³ã解æããã*/408 /* IP ヘッダの長さをチェックし、オプションを解析する。*/ 428 409 if (hlen > IP4_HDR_SIZE) { 429 410 NET_COUNT_IP4(net_count_ip4[NC_IP4_OPTS], 1); 430 /* %%% ãªãã·ã§ã³ã®è§£æ%%% */431 } 432 433 /* ãã¼ã¿ã°ã©ã é·ããã§ãã¯ããã*/411 /* %%% オプションの解析 %%% */ 412 } 413 414 /* データグラム長をチェックする。*/ 434 415 if (ntohs(ip4h->len) > input->len - IF_HDR_SIZE) { 435 416 NET_COUNT_IP4(net_count_ip4[NC_IP4_IN_ERR_SHORT], 1); … … 438 419 } 439 420 440 /* ãããã¯ã¼ã¯ãããã¡ã®é·ãããã¼ã¿ã°ã©ã é·ã«èª¿æ´ããã*/421 /* ネットワークバッファの長さをデータグラム長に調整する。*/ 441 422 input->len = (uint16_t)(ntohs(ip4h->len) + IF_HDR_SIZE); 442 423 443 /* ãã§ãã¯ãµã ããã§ãã¯ããã*/424 /* チェックサムをチェックする。*/ 444 425 if (in_cksum(ip4h, hlen) != 0) { 445 426 NET_COUNT_IP4(net_count_ip4[NC_IP4_IN_ERR_CKSUM], 1); … … 448 429 } 449 430 450 /* IP ãããã®é·ãããã§ãã¯ããä¸ä½ã ICMP 以å¤ã¯ãªãã·ã§ã³ãæ¶å»ããã*/431 /* IP ヘッダの長さをチェックし、上位が ICMP 以外はオプションを消去する。*/ 451 432 if (hlen > IP4_HDR_SIZE && ip4h->proto != IPPROTO_ICMP) { 452 433 memset((uint8_t*)ip4h + IP4_HDR_SIZE, 0, hlen - IP4_HDR_SIZE); 453 434 } 454 435 455 /* éä¿¡å 456 ã¢ãã¬ã¹ããã§ãã¯ããã*/ 436 /* 送信元アドレスをチェックする。*/ 457 437 src = ntohl(ip4h->src); 458 438 bc = (ifp->in4_ifaddr.addr & ifp->in4_ifaddr.mask) | ~ifp->in4_ifaddr.mask; … … 476 456 #endif /* of #ifdef SUPPORT_LOOP */ 477 457 478 /* ãã¦å 479 ã¢ãã¬ã¹ããã§ãã¯ããã*/ 458 /* あて先アドレスをチェックする。*/ 480 459 dst = ntohl(ip4h->dst); 481 460 … … 483 462 484 463 /* 485 * DHCP_CFG ãå®ç¾©ããã¦ããã¨ãã¯ããã¼ã«ã«ã¢ãã¬ã¹ãæªå®ç¾©ã®486 * å ´åããã¼ã¿ã°ã©ã ãåä¿¡ããã464 * DHCP_CFG が定義されているときは、ローカルアドレスが未定義の 465 * 場合もデータグラムを受信する。 487 466 */ 488 467 … … 529 508 #ifdef IP4_CFG_FRAGMENT 530 509 531 /* åå²ããã¦ããããã§ãã¯ããã*/510 /* 分割されているかチェックする。*/ 532 511 if (ntohs(ip4h->flg_off) & (IP4_MF | IP4_OFFMASK)) { 533 512 if ((input = ip_reass(ip4h, input)) == NULL) … … 537 516 #else /* of #ifdef IP4_CFG_FRAGMENT */ 538 517 539 /* åå²ããã¦ããããã§ãã¯ããã*/518 /* 分割されているかチェックする。*/ 540 519 if (ntohs(ip4h->flg_off) & (IP4_MF | IP4_OFFMASK)) { 541 520 T_IN4_ADDR src; … … 555 534 556 535 #if defined(SUPPORT_IPSEC) 557 /* ããã§ipsec4_in_rejectãå®è¡ãã*/536 /* ここでipsec4_in_rejectを実行する */ 558 537 if ((ip4h->proto != IPPROTO_ESP) && ipsec4_in_reject (input)) { 559 538 goto buf_rel; … … 561 540 #endif /* of #if defined(SUPPORT_IPSEC) */ 562 541 563 /* ãããã³ã«ãé¸æãã*/542 /* プロトコルを選択する */ 564 543 switch (ip4h->proto) { 565 544 … … 607 586 NET_COUNT_MIB(ip_stats.ipInUnknownProtos, 1); 608 587 609 /* ãã¼ã«ã« IP ã¢ãã¬ã¹ã«å±ãããã¼ã¿ã°ã©ã ã®ã¿ ICMP ã¨ã©ã¼ãéç¥ããã*/588 /* ローカル IP アドレスに届いたデータグラムのみ ICMP エラーを通知する。*/ 610 589 if (dst == ifp->in4_ifaddr.addr) { 611 590 T_IN4_ADDR src; … … 616 595 } 617 596 /* 618 * icmp_error ã§ã¯ããããã¯ã¼ã¯ãããã¡ input ãè¿å´ããªãã®ã§619 * éæ¾ãã¦ããçµäºããã597 * icmp_error では、ネットワークバッファ input を返却しないので 598 * 開放してから終了する。 620 599 */ 621 600 break;
Note:
See TracChangeset
for help on using the changeset viewer.