if_gre.c (164033) | if_gre.c (171056) |
---|---|
1/* $NetBSD: if_gre.c,v 1.49 2003/12/11 00:22:29 itojun Exp $ */ | 1/* $NetBSD: if_gre.c,v 1.49 2003/12/11 00:22:29 itojun Exp $ */ |
2/* $FreeBSD: head/sys/net/if_gre.c 164033 2006-11-06 13:42:10Z rwatson $ */ | 2/* $FreeBSD: head/sys/net/if_gre.c 171056 2007-06-26 23:01:01Z rwatson $ */ |
3 4/*- 5 * Copyright (c) 1998 The NetBSD Foundation, Inc. 6 * All rights reserved. 7 * 8 * This code is derived from software contributed to The NetBSD Foundation 9 * by Heiko W.Rupp <hwr@pilhuhn.de> 10 * --- 438 unchanged lines hidden (view full) --- 449 switch (cmd) { 450 case SIOCSIFADDR: 451 ifp->if_flags |= IFF_UP; 452 break; 453 case SIOCSIFDSTADDR: 454 break; 455 case SIOCSIFFLAGS: 456 /* | 3 4/*- 5 * Copyright (c) 1998 The NetBSD Foundation, Inc. 6 * All rights reserved. 7 * 8 * This code is derived from software contributed to The NetBSD Foundation 9 * by Heiko W.Rupp <hwr@pilhuhn.de> 10 * --- 438 unchanged lines hidden (view full) --- 449 switch (cmd) { 450 case SIOCSIFADDR: 451 ifp->if_flags |= IFF_UP; 452 break; 453 case SIOCSIFDSTADDR: 454 break; 455 case SIOCSIFFLAGS: 456 /* |
457 * XXXRW: Isn't this suser() redundant to the ifnet layer 458 * check? | 457 * XXXRW: Isn't this priv_check() redundant to the ifnet 458 * layer check? |
459 */ 460 if ((error = priv_check(curthread, PRIV_NET_SETIFFLAGS)) != 0) 461 break; 462 if ((ifr->ifr_flags & IFF_LINK0) != 0) 463 sc->g_proto = IPPROTO_GRE; 464 else 465 sc->g_proto = IPPROTO_MOBILE; 466 if ((ifr->ifr_flags & IFF_LINK2) != 0) 467 sc->wccp_ver = WCCP_V2; 468 else 469 sc->wccp_ver = WCCP_V1; 470 goto recompute; 471 case SIOCSIFMTU: 472 /* | 459 */ 460 if ((error = priv_check(curthread, PRIV_NET_SETIFFLAGS)) != 0) 461 break; 462 if ((ifr->ifr_flags & IFF_LINK0) != 0) 463 sc->g_proto = IPPROTO_GRE; 464 else 465 sc->g_proto = IPPROTO_MOBILE; 466 if ((ifr->ifr_flags & IFF_LINK2) != 0) 467 sc->wccp_ver = WCCP_V2; 468 else 469 sc->wccp_ver = WCCP_V1; 470 goto recompute; 471 case SIOCSIFMTU: 472 /* |
473 * XXXRW: Isn't this suser() redundant to the ifnet layer 474 * check? | 473 * XXXRW: Isn't this priv_check() redundant to the ifnet 474 * layer check? |
475 */ 476 if ((error = priv_check(curthread, PRIV_NET_SETIFMTU)) != 0) 477 break; 478 if (ifr->ifr_mtu < 576) { 479 error = EINVAL; 480 break; 481 } 482 ifp->if_mtu = ifr->ifr_mtu; 483 break; 484 case SIOCGIFMTU: 485 ifr->ifr_mtu = GRE2IFP(sc)->if_mtu; 486 break; 487 case SIOCADDMULTI: 488 /* | 475 */ 476 if ((error = priv_check(curthread, PRIV_NET_SETIFMTU)) != 0) 477 break; 478 if (ifr->ifr_mtu < 576) { 479 error = EINVAL; 480 break; 481 } 482 ifp->if_mtu = ifr->ifr_mtu; 483 break; 484 case SIOCGIFMTU: 485 ifr->ifr_mtu = GRE2IFP(sc)->if_mtu; 486 break; 487 case SIOCADDMULTI: 488 /* |
489 * XXXRW: Isn't this suser() redundant to the ifnet layer 490 * check? | 489 * XXXRW: Isn't this priv_checkr() redundant to the ifnet 490 * layer check? |
491 */ 492 if ((error = priv_check(curthread, PRIV_NET_ADDMULTI)) != 0) 493 break; 494 if (ifr == 0) { 495 error = EAFNOSUPPORT; 496 break; 497 } 498 switch (ifr->ifr_addr.sa_family) { --- 7 unchanged lines hidden (view full) --- 506#endif 507 default: 508 error = EAFNOSUPPORT; 509 break; 510 } 511 break; 512 case SIOCDELMULTI: 513 /* | 491 */ 492 if ((error = priv_check(curthread, PRIV_NET_ADDMULTI)) != 0) 493 break; 494 if (ifr == 0) { 495 error = EAFNOSUPPORT; 496 break; 497 } 498 switch (ifr->ifr_addr.sa_family) { --- 7 unchanged lines hidden (view full) --- 506#endif 507 default: 508 error = EAFNOSUPPORT; 509 break; 510 } 511 break; 512 case SIOCDELMULTI: 513 /* |
514 * XXXRW: Isn't this suser() redundant to the ifnet layer 515 * check? | 514 * XXXRW: Isn't this priv_check() redundant to the ifnet 515 * layer check? |
516 */ 517 if ((error = priv_check(curthread, PRIV_NET_DELIFGROUP)) != 0) 518 break; 519 if (ifr == 0) { 520 error = EAFNOSUPPORT; 521 break; 522 } 523 switch (ifr->ifr_addr.sa_family) { --- 7 unchanged lines hidden (view full) --- 531#endif 532 default: 533 error = EAFNOSUPPORT; 534 break; 535 } 536 break; 537 case GRESPROTO: 538 /* | 516 */ 517 if ((error = priv_check(curthread, PRIV_NET_DELIFGROUP)) != 0) 518 break; 519 if (ifr == 0) { 520 error = EAFNOSUPPORT; 521 break; 522 } 523 switch (ifr->ifr_addr.sa_family) { --- 7 unchanged lines hidden (view full) --- 531#endif 532 default: 533 error = EAFNOSUPPORT; 534 break; 535 } 536 break; 537 case GRESPROTO: 538 /* |
539 * XXXRW: Isn't this suser() redundant to the ifnet layer 540 * check? | 539 * XXXRW: Isn't this priv_check() redundant to the ifnet 540 * layer check? |
541 */ 542 if ((error = priv_check(curthread, PRIV_NET_GRE)) != 0) 543 break; 544 sc->g_proto = ifr->ifr_flags; 545 switch (sc->g_proto) { 546 case IPPROTO_GRE: 547 ifp->if_flags |= IFF_LINK0; 548 break; --- 73 unchanged lines hidden (view full) --- 622 si.sin_family = AF_INET; 623 si.sin_len = sizeof(struct sockaddr_in); 624 si.sin_addr.s_addr = sc->g_dst.s_addr; 625 sa = sintosa(&si); 626 ifr->ifr_addr = *sa; 627 break; 628 case SIOCSIFPHYADDR: 629 /* | 541 */ 542 if ((error = priv_check(curthread, PRIV_NET_GRE)) != 0) 543 break; 544 sc->g_proto = ifr->ifr_flags; 545 switch (sc->g_proto) { 546 case IPPROTO_GRE: 547 ifp->if_flags |= IFF_LINK0; 548 break; --- 73 unchanged lines hidden (view full) --- 622 si.sin_family = AF_INET; 623 si.sin_len = sizeof(struct sockaddr_in); 624 si.sin_addr.s_addr = sc->g_dst.s_addr; 625 sa = sintosa(&si); 626 ifr->ifr_addr = *sa; 627 break; 628 case SIOCSIFPHYADDR: 629 /* |
630 * XXXRW: Isn't this suser() redundant to the ifnet layer 631 * check? | 630 * XXXRW: Isn't this priv_check() redundant to the ifnet 631 * layer check? |
632 */ 633 if ((error = priv_check(curthread, PRIV_NET_SETIFPHYS)) != 0) 634 break; 635 if (aifr->ifra_addr.sin_family != AF_INET || 636 aifr->ifra_dstaddr.sin_family != AF_INET) { 637 error = EAFNOSUPPORT; 638 break; 639 } 640 if (aifr->ifra_addr.sin_len != sizeof(si) || 641 aifr->ifra_dstaddr.sin_len != sizeof(si)) { 642 error = EINVAL; 643 break; 644 } 645 sc->g_src = aifr->ifra_addr.sin_addr; 646 sc->g_dst = aifr->ifra_dstaddr.sin_addr; 647 goto recompute; 648 case SIOCSLIFPHYADDR: 649 /* | 632 */ 633 if ((error = priv_check(curthread, PRIV_NET_SETIFPHYS)) != 0) 634 break; 635 if (aifr->ifra_addr.sin_family != AF_INET || 636 aifr->ifra_dstaddr.sin_family != AF_INET) { 637 error = EAFNOSUPPORT; 638 break; 639 } 640 if (aifr->ifra_addr.sin_len != sizeof(si) || 641 aifr->ifra_dstaddr.sin_len != sizeof(si)) { 642 error = EINVAL; 643 break; 644 } 645 sc->g_src = aifr->ifra_addr.sin_addr; 646 sc->g_dst = aifr->ifra_dstaddr.sin_addr; 647 goto recompute; 648 case SIOCSLIFPHYADDR: 649 /* |
650 * XXXRW: Isn't this suser() redundant to the ifnet layer 651 * check? | 650 * XXXRW: Isn't this priv_check() redundant to the ifnet 651 * layer check? |
652 */ 653 if ((error = priv_check(curthread, PRIV_NET_SETIFPHYS)) != 0) 654 break; 655 if (lifr->addr.ss_family != AF_INET || 656 lifr->dstaddr.ss_family != AF_INET) { 657 error = EAFNOSUPPORT; 658 break; 659 } 660 if (lifr->addr.ss_len != sizeof(si) || 661 lifr->dstaddr.ss_len != sizeof(si)) { 662 error = EINVAL; 663 break; 664 } 665 sc->g_src = (satosin(&lifr->addr))->sin_addr; 666 sc->g_dst = 667 (satosin(&lifr->dstaddr))->sin_addr; 668 goto recompute; 669 case SIOCDIFPHYADDR: 670 /* | 652 */ 653 if ((error = priv_check(curthread, PRIV_NET_SETIFPHYS)) != 0) 654 break; 655 if (lifr->addr.ss_family != AF_INET || 656 lifr->dstaddr.ss_family != AF_INET) { 657 error = EAFNOSUPPORT; 658 break; 659 } 660 if (lifr->addr.ss_len != sizeof(si) || 661 lifr->dstaddr.ss_len != sizeof(si)) { 662 error = EINVAL; 663 break; 664 } 665 sc->g_src = (satosin(&lifr->addr))->sin_addr; 666 sc->g_dst = 667 (satosin(&lifr->dstaddr))->sin_addr; 668 goto recompute; 669 case SIOCDIFPHYADDR: 670 /* |
671 * XXXRW: Isn't this suser() redundant to the ifnet layer 672 * check? | 671 * XXXRW: Isn't this priv_check() redundant to the ifnet 672 * layer check? |
673 */ 674 if ((error = priv_check(curthread, PRIV_NET_SETIFPHYS)) != 0) 675 break; 676 sc->g_src.s_addr = INADDR_ANY; 677 sc->g_dst.s_addr = INADDR_ANY; 678 goto recompute; 679 case SIOCGLIFPHYADDR: 680 if (sc->g_src.s_addr == INADDR_ANY || --- 181 unchanged lines hidden --- | 673 */ 674 if ((error = priv_check(curthread, PRIV_NET_SETIFPHYS)) != 0) 675 break; 676 sc->g_src.s_addr = INADDR_ANY; 677 sc->g_dst.s_addr = INADDR_ANY; 678 goto recompute; 679 case SIOCGLIFPHYADDR: 680 if (sc->g_src.s_addr == INADDR_ANY || --- 181 unchanged lines hidden --- |