diff --git a/ifenslave.c b/ifenslave.c deleted file mode 100644 index 62a285e..0000000 --- a/ifenslave.c +++ /dev/null @@ -1,1103 +0,0 @@ -/* Mode: C; - * ifenslave.c: Configure network interfaces for parallel routing. - * - * This program controls the Linux implementation of running multiple - * network interfaces in parallel. - * - * Author: Donald Becker - * Copyright 1994-1996 Donald Becker - * - * This program is free software; you can redistribute it - * and/or modify it under the terms of the GNU General Public - * License as published by the Free Software Foundation. - * - * The author may be reached as becker@CESDIS.gsfc.nasa.gov, or C/O - * Center of Excellence in Space Data and Information Sciences - * Code 930.5, Goddard Space Flight Center, Greenbelt MD 20771 - * - * Changes : - * - 2000/10/02 Willy Tarreau : - * - few fixes. Master's MAC address is now correctly taken from - * the first device when not previously set ; - * - detach support : call BOND_RELEASE to detach an enslaved interface. - * - give a mini-howto from command-line help : # ifenslave -h - * - * - 2001/02/16 Chad N. Tindel : - * - Master is now brought down before setting the MAC address. In - * the 2.4 kernel you can't change the MAC address while the device is - * up because you get EBUSY. - * - * - 2001/09/13 Takao Indoh - * - Added the ability to change the active interface on a mode 1 bond - * at runtime. - * - * - 2001/10/23 Chad N. Tindel : - * - No longer set the MAC address of the master. The bond device will - * take care of this itself - * - Try the SIOC*** versions of the bonding ioctls before using the - * old versions - * - 2002/02/18 Erik Habbinga : - * - ifr2.ifr_flags was not initialized in the hwaddr_notset case, - * SIOCGIFFLAGS now called before hwaddr_notset test - * - * - 2002/10/31 Tony Cureington : - * - If the master does not have a hardware address when the first slave - * is enslaved, the master is assigned the hardware address of that - * slave - there is a comment in bonding.c stating "ifenslave takes - * care of this now." This corrects the problem of slaves having - * different hardware addresses in active-backup mode when - * multiple interfaces are specified on a single ifenslave command - * (ifenslave bond0 eth0 eth1). - * - * - 2003/03/18 - Tsippy Mendelson and - * Shmulik Hen - * - Moved setting the slave's mac address and openning it, from - * the application to the driver. This enables support of modes - * that need to use the unique mac address of each slave. - * The driver also takes care of closing the slave and restoring its - * original mac address upon release. - * In addition, block possibility of enslaving before the master is up. - * This prevents putting the system in an undefined state. - * - * - 2003/05/01 - Amir Noam - * - Added ABI version control to restore compatibility between - * new/old ifenslave and new/old bonding. - * - Prevent adding an adapter that is already a slave. - * Fixes the problem of stalling the transmission and leaving - * the slave in a down state. - * - * - 2003/05/01 - Shmulik Hen - * - Prevent enslaving if the bond device is down. - * Fixes the problem of leaving the system in unstable state and - * halting when trying to remove the module. - * - Close socket on all abnormal exists. - * - Add versioning scheme that follows that of the bonding driver. - * current version is 1.0.0 as a base line. - * - * - 2003/05/22 - Jay Vosburgh - * - ifenslave -c was broken; it's now fixed - * - Fixed problem with routes vanishing from master during enslave - * processing. - * - * - 2003/05/27 - Amir Noam - * - Fix backward compatibility issues: - * For drivers not using ABI versions, slave was set down while - * it should be left up before enslaving. - * Also, master was not set down and the default set_mac_address() - * would fail and generate an error message in the system log. - * - For opt_c: slave should not be set to the master's setting - * while it is running. It was already set during enslave. To - * simplify things, it is now handled separately. - * - * - 2003/12/01 - Shmulik Hen - * - Code cleanup and style changes - * set version to 1.1.0 - */ - -#define APP_VERSION "1.1.0" -#define APP_RELDATE "December 1, 2003" -#define APP_NAME "ifenslave" - -static char *version = -APP_NAME ".c:v" APP_VERSION " (" APP_RELDATE ")\n" -"o Donald Becker (becker@cesdis.gsfc.nasa.gov).\n" -"o Detach support added on 2000/10/02 by Willy Tarreau (willy at meta-x.org).\n" -"o 2.4 kernel support added on 2001/02/16 by Chad N. Tindel\n" -" (ctindel at ieee dot org).\n"; - -static const char *usage_msg = -"Usage: ifenslave [-f] [...]\n" -" ifenslave -d [...]\n" -" ifenslave -c \n" -" ifenslave --help\n"; - -static const char *help_msg = -"\n" -" To create a bond device, simply follow these three steps :\n" -" - ensure that the required drivers are properly loaded :\n" -" # modprobe bonding ; modprobe <3c59x|eepro100|pcnet32|tulip|...>\n" -" - assign an IP address to the bond device :\n" -" # ifconfig bond0 netmask broadcast \n" -" - attach all the interfaces you need to the bond device :\n" -" # ifenslave [{-f|--force}] bond0 eth0 [eth1 [eth2]...]\n" -" If bond0 didn't have a MAC address, it will take eth0's. Then, all\n" -" interfaces attached AFTER this assignment will get the same MAC addr.\n" -" (except for ALB/TLB modes)\n" -"\n" -" To set the bond device down and automatically release all the slaves :\n" -" # ifconfig bond0 down\n" -"\n" -" To detach a dead interface without setting the bond device down :\n" -" # ifenslave {-d|--detach} bond0 eth0 [eth1 [eth2]...]\n" -"\n" -" To change active slave :\n" -" # ifenslave {-c|--change-active} bond0 eth0\n" -"\n" -" To show master interface info\n" -" # ifenslave bond0\n" -"\n" -" To show all interfaces info\n" -" # ifenslave {-a|--all-interfaces}\n" -"\n" -" To be more verbose\n" -" # ifenslave {-v|--verbose} ...\n" -"\n" -" # ifenslave {-u|--usage} Show usage\n" -" # ifenslave {-V|--version} Show version\n" -" # ifenslave {-h|--help} This message\n" -"\n"; - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -typedef unsigned long long u64; /* hack, so we may include kernel's ethtool.h */ -typedef __uint32_t u32; /* ditto */ -typedef __uint16_t u16; /* ditto */ -typedef __uint8_t u8; /* ditto */ -#include - -struct option longopts[] = { - /* { name has_arg *flag val } */ - {"all-interfaces", 0, 0, 'a'}, /* Show all interfaces. */ - {"change-active", 0, 0, 'c'}, /* Change the active slave. */ - {"detach", 0, 0, 'd'}, /* Detach a slave interface. */ - {"force", 0, 0, 'f'}, /* Force the operation. */ - {"help", 0, 0, 'h'}, /* Give help */ - {"usage", 0, 0, 'u'}, /* Give usage */ - {"verbose", 0, 0, 'v'}, /* Report each action taken. */ - {"version", 0, 0, 'V'}, /* Emit version information. */ - { 0, 0, 0, 0} -}; - -/* Command-line flags. */ -unsigned int -opt_a = 0, /* Show-all-interfaces flag. */ -opt_c = 0, /* Change-active-slave flag. */ -opt_d = 0, /* Detach a slave interface. */ -opt_f = 0, /* Force the operation. */ -opt_h = 0, /* Help */ -opt_u = 0, /* Usage */ -opt_v = 0, /* Verbose flag. */ -opt_V = 0; /* Version */ - -int skfd = -1; /* AF_INET socket for ioctl() calls.*/ -int abi_ver = 0; /* userland - kernel ABI version */ -int hwaddr_set = 0; /* Master's hwaddr is set */ -int saved_errno; - -struct ifreq master_mtu, master_flags, master_hwaddr; -struct ifreq slave_mtu, slave_flags, slave_hwaddr; - -struct dev_ifr { - struct ifreq *req_ifr; - char *req_name; - int req_type; -}; - -struct dev_ifr master_ifra[] = { - {&master_mtu, "SIOCGIFMTU", SIOCGIFMTU}, - {&master_flags, "SIOCGIFFLAGS", SIOCGIFFLAGS}, - {&master_hwaddr, "SIOCGIFHWADDR", SIOCGIFHWADDR}, - {NULL, "", 0} -}; - -struct dev_ifr slave_ifra[] = { - {&slave_mtu, "SIOCGIFMTU", SIOCGIFMTU}, - {&slave_flags, "SIOCGIFFLAGS", SIOCGIFFLAGS}, - {&slave_hwaddr, "SIOCGIFHWADDR", SIOCGIFHWADDR}, - {NULL, "", 0} -}; - -static void if_print(char *ifname); -static int get_drv_info(char *master_ifname); -static int get_if_settings(char *ifname, struct dev_ifr ifra[]); -static int get_slave_flags(char *slave_ifname); -static int set_master_hwaddr(char *master_ifname, struct sockaddr *hwaddr); -static int set_slave_hwaddr(char *slave_ifname, struct sockaddr *hwaddr); -static int set_slave_mtu(char *slave_ifname, int mtu); -static int set_if_flags(char *ifname, short flags); -static int set_if_up(char *ifname, short flags); -static int set_if_down(char *ifname, short flags); -static int clear_if_addr(char *ifname); -static int set_if_addr(char *master_ifname, char *slave_ifname); -static int change_active(char *master_ifname, char *slave_ifname); -static int enslave(char *master_ifname, char *slave_ifname); -static int release(char *master_ifname, char *slave_ifname); -#define v_print(fmt, args...) \ - if (opt_v) \ - fprintf(stderr, fmt, ## args ) - -int main(int argc, char *argv[]) -{ - char **spp, *master_ifname, *slave_ifname; - int c, i, rv; - int res = 0; - int exclusive = 0; - - while ((c = getopt_long(argc, argv, "acdfhuvV", longopts, 0)) != EOF) { - switch (c) { - case 'a': opt_a++; exclusive++; break; - case 'c': opt_c++; exclusive++; break; - case 'd': opt_d++; exclusive++; break; - case 'f': opt_f++; exclusive++; break; - case 'h': opt_h++; exclusive++; break; - case 'u': opt_u++; exclusive++; break; - case 'v': opt_v++; break; - case 'V': opt_V++; exclusive++; break; - - case '?': - fprintf(stderr, usage_msg); - res = 2; - goto out; - } - } - - /* options check */ - if (exclusive > 1) { - fprintf(stderr, usage_msg); - res = 2; - goto out; - } - - if (opt_v || opt_V) { - printf(version); - if (opt_V) { - res = 0; - goto out; - } - } - - if (opt_u) { - printf(usage_msg); - res = 0; - goto out; - } - - if (opt_h) { - printf(usage_msg); - printf(help_msg); - res = 0; - goto out; - } - - /* Open a basic socket */ - if ((skfd = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { - perror("socket"); - res = 1; - goto out; - } - - if (opt_a) { - if (optind == argc) { - /* No remaining args */ - /* show all interfaces */ - if_print((char *)NULL); - goto out; - } else { - /* Just show usage */ - fprintf(stderr, usage_msg); - res = 2; - goto out; - } - } - - /* Copy the interface name */ - spp = argv + optind; - master_ifname = *spp++; - - if (master_ifname == NULL) { - fprintf(stderr, usage_msg); - res = 2; - goto out; - } - - /* exchange abi version with bonding module */ - res = get_drv_info(master_ifname); - if (res) { - fprintf(stderr, - "Master '%s': Error: handshake with driver failed. " - "Aborting\n", - master_ifname); - goto out; - } - - slave_ifname = *spp++; - - if (slave_ifname == NULL) { - if (opt_d || opt_c) { - fprintf(stderr, usage_msg); - res = 2; - goto out; - } - - /* A single arg means show the - * configuration for this interface - */ - if_print(master_ifname); - goto out; - } - - res = get_if_settings(master_ifname, master_ifra); - if (res) { - /* Probably a good reason not to go on */ - fprintf(stderr, - "Master '%s': Error: get settings failed: %s. " - "Aborting\n", - master_ifname, strerror(res)); - goto out; - } - - /* check if master is indeed a master; - * if not then fail any operation - */ - if (!(master_flags.ifr_flags & IFF_MASTER)) { - fprintf(stderr, - "Illegal operation; the specified interface '%s' " - "is not a master. Aborting\n", - master_ifname); - res = 1; - goto out; - } - - /* check if master is up; if not then fail any operation */ - if (!(master_flags.ifr_flags & IFF_UP)) { - fprintf(stderr, - "Illegal operation; the specified master interface " - "'%s' is not up.\n", - master_ifname); - res = 1; - goto out; - } - - /* Only for enslaving */ - if (!opt_c && !opt_d) { - sa_family_t master_family = master_hwaddr.ifr_hwaddr.sa_family; - unsigned char *hwaddr = - (unsigned char *)master_hwaddr.ifr_hwaddr.sa_data; - - /* The family '1' is ARPHRD_ETHER for ethernet. */ - if (master_family != 1 && !opt_f) { - fprintf(stderr, - "Illegal operation: The specified master " - "interface '%s' is not ethernet-like.\n " - "This program is designed to work with " - "ethernet-like network interfaces.\n " - "Use the '-f' option to force the " - "operation.\n", - master_ifname); - res = 1; - goto out; - } - - /* Check master's hw addr */ - for (i = 0; i < 6; i++) { - if (hwaddr[i] != 0) { - hwaddr_set = 1; - break; - } - } - - if (hwaddr_set) { - v_print("current hardware address of master '%s' " - "is %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x, " - "type %d\n", - master_ifname, - hwaddr[0], hwaddr[1], - hwaddr[2], hwaddr[3], - hwaddr[4], hwaddr[5], - master_family); - } - } - - /* Accepts only one slave */ - if (opt_c) { - /* change active slave */ - res = get_slave_flags(slave_ifname); - if (res) { - fprintf(stderr, - "Slave '%s': Error: get flags failed. " - "Aborting\n", - slave_ifname); - goto out; - } - res = change_active(master_ifname, slave_ifname); - if (res) { - fprintf(stderr, - "Master '%s', Slave '%s': Error: " - "Change active failed\n", - master_ifname, slave_ifname); - } - } else { - /* Accept multiple slaves */ - do { - if (opt_d) { - /* detach a slave interface from the master */ - rv = get_slave_flags(slave_ifname); - if (rv) { - /* Can't work with this slave. */ - /* remember the error and skip it*/ - fprintf(stderr, - "Slave '%s': Error: get flags " - "failed. Skipping\n", - slave_ifname); - res = rv; - continue; - } - rv = release(master_ifname, slave_ifname); - if (rv) { - fprintf(stderr, - "Master '%s', Slave '%s': Error: " - "Release failed\n", - master_ifname, slave_ifname); - res = rv; - } - } else { - /* attach a slave interface to the master */ - rv = get_if_settings(slave_ifname, slave_ifra); - if (rv) { - /* Can't work with this slave. */ - /* remember the error and skip it*/ - fprintf(stderr, - "Slave '%s': Error: get " - "settings failed: %s. " - "Skipping\n", - slave_ifname, strerror(rv)); - res = rv; - continue; - } - rv = enslave(master_ifname, slave_ifname); - if (rv) { - fprintf(stderr, - "Master '%s', Slave '%s': Error: " - "Enslave failed\n", - master_ifname, slave_ifname); - res = rv; - } - } - } while ((slave_ifname = *spp++) != NULL); - } - -out: - if (skfd >= 0) { - close(skfd); - } - - return res; -} - -static short mif_flags; - -/* Get the inteface configuration from the kernel. */ -static int if_getconfig(char *ifname) -{ - struct ifreq ifr; - int metric, mtu; /* Parameters of the master interface. */ - struct sockaddr dstaddr, broadaddr, netmask; - unsigned char *hwaddr; - - strcpy(ifr.ifr_name, ifname); - if (ioctl(skfd, SIOCGIFFLAGS, &ifr) < 0) - return -1; - mif_flags = ifr.ifr_flags; - printf("The result of SIOCGIFFLAGS on %s is %x.\n", - ifname, ifr.ifr_flags); - - strcpy(ifr.ifr_name, ifname); - if (ioctl(skfd, SIOCGIFADDR, &ifr) < 0) - return -1; - printf("The result of SIOCGIFADDR is %2.2x.%2.2x.%2.2x.%2.2x.\n", - ifr.ifr_addr.sa_data[0], ifr.ifr_addr.sa_data[1], - ifr.ifr_addr.sa_data[2], ifr.ifr_addr.sa_data[3]); - - strcpy(ifr.ifr_name, ifname); - if (ioctl(skfd, SIOCGIFHWADDR, &ifr) < 0) - return -1; - - /* Gotta convert from 'char' to unsigned for printf(). */ - hwaddr = (unsigned char *)ifr.ifr_hwaddr.sa_data; - printf("The result of SIOCGIFHWADDR is type %d " - "%2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x.\n", - ifr.ifr_hwaddr.sa_family, hwaddr[0], hwaddr[1], - hwaddr[2], hwaddr[3], hwaddr[4], hwaddr[5]); - - strcpy(ifr.ifr_name, ifname); - if (ioctl(skfd, SIOCGIFMETRIC, &ifr) < 0) { - metric = 0; - } else - metric = ifr.ifr_metric; - - strcpy(ifr.ifr_name, ifname); - if (ioctl(skfd, SIOCGIFMTU, &ifr) < 0) - mtu = 0; - else - mtu = ifr.ifr_mtu; - - strcpy(ifr.ifr_name, ifname); - if (ioctl(skfd, SIOCGIFDSTADDR, &ifr) < 0) { - memset(&dstaddr, 0, sizeof(struct sockaddr)); - } else - dstaddr = ifr.ifr_dstaddr; - - strcpy(ifr.ifr_name, ifname); - if (ioctl(skfd, SIOCGIFBRDADDR, &ifr) < 0) { - memset(&broadaddr, 0, sizeof(struct sockaddr)); - } else - broadaddr = ifr.ifr_broadaddr; - - strcpy(ifr.ifr_name, ifname); - if (ioctl(skfd, SIOCGIFNETMASK, &ifr) < 0) { - memset(&netmask, 0, sizeof(struct sockaddr)); - } else - netmask = ifr.ifr_netmask; - - return 0; -} - -static void if_print(char *ifname) -{ - char buff[1024]; - struct ifconf ifc; - struct ifreq *ifr; - int i; - - if (ifname == (char *)NULL) { - ifc.ifc_len = sizeof(buff); - ifc.ifc_buf = buff; - if (ioctl(skfd, SIOCGIFCONF, &ifc) < 0) { - perror("SIOCGIFCONF failed"); - return; - } - - ifr = ifc.ifc_req; - for (i = ifc.ifc_len / sizeof(struct ifreq); --i >= 0; ifr++) { - if (if_getconfig(ifr->ifr_name) < 0) { - fprintf(stderr, - "%s: unknown interface.\n", - ifr->ifr_name); - continue; - } - - if (((mif_flags & IFF_UP) == 0) && !opt_a) continue; - /*ife_print(&ife);*/ - } - } else { - if (if_getconfig(ifname) < 0) { - fprintf(stderr, - "%s: unknown interface.\n", ifname); - } - } -} - -static int get_drv_info(char *master_ifname) -{ - struct ifreq ifr; - struct ethtool_drvinfo info; - char *endptr; - - memset(&ifr, 0, sizeof(ifr)); - strncpy(ifr.ifr_name, master_ifname, IFNAMSIZ); - ifr.ifr_data = (caddr_t)&info; - - info.cmd = ETHTOOL_GDRVINFO; - strncpy(info.driver, "ifenslave", 32); - snprintf(info.fw_version, 32, "%d", BOND_ABI_VERSION); - - if (ioctl(skfd, SIOCETHTOOL, &ifr) < 0) { - if (errno == EOPNOTSUPP) { - goto out; - } - - saved_errno = errno; - v_print("Master '%s': Error: get bonding info failed %s\n", - master_ifname, strerror(saved_errno)); - return 1; - } - - abi_ver = strtoul(info.fw_version, &endptr, 0); - if (*endptr) { - v_print("Master '%s': Error: got invalid string as an ABI " - "version from the bonding module\n", - master_ifname); - return 1; - } - -out: - v_print("ABI ver is %d\n", abi_ver); - - return 0; -} - -static int change_active(char *master_ifname, char *slave_ifname) -{ - struct ifreq ifr; - int res = 0; - - if (!(slave_flags.ifr_flags & IFF_SLAVE)) { - fprintf(stderr, - "Illegal operation: The specified slave interface " - "'%s' is not a slave\n", - slave_ifname); - return 1; - } - - strncpy(ifr.ifr_name, master_ifname, IFNAMSIZ); - strncpy(ifr.ifr_slave, slave_ifname, IFNAMSIZ); - if ((ioctl(skfd, SIOCBONDCHANGEACTIVE, &ifr) < 0) && - (ioctl(skfd, BOND_CHANGE_ACTIVE_OLD, &ifr) < 0)) { - saved_errno = errno; - v_print("Master '%s': Error: SIOCBONDCHANGEACTIVE failed: " - "%s\n", - master_ifname, strerror(saved_errno)); - res = 1; - } - - return res; -} - -static int enslave(char *master_ifname, char *slave_ifname) -{ - struct ifreq ifr; - int res = 0; - - if (slave_flags.ifr_flags & IFF_SLAVE) { - fprintf(stderr, - "Illegal operation: The specified slave interface " - "'%s' is already a slave\n", - slave_ifname); - return 1; - } - - res = set_if_down(slave_ifname, slave_flags.ifr_flags); - if (res) { - fprintf(stderr, - "Slave '%s': Error: bring interface down failed\n", - slave_ifname); - return res; - } - - if (abi_ver < 2) { - /* Older bonding versions would panic if the slave has no IP - * address, so get the IP setting from the master. - */ - set_if_addr(master_ifname, slave_ifname); - } else { - res = clear_if_addr(slave_ifname); - if (res) { - fprintf(stderr, - "Slave '%s': Error: clear address failed\n", - slave_ifname); - return res; - } - } - - if (master_mtu.ifr_mtu != slave_mtu.ifr_mtu) { - res = set_slave_mtu(slave_ifname, master_mtu.ifr_mtu); - if (res) { - fprintf(stderr, - "Slave '%s': Error: set MTU failed\n", - slave_ifname); - return res; - } - } - - if (hwaddr_set) { - /* Master already has an hwaddr - * so set it's hwaddr to the slave - */ - if (abi_ver < 1) { - /* The driver is using an old ABI, so - * the application sets the slave's - * hwaddr - */ - res = set_slave_hwaddr(slave_ifname, - &(master_hwaddr.ifr_hwaddr)); - if (res) { - fprintf(stderr, - "Slave '%s': Error: set hw address " - "failed\n", - slave_ifname); - goto undo_mtu; - } - - /* For old ABI the application needs to bring the - * slave back up - */ - res = set_if_up(slave_ifname, slave_flags.ifr_flags); - if (res) { - fprintf(stderr, - "Slave '%s': Error: bring interface " - "down failed\n", - slave_ifname); - goto undo_slave_mac; - } - } - /* The driver is using a new ABI, - * so the driver takes care of setting - * the slave's hwaddr and bringing - * it up again - */ - } else { - /* No hwaddr for master yet, so - * set the slave's hwaddr to it - */ - if (abi_ver < 1) { - /* For old ABI, the master needs to be - * down before setting it's hwaddr - */ - res = set_if_down(master_ifname, master_flags.ifr_flags); - if (res) { - fprintf(stderr, - "Master '%s': Error: bring interface " - "down failed\n", - master_ifname); - goto undo_mtu; - } - } - - res = set_master_hwaddr(master_ifname, - &(slave_hwaddr.ifr_hwaddr)); - if (res) { - fprintf(stderr, - "Master '%s': Error: set hw address " - "failed\n", - master_ifname); - goto undo_mtu; - } - - if (abi_ver < 1) { - /* For old ABI, bring the master - * back up - */ - res = set_if_up(master_ifname, master_flags.ifr_flags); - if (res) { - fprintf(stderr, - "Master '%s': Error: bring interface " - "up failed\n", - master_ifname); - goto undo_master_mac; - } - } - - hwaddr_set = 1; - } - - /* Do the real thing */ - strncpy(ifr.ifr_name, master_ifname, IFNAMSIZ); - strncpy(ifr.ifr_slave, slave_ifname, IFNAMSIZ); - if ((ioctl(skfd, SIOCBONDENSLAVE, &ifr) < 0) && - (ioctl(skfd, BOND_ENSLAVE_OLD, &ifr) < 0)) { - saved_errno = errno; - v_print("Master '%s': Error: SIOCBONDENSLAVE failed: %s\n", - master_ifname, strerror(saved_errno)); - res = 1; - } - - if (res) { - goto undo_master_mac; - } - - return 0; - -/* rollback (best effort) */ -undo_master_mac: - set_master_hwaddr(master_ifname, &(master_hwaddr.ifr_hwaddr)); - hwaddr_set = 0; - goto undo_mtu; -undo_slave_mac: - set_slave_hwaddr(slave_ifname, &(slave_hwaddr.ifr_hwaddr)); -undo_mtu: - set_slave_mtu(slave_ifname, slave_mtu.ifr_mtu); - return res; -} - -static int release(char *master_ifname, char *slave_ifname) -{ - struct ifreq ifr; - int res = 0; - - if (!(slave_flags.ifr_flags & IFF_SLAVE)) { - fprintf(stderr, - "Illegal operation: The specified slave interface " - "'%s' is not a slave\n", - slave_ifname); - return 1; - } - - strncpy(ifr.ifr_name, master_ifname, IFNAMSIZ); - strncpy(ifr.ifr_slave, slave_ifname, IFNAMSIZ); - if ((ioctl(skfd, SIOCBONDRELEASE, &ifr) < 0) && - (ioctl(skfd, BOND_RELEASE_OLD, &ifr) < 0)) { - saved_errno = errno; - v_print("Master '%s': Error: SIOCBONDRELEASE failed: %s\n", - master_ifname, strerror(saved_errno)); - return 1; - } else if (abi_ver < 1) { - /* The driver is using an old ABI, so we'll set the interface - * down to avoid any conflicts due to same MAC/IP - */ - res = set_if_down(slave_ifname, slave_flags.ifr_flags); - if (res) { - fprintf(stderr, - "Slave '%s': Error: bring interface " - "down failed\n", - slave_ifname); - } - } - - /* set to default mtu */ - set_slave_mtu(slave_ifname, 1500); - - return res; -} - -static int get_if_settings(char *ifname, struct dev_ifr ifra[]) -{ - int i; - int res = 0; - - for (i = 0; ifra[i].req_ifr; i++) { - strncpy(ifra[i].req_ifr->ifr_name, ifname, IFNAMSIZ); - res = ioctl(skfd, ifra[i].req_type, ifra[i].req_ifr); - if (res < 0) { - saved_errno = errno; - v_print("Interface '%s': Error: %s failed: %s\n", - ifname, ifra[i].req_name, - strerror(saved_errno)); - - return saved_errno; - } - } - - return 0; -} - -static int get_slave_flags(char *slave_ifname) -{ - int res = 0; - - strncpy(slave_flags.ifr_name, slave_ifname, IFNAMSIZ); - res = ioctl(skfd, SIOCGIFFLAGS, &slave_flags); - if (res < 0) { - saved_errno = errno; - v_print("Slave '%s': Error: SIOCGIFFLAGS failed: %s\n", - slave_ifname, strerror(saved_errno)); - } else { - v_print("Slave %s: flags %04X.\n", - slave_ifname, slave_flags.ifr_flags); - } - - return res; -} - -static int set_master_hwaddr(char *master_ifname, struct sockaddr *hwaddr) -{ - unsigned char *addr = (unsigned char *)hwaddr->sa_data; - struct ifreq ifr; - int res = 0; - - strncpy(ifr.ifr_name, master_ifname, IFNAMSIZ); - memcpy(&(ifr.ifr_hwaddr), hwaddr, sizeof(struct sockaddr)); - res = ioctl(skfd, SIOCSIFHWADDR, &ifr); - if (res < 0) { - saved_errno = errno; - v_print("Master '%s': Error: SIOCSIFHWADDR failed: %s\n", - master_ifname, strerror(saved_errno)); - return res; - } else { - v_print("Master '%s': hardware address set to " - "%2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x.\n", - master_ifname, addr[0], addr[1], addr[2], - addr[3], addr[4], addr[5]); - } - - return res; -} - -static int set_slave_hwaddr(char *slave_ifname, struct sockaddr *hwaddr) -{ - unsigned char *addr = (unsigned char *)hwaddr->sa_data; - struct ifreq ifr; - int res = 0; - - strncpy(ifr.ifr_name, slave_ifname, IFNAMSIZ); - memcpy(&(ifr.ifr_hwaddr), hwaddr, sizeof(struct sockaddr)); - res = ioctl(skfd, SIOCSIFHWADDR, &ifr); - if (res < 0) { - saved_errno = errno; - - v_print("Slave '%s': Error: SIOCSIFHWADDR failed: %s\n", - slave_ifname, strerror(saved_errno)); - - if (saved_errno == EBUSY) { - v_print(" The device is busy: it must be idle " - "before running this command.\n"); - } else if (saved_errno == EOPNOTSUPP) { - v_print(" The device does not support setting " - "the MAC address.\n" - " Your kernel likely does not support slave " - "devices.\n"); - } else if (saved_errno == EINVAL) { - v_print(" The device's address type does not match " - "the master's address type.\n"); - } - return res; - } else { - v_print("Slave '%s': hardware address set to " - "%2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x.\n", - slave_ifname, addr[0], addr[1], addr[2], - addr[3], addr[4], addr[5]); - } - - return res; -} - -static int set_slave_mtu(char *slave_ifname, int mtu) -{ - struct ifreq ifr; - int res = 0; - - ifr.ifr_mtu = mtu; - strncpy(ifr.ifr_name, slave_ifname, IFNAMSIZ); - - res = ioctl(skfd, SIOCSIFMTU, &ifr); - if (res < 0) { - saved_errno = errno; - v_print("Slave '%s': Error: SIOCSIFMTU failed: %s\n", - slave_ifname, strerror(saved_errno)); - } else { - v_print("Slave '%s': MTU set to %d.\n", slave_ifname, mtu); - } - - return res; -} - -static int set_if_flags(char *ifname, short flags) -{ - struct ifreq ifr; - int res = 0; - - ifr.ifr_flags = flags; - strncpy(ifr.ifr_name, ifname, IFNAMSIZ); - - res = ioctl(skfd, SIOCSIFFLAGS, &ifr); - if (res < 0) { - saved_errno = errno; - v_print("Interface '%s': Error: SIOCSIFFLAGS failed: %s\n", - ifname, strerror(saved_errno)); - } else { - v_print("Interface '%s': flags set to %04X.\n", ifname, flags); - } - - return res; -} - -static int set_if_up(char *ifname, short flags) -{ - return set_if_flags(ifname, flags | IFF_UP); -} - -static int set_if_down(char *ifname, short flags) -{ - return set_if_flags(ifname, flags & ~IFF_UP); -} - -static int clear_if_addr(char *ifname) -{ - struct ifreq ifr; - int res = 0; - - strncpy(ifr.ifr_name, ifname, IFNAMSIZ); - ifr.ifr_addr.sa_family = AF_INET; - memset(ifr.ifr_addr.sa_data, 0, sizeof(ifr.ifr_addr.sa_data)); - - res = ioctl(skfd, SIOCSIFADDR, &ifr); - if (res < 0) { - saved_errno = errno; - v_print("Interface '%s': Error: SIOCSIFADDR failed: %s\n", - ifname, strerror(saved_errno)); - } else { - v_print("Interface '%s': address cleared\n", ifname); - } - - return res; -} - -static int set_if_addr(char *master_ifname, char *slave_ifname) -{ - struct ifreq ifr; - int res; - unsigned char *ipaddr; - int i; - struct { - char *req_name; - char *desc; - int g_ioctl; - int s_ioctl; - } ifra[] = { - {"IFADDR", "addr", SIOCGIFADDR, SIOCSIFADDR}, - {"DSTADDR", "destination addr", SIOCGIFDSTADDR, SIOCSIFDSTADDR}, - {"BRDADDR", "broadcast addr", SIOCGIFBRDADDR, SIOCSIFBRDADDR}, - {"NETMASK", "netmask", SIOCGIFNETMASK, SIOCSIFNETMASK}, - {NULL, NULL, 0, 0}, - }; - - for (i = 0; ifra[i].req_name; i++) { - strncpy(ifr.ifr_name, master_ifname, IFNAMSIZ); - res = ioctl(skfd, ifra[i].g_ioctl, &ifr); - if (res < 0) { - int saved_errno = errno; - - v_print("Interface '%s': Error: SIOCG%s failed: %s\n", - master_ifname, ifra[i].req_name, - strerror(saved_errno)); - - ifr.ifr_addr.sa_family = AF_INET; - memset(ifr.ifr_addr.sa_data, 0, - sizeof(ifr.ifr_addr.sa_data)); - } - - strncpy(ifr.ifr_name, slave_ifname, IFNAMSIZ); - res = ioctl(skfd, ifra[i].s_ioctl, &ifr); - if (res < 0) { - int saved_errno = errno; - - v_print("Interface '%s': Error: SIOCS%s failed: %s\n", - slave_ifname, ifra[i].req_name, - strerror(saved_errno)); - - } - - ipaddr = (unsigned char *)ifr.ifr_addr.sa_data; - v_print("Interface '%s': set IP %s to %d.%d.%d.%d\n", - slave_ifname, ifra[i].desc, - ipaddr[0], ipaddr[1], ipaddr[2], ipaddr[3]); - } - - return 0; -} - -/* - * Local variables: - * version-control: t - * kept-new-versions: 5 - * c-indent-level: 4 - * c-basic-offset: 4 - * tab-width: 4 - * compile-command: "gcc -Wall -Wstrict-prototypes -O -I/usr/src/linux/include ifenslave.c -o ifenslave" - * End: - */ - diff --git a/iputils-ifenslave.diff b/iputils-ifenslave.diff deleted file mode 100644 index 2d638e1..0000000 --- a/iputils-ifenslave.diff +++ /dev/null @@ -1,13 +0,0 @@ ---- ifenslave.c -+++ ifenslave.c -@@ -520,8 +520,8 @@ static int if_getconfig(char *ifname) - if (ioctl(skfd, SIOCGIFADDR, &ifr) < 0) - return -1; - printf("The result of SIOCGIFADDR is %2.2x.%2.2x.%2.2x.%2.2x.\n", -- ifr.ifr_addr.sa_data[0], ifr.ifr_addr.sa_data[1], -- ifr.ifr_addr.sa_data[2], ifr.ifr_addr.sa_data[3]); -+ ifr.ifr_addr.sa_data[2] & 0xff, ifr.ifr_addr.sa_data[3] & 0xff, -+ ifr.ifr_addr.sa_data[4] & 0xff, ifr.ifr_addr.sa_data[5] & 0xff); - - strcpy(ifr.ifr_name, ifname); - if (ioctl(skfd, SIOCGIFHWADDR, &ifr) < 0) diff --git a/iputils-s20101006-ping-interrupt.diff b/iputils-ping-interrupt.diff similarity index 61% rename from iputils-s20101006-ping-interrupt.diff rename to iputils-ping-interrupt.diff index 759328f..d5cfd2f 100644 --- a/iputils-s20101006-ping-interrupt.diff +++ b/iputils-ping-interrupt.diff @@ -8,19 +8,19 @@ Signed-off-by: Hannes Reinecke ping.c | 9 +++++++++ 1 file changed, 9 insertions(+) -diff --git a/ping.c b/ping.c -index 0357c3d..83a7aad 100644 ---- a/ping.c -+++ b/ping.c -@@ -103,6 +103,7 @@ static void usage(void) __attribute__((noreturn)); - static u_short in_cksum(const u_short *addr, int len, u_short salt); +Index: iputils/ping.c +=================================================================== +--- iputils.orig/ping.c ++++ iputils/ping.c +@@ -96,6 +96,7 @@ static void usage(void) __attribute__((n + static unsigned short in_cksum(const unsigned short *addr, int len, unsigned short salt); static void pr_icmph(__u8 type, __u8 code, __u32 info, struct icmphdr *icp); static int parsetos(char *str); +static void doexit (int); static struct { struct cmsghdr cm; -@@ -262,6 +263,8 @@ main(int argc, char **argv) +@@ -514,6 +515,8 @@ int ping4_run(int argc, char **argv, str options |= F_SOURCEROUTE; } } @@ -29,8 +29,8 @@ index 0357c3d..83a7aad 100644 while (argc > 0) { target = *argv; -@@ -1398,3 +1401,9 @@ void usage(void) - ); +@@ -1627,3 +1630,9 @@ void usage(void) + ping6_usage(1); exit(2); } + @@ -39,6 +39,3 @@ index 0357c3d..83a7aad 100644 + exit (1); +} + --- -1.8.1.4 - diff --git a/iputils-remove-bogus-check-required-for-2.4.9-kernels.patch b/iputils-remove-bogus-check-required-for-2.4.9-kernels.patch index d222fd6..ffdb94d 100644 --- a/iputils-remove-bogus-check-required-for-2.4.9-kernels.patch +++ b/iputils-remove-bogus-check-required-for-2.4.9-kernels.patch @@ -12,45 +12,24 @@ diff --git a/ping.c b/ping.c index b9d649531621..f9f4a28f5dc1 100644 --- a/ping.c +++ b/ping.c -@@ -654,17 +654,6 @@ int receive_error_msg() +@ -898,17 +898,6 @@ acknowledge(ntohs(icmph.un.echo.sequence)); -- if (!working_recverr) { +- if (sock->socktype == SOCK_RAW && !sock->working_recverr) { - struct icmp_filter filt; -- working_recverr = 1; +- sock->working_recverr = 1; - /* OK, it works. Add stronger filter. */ -- filt.data = ~((1<fd, SOL_RAW, ICMP_FILTER, (char*)&filt, sizeof(filt)) == -1) - perror("\rWARNING: setsockopt(ICMP_FILTER)"); - } - net_errors++; nerrors++; if (options & F_QUIET) -@@ -820,19 +809,7 @@ parse_reply(struct msghdr *msg, int cc, void *addr, struct timeval *tv) - icp->type != ICMP_SOURCE_QUENCH); - if (error_pkt) { - acknowledge(ntohs(icp1->un.echo.sequence)); -- if (working_recverr) { -- return 0; -- } else { -- static int once; -- /* Sigh, IP_RECVERR for raw socket -- * was broken until 2.4.9. So, we ignore -- * the first error and warn on the second. -- */ -- if (once++ == 1) -- fprintf(stderr, "\rWARNING: kernel is not very fresh, upgrade is recommended.\n"); -- if (once == 1) -- return 0; -- } -+ return 0; - } - nerrors+=error_pkt; - if (options&F_QUIET) -- 2.3.5 diff --git a/iputils-s20121221.tar.bz2 b/iputils-s20121221.tar.bz2 deleted file mode 100644 index cc91498..0000000 --- a/iputils-s20121221.tar.bz2 +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:450f549fc5b620c23c5929aa6d54b7ddfc7ee1cb1e8efdc5e8bb21d8d0c5319f -size 155344 diff --git a/iputils-s20101006-sec-ping-unblock.diff b/iputils-sec-ping-unblock.diff similarity index 67% rename from iputils-s20101006-sec-ping-unblock.diff rename to iputils-sec-ping-unblock.diff index f4aad66..cf79276 100644 --- a/iputils-s20101006-sec-ping-unblock.diff +++ b/iputils-sec-ping-unblock.diff @@ -15,14 +15,15 @@ Signed-off-by: Hannes Reinecke ping.c | 10 ++++++++++ 1 file changed, 10 insertions(+) -diff --git a/ping.c b/ping.c -index 71b445d..0357c3d 100644 ---- a/ping.c -+++ b/ping.c -@@ -139,6 +139,16 @@ main(int argc, char **argv) +Index: iputils/ping.c +=================================================================== +--- iputils.orig/ping.c ++++ iputils/ping.c +@@ -443,6 +443,17 @@ main(int argc, char **argv) + /* Create sockets */ enable_capability_raw(); - ++ + /* + * ping depend on SIGALARM to exit sometimes, + * but to popen, system, fork carry on parent signal handler @@ -33,9 +34,6 @@ index 71b445d..0357c3d 100644 + sigprocmask(SIG_UNBLOCK, &s, NULL); + set_signal(SIGALRM, doexit); + - icmp_sock = socket(AF_INET, SOCK_RAW, IPPROTO_ICMP); - socket_errno = errno; - --- -1.8.1.4 - + if (hints.ai_family != AF_INET6) + create_socket(&sock4, AF_INET, hints.ai_socktype, IPPROTO_ICMP, hints.ai_family == AF_INET); + if (hints.ai_family != AF_INET) diff --git a/iputils-traceroute6-stdint.diff b/iputils-traceroute6-stdint.diff deleted file mode 100644 index 5646c00..0000000 --- a/iputils-traceroute6-stdint.diff +++ /dev/null @@ -1,25 +0,0 @@ -From 9c60c5877436c2feabe55ff91f6d279564fe1a31 Mon Sep 17 00:00:00 2001 -From: Hannes Reinecke -Date: Thu, 23 Jan 2014 10:32:36 +0100 -Subject: traceroute6: Include stdint.h - -Signed-off-by: Hannes Reinecke ---- - traceroute6.c | 1 + - 1 file changed, 1 insertion(+) - -diff --git a/traceroute6.c b/traceroute6.c -index 0538d4b..7205fa3 100644 ---- a/traceroute6.c -+++ b/traceroute6.c -@@ -230,6 +230,7 @@ char copyright[] = - * Tue Dec 20 03:50:13 PST 1988 - */ - -+#include - #include - #include - #include --- -1.8.1.4 - diff --git a/iputils.changes b/iputils.changes index a3c9fcf..52ae620 100644 --- a/iputils.changes +++ b/iputils.changes @@ -1,3 +1,131 @@ +------------------------------------------------------------------- +Tue May 24 09:28:43 UTC 2016 - meissner@suse.com + +- do not install rarpd and rarpd.8 manpage (comes from rarpd rpm currently) + +------------------------------------------------------------------- +Tue May 17 16:15:24 UTC 2016 - mchandras@suse.de + +- Update to version s20160308 (Changes taken from the RELNOTES file) + * use syntax compatible with busybox date in Makefile + * 'admin prohibited' should print !X not !S. + * Makefile: use #define as in previous code changes + * doc/Makefile: require bash, because we use pushd and popd + * doc: don't timestamp manpages by default + * ping: status() now returns received/transmitted instead of trans/recv + * ping: don't mess with internals of struct msghdr + * ping: ICMP error replies while errno < 0 is a hard error + * ping: always use POSIX locale when parsing -i + * ping: link against libm + * made ping functions protocol independent + * ping: perform dual-stack ping by default + * ping: remove obsolete preprocessor directives + * ping: avoid name clashes between IPv4 and IPv6 code + * ping: merge all ping header files into a single one + * ping: merge `ping6` command into `ping` + * ping: refactor ping options + * ping: refactor ping socket code + * ping: merge IPv4 and IPv6 `pr_addr()` + * ping: fix defines and libs in Makefile + * ping: handle single protocol systems + * iputils ping/ping6: Add a function to check if a packet is ours + * ping: Add to fix compilation error. + * ping6: Use GNUTLS API directly for MD5. (v2) + * ping6: Use libgcrypt instead of gnutls for MD5. + * Allow ping to use IPv6 addresses + * ping,ping6 doc: More description on CAP_NET_RAW usage. + * if IPv4 resolving fails fallback to ping6 + * ping: in usage print the 'ping -6' options as well + * ping: allow option -4 which forces IPv4 + * combine sock and errno into a single structure + * This patch allows running ping and ping6 without root privileges on + * use better names for socket variables + * tracepath,doc: fix corrupted tag + * doc: ping: add missing options and remove ping6 + * ninfod: remove unused variables + * ninfod: Regenerate configure by autoconf-2.69. + * ninfod: libgcrypt support. + * Fix building with musl + * travis.yml: install nettle-dev + * Allow using nettle instead of libgcrypt for MD5 + * avoid compiler warning caused by snapshot.h + * make `getaddrinfo()` and `getnameinfo()` usage consistent + * enable IDN by default + * remove IPV4_TARGETS and IPV6_TARGETS + * Use svg instead of png to get better image quality + * spec: Configure before building ninfod. + * spec: Fix date in %changelog. + * make,spec: Add rpm target. +- Refreshed patches + * iputils-ping-interrupt.diff + * iputils-sec-ping-unblock.diff +- Remove ifenslave.c. It has been removed in the linux kernel commit + b1098bbe1b24("bonding: remove ifenslave.c from kernel source"). + bonding can be done via iproute (netlink) +- dropped iputils-ifenslave.diff +- Append our CFLAGS to the upstream ones instead of overriding them. +- Cleanup old make command since the upstream Makefile does things right + it seems. +- Use Provides: for old /{,s}bin utils to satisfy reverse dependencies. +- Install utilities to /bin and /sbin until reverse dependencies are + properly fixed. +- Do not install tftp and traceroute to avoid conflicts with the tftp and + traceroute packages. Stick to what iputils used to provide in the past. +- Remove iputils-traceroute6-stdint.diff patch since we are not building + the traceroute* utilities. +- Install tracepath to /usr/bin. (boo#795788) + +------------------------------------------------------------------- +Tue Dec 1 13:39:07 UTC 2015 - p.drouand@gmail.com + +- Update to version s20150815 + * use syntax compatible with busybox date in Makefile + * Makefile: use #define as in previous code changes + * ping: status() now returns received/transmitted instead of trans/recv + * ping: don't mess with internals of struct msghdr + * tracepath,doc: fix corrupted tag + * made ping functions protocol independent + * Allow ping to use IPv6 addresses + * if IPv4 resolving fails fallback to ping6 + * ping: in usage print the 'ping -6' options as well + * ping: allow option -4 which forces IPv4 + * combine sock and errno into a single structure + * This patch allows running ping and ping6 without root privileges on + * use better names for socket variables + * travis.yml: install nettle-dev + * Allow using nettle instead of libgcrypt for MD5 + * avoid compiler warning caused by snapshot.h + * make `getaddrinfo()` and `getnameinfo()` usage consistent + * enable IDN by default + * ping: perform dual-stack ping by default + * remove IPV4_TARGETS and IPV6_TARGETS + * ping: remove obsolete preprocessor directives + * ping: avoid name clashes between IPv4 and IPv6 code + * ping: merge all ping header files into a single one + * ping: merge `ping6` command into `ping` + * ping: refactor ping options + * ping: refactor ping socket code + * ping: merge IPv4 and IPv6 `pr_addr()` + * Use svg instead of png to get better image quality + * iputils ping/ping6: Add a function to check if a packet is ours + * ping: Add to fix compilation error. + * ping6: Use GNUTLS API directly for MD5. (v2) + * ping6: Use libgcrypt instead of gnutls for MD5. + * ninfod: Regenerate configure by autoconf-2.69. + * ninfod: libgcrypt support. + * spec: Configure before building ninfod. + * spec: Fix date in %changelog. + * make,spec: Add rpm target. + * ping,ping6 doc: More description on CAP_NET_RAW usage. +- Update patches + * iputils-s20101006-ping-interrupt.diff > iputils-ping-interrupt.diff + * iputils-s20101006-sec-ping-unblock.diff > iputils-sec-ping-unblock.diff + * iputils-remove-bogus-check-required-for-2.4.9-kernels.patch +- Update home project page and download Url +- Remove obsolete %clean section +- Remove UsrMerge process; it has been done for more than two + openSUSE releases now + ------------------------------------------------------------------- Mon Apr 20 17:07:42 CEST 2015 - tiwai@suse.de diff --git a/iputils.spec b/iputils.spec index 1a6e3c4..eaef6d1 100644 --- a/iputils.spec +++ b/iputils.spec @@ -1,7 +1,7 @@ # # spec file for package iputils # -# Copyright (c) 2015 SUSE LINUX GmbH, Nuernberg, Germany. +# Copyright (c) 2016 SUSE LINUX GmbH, Nuernberg, Germany. # # All modifications and additions to the file contributed by third parties # remain the property of their copyright owners, unless otherwise agreed @@ -23,104 +23,107 @@ BuildRequires: libcap-devel BuildRequires: libopenssl-devel BuildRequires: opensp BuildRequires: perl-SGMLS +BuildRequires: pkgconfig(libidn) +# For Makefile modifications +BuildRequires: sed Summary: IPv4 and IPv6 Networking Utilities License: BSD-3-Clause and GPL-2.0+ Group: Productivity/Networking/Other -Version: s20121221 +Version: s20160308 Release: 0 -Url: http://www.skbuff.net/iputils -Source: http://www.skbuff.net/iputils/iputils-%{version}.tar.bz2 -# XXX: from linux/Documentation/networking/ifenslave.c -Source1: ifenslave.c -Patch2: iputils-traceroute6-stdint.diff -Patch3: iputils-ifenslave.diff -Patch8: iputils-s20101006-sec-ping-unblock.diff -Patch9: iputils-s20101006-ping-interrupt.diff +Url: https://github.com/iputils/iputils +Source: https://github.com/iputils/iputils/archive/%{version}.tar.gz +Patch8: iputils-sec-ping-unblock.diff +Patch9: iputils-ping-interrupt.diff # PATCH-FIX-UPSTREAM iputils-remove-bogus-check-required-for-2.4.9-kernels.patch tiwai@suse.de - boo#927831 Patch10: iputils-remove-bogus-check-required-for-2.4.9-kernels.patch BuildRoot: %{_tmppath}/%{name}-%{version}-build PreReq: permissions +# I have spotted at least two packages (yast-printer and dhcp-client) that need +# /bin/ping and /sbin/arping but they do not seem to use them with absolute +# paths so we may be lukcy and no further changes are necessary. +Provides: /bin/ping +Provides: /sbin/arping %description This package contains some small network tools for IPv4 and IPv6 like -rdisc, ping6, traceroute6, tracepath, and tracepath6. +rdisc, ping, arping, tracepath and tracepath6. %prep %setup -q -cp -a %SOURCE1 . -%patch2 -p1 -%patch3 %patch8 -p1 %patch9 -p1 %patch10 -p1 %build -make %{?_smp_mflags} KERNEL_INCLUDE=$PWD \ - CCOPT='%optflags -fno-strict-aliasing -fpie -D_GNU_SOURCE' \ - LDLIBS='-Wl,-z,relro,-z,now -pie -lcap -lresolv' \ - CAPABILITIES=1 LDFLAG_GNUTLS='-lcrypto -lssl' -gcc $RPM_OPT_FLAGS -o ifenslave ifenslave.c +# Drop LASTTAG variable since it needs git and it's not used for regular +# building +sed -i '/^LASTTAG:=/d' Makefile +# Do not link against nettle +sed -i '/^USE_NETTLE/s/yes/no/' Makefile + +# Export CFLAGS so we can also benefit from the ones the Makefile sets for us +# Instead of overriding all of them. +export CFLAGS='%{optflags} -fpie' +# Pulled-in by the LINK.o variable. +export LDFLAGS='-pie -Wl,-z,relro,-z,now' + +# Build only selected apps +make %{?_smp_mflags} arping clockdiff ping rdisc tracepath \ + tracepath6 rarpd make man %install mkdir -p $RPM_BUILD_ROOT/%_sbindir mkdir -p $RPM_BUILD_ROOT/%_bindir install arping $RPM_BUILD_ROOT/%{_sbindir} -install ifenslave $RPM_BUILD_ROOT/%{_sbindir} install clockdiff $RPM_BUILD_ROOT/%{_sbindir} install rdisc $RPM_BUILD_ROOT/%{_sbindir}/in.rdisc -install tracepath $RPM_BUILD_ROOT/%{_sbindir} -install tracepath6 $RPM_BUILD_ROOT/%{_sbindir} +# boo#795788 +install tracepath $RPM_BUILD_ROOT/%{_bindir} +install tracepath6 $RPM_BUILD_ROOT/%{_bindir} install ping $RPM_BUILD_ROOT/%{_bindir} -install ping6 $RPM_BUILD_ROOT/%{_bindir} -install ipg $RPM_BUILD_ROOT/%{_bindir} +#install rarpd $RPM_BUILD_ROOT/%{_bindir} #UsrMerge +# We still have reverse dependencies using /sbin/* or /bin/* +# so keep these symlinks for now. They are slowly being fixed +# but lets not just break them yet. mkdir -p $RPM_BUILD_ROOT/{bin,sbin} -ln -sf %{_sbindir}/arping $RPM_BUILD_ROOT/sbin -ln -sf %{_sbindir}/ifenslave $RPM_BUILD_ROOT/sbin -ln -sf %{_sbindir}/clockdiff $RPM_BUILD_ROOT/sbin -ln -sf %{_sbindir}/in.rdisc $RPM_BUILD_ROOT/sbin -ln -sf %{_sbindir}/tracepath $RPM_BUILD_ROOT/sbin -ln -sf %{_sbindir}/tracepath6 $RPM_BUILD_ROOT/sbin -ln -sf %{_bindir}/ping $RPM_BUILD_ROOT/bin -ln -sf %{_bindir}/ping6 $RPM_BUILD_ROOT/bin -ln -sf %{_bindir}/ipg $RPM_BUILD_ROOT/bin +ln -sf %{_sbindir}/arping $RPM_BUILD_ROOT/sbin +ln -sf %{_sbindir}/clockdiff $RPM_BUILD_ROOT/sbin +ln -sf %{_sbindir}/in.rdisc $RPM_BUILD_ROOT/sbin +ln -sf %{_bindir}/tracepath $RPM_BUILD_ROOT/bin +ln -sf %{_bindir}/tracepath6 $RPM_BUILD_ROOT/bin +ln -sf %{_bindir}/ping $RPM_BUILD_ROOT/bin #EndUsrMerge -mkdir -p $RPM_BUILD_ROOT%_mandir/man8 -install -m 644 doc/arping.8 $RPM_BUILD_ROOT%_mandir/man8/ -install -m 644 doc/clockdiff.8 $RPM_BUILD_ROOT%_mandir/man8/ -install -m 644 doc/tracepath.8 $RPM_BUILD_ROOT%_mandir/man8/ -install -m 644 doc/ping.8 $RPM_BUILD_ROOT%_mandir/man8/ -install -m 644 doc/ping.8 $RPM_BUILD_ROOT%_mandir/man8/ping6.8 -install -m 644 doc/pg3.8 $RPM_BUILD_ROOT%_mandir/man8/ -install -m 644 doc/rdisc.8 $RPM_BUILD_ROOT%_mandir/man8/ -%clean -rm -rf $RPM_BUILD_ROOT +mkdir -p $RPM_BUILD_ROOT/%{_mandir}/man8 +# Remove conflicting manpages +rm doc/tftpd* doc/traceroute* doc/rarpd* +# Install the rest +install -m 644 doc/*.8 $RPM_BUILD_ROOT%_mandir/man8/ %post -%set_permissions %{_bindir}/ping %{_bindir}/ping6 +%set_permissions %{_bindir}/ping %verifyscript -%verify_permissions %{_bindir}/ping %{_bindir}/ping6 +%verify_permissions -e %{_bindir}/ping %files %defattr(-,root,root) %doc RELNOTES +%verify(not mode) %attr(0755,root,root) %{_bindir}/ping +#%{_bindir}/rarpd %{_sbindir}/arping -%{_sbindir}/ifenslave %{_sbindir}/clockdiff -%verify(not mode caps) %attr(4755,root,root) %{_bindir}/ping -%verify(not mode caps) %attr(4755,root,root) %{_bindir}/ping6 -%{_bindir}/ipg -%{_sbindir}/tracepath -%{_sbindir}/tracepath6 +%{_bindir}/tracepath +%{_bindir}/tracepath6 %{_sbindir}/in.rdisc +%attr(644,root,root) %_mandir/man8/* #UsrMerge /bin/* /sbin/* #EndUsrMerge -%attr(644,root,root) %_mandir/man8/* %changelog diff --git a/s20160308.tar.gz b/s20160308.tar.gz new file mode 100644 index 0000000..8cc5031 --- /dev/null +++ b/s20160308.tar.gz @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:803d11b14af1bd3852c83111cc29e904bc3ca936c093dbb419d0671d3c9d964b +size 195348