diff -ruN iptraf-2.7.0-old/src/dirs.h iptraf-2.7.0-new/src/dirs.h --- iptraf-2.7.0-old/src/dirs.h 2001-05-03 12:44:11.000000000 +0200 +++ iptraf-2.7.0-new/src/dirs.h 2005-10-04 21:51:26.000000000 +0200 @@ -148,11 +148,10 @@ #define PORTFILE get_path(T_WORKDIR, "ports.dat") /* - * The Ethernet and FDDI host description files + * The Ethernet host description files */ #define ETHFILE get_path(T_WORKDIR, "ethernet.desc") -#define FDDIFILE get_path(T_WORKDIR, "fddi.desc") /* * The rvnamed program file diff -ruN iptraf-2.7.0-old/src/hostmon.c iptraf-2.7.0-new/src/hostmon.c --- iptraf-2.7.0-old/src/hostmon.c 2002-04-16 04:15:25.000000000 +0200 +++ iptraf-2.7.0-new/src/hostmon.c 2005-10-04 21:52:02.000000000 +0200 @@ -30,7 +30,6 @@ #include <netinet/in.h> #include <linux/if_packet.h> #include <linux/if_ether.h> -#include <linux/if_fddi.h> #include <linux/if_tr.h> #include <net/if_arp.h> #include <stdlib.h> @@ -294,8 +293,6 @@ wprintw(table->tabwin, "Ethernet"); else if (entry->un.desc.linktype == LINK_PLIP) wprintw(table->tabwin, "PLIP"); - else if (entry->un.desc.linktype == LINK_FDDI) - wprintw(table->tabwin, "FDDI"); wprintw(table->tabwin, " HW addr: %s", entry->un.desc.ascaddr); @@ -771,7 +768,6 @@ initethtab(&table, options->actmode); loaddesclist(&elist, LINK_ETHERNET, WITHETCETHERS); - loaddesclist(&flist, LINK_FDDI, WITHETCETHERS); if (logging) { if (strcmp(current_logfile, "") == 0) @@ -854,7 +850,7 @@ } linktype = getlinktype(fromaddr.sll_hatype, ifname, -1, NULL); - if ((linktype == LINK_ETHERNET) || (linktype == LINK_FDDI) + if ((linktype == LINK_ETHERNET) || (linktype == LINK_PLIP) || (linktype == LINK_TR)) { if (fromaddr.sll_protocol == htons(ETH_P_IP)) is_ip = 1; @@ -871,12 +867,6 @@ memcpy(scratch_daddr, ((struct ethhdr *) buf)->h_dest, ETH_ALEN); list = &elist; - } else if (linktype == LINK_FDDI) { - memcpy(scratch_saddr, ((struct fddihdr *) buf)->saddr, - FDDI_K_ALEN); - memcpy(scratch_daddr, ((struct fddihdr *) buf)->daddr, - FDDI_K_ALEN); - list = &flist; } else if (linktype == LINK_TR) { memcpy(scratch_saddr, ((struct trh_hdr *) buf)->saddr, TR_ALEN); diff -ruN iptraf-2.7.0-old/src/ifaces.c iptraf-2.7.0-new/src/ifaces.c --- iptraf-2.7.0-old/src/ifaces.c 2002-05-08 11:43:27.000000000 +0200 +++ iptraf-2.7.0-new/src/ifaces.c 2005-10-04 21:54:00.000000000 +0200 @@ -37,9 +37,9 @@ extern int daemonized; char ifaces[][6] = - { "lo", "eth", "sl", "ppp", "ippp", "plip", "fddi", "isdn", "dvb", + { "lo", "eth", "sl", "ppp", "ippp", "plip", "isdn", "dvb", "pvc", "hdlc", "ipsec", "sbni", "tr", "wvlan", "wlan", "sm2", "sm3", - "pent", "lec" }; + "pent", "lec", "vlan" }; char *ltrim(char *buf) { diff -ruN iptraf-2.7.0-old/src/landesc.c iptraf-2.7.0-new/src/landesc.c --- iptraf-2.7.0-old/src/landesc.c 2001-11-27 11:23:32.000000000 +0100 +++ iptraf-2.7.0-new/src/landesc.c 2005-10-04 21:57:33.000000000 +0200 @@ -82,8 +82,6 @@ if (linktype == LINK_ETHERNET) fd = fopen(ETHFILE, "r"); - else if (linktype == LINK_FDDI) - fd = fopen(FDDIFILE, "r"); if (fd == NULL) { return; @@ -204,8 +202,6 @@ if (linktype == LINK_ETHERNET) fd = fopen(ETHFILE, "w"); - else if (linktype == LINK_FDDI) - fd = fopen(FDDIFILE, "w"); if (fd < 0) { etherr(); diff -ruN iptraf-2.7.0-old/src/links.h iptraf-2.7.0-new/src/links.h --- iptraf-2.7.0-old/src/links.h 2001-12-18 03:45:16.000000000 +0100 +++ iptraf-2.7.0-new/src/links.h 2005-10-04 21:57:17.000000000 +0200 @@ -5,7 +5,6 @@ #define LINK_LOOPBACK 5 #define LINK_ISDN_RAWIP 6 #define LINK_ISDN_CISCOHDLC 7 -#define LINK_FDDI 8 #define LINK_FRAD 9 #define LINK_DLCI 10 #define LINK_TR 11 diff -ruN iptraf-2.7.0-old/src/log.c iptraf-2.7.0-new/src/log.c --- iptraf-2.7.0-old/src/log.c 2002-04-22 05:59:15.000000000 +0200 +++ iptraf-2.7.0-new/src/log.c 2005-10-04 21:57:51.000000000 +0200 @@ -465,8 +465,6 @@ ptmp->un.desc.ascaddr); else if (ptmp->un.desc.linktype == LINK_PLIP) fprintf(fd, "\nPLIP address: %s", ptmp->un.desc.ascaddr); - else if (ptmp->un.desc.linktype == LINK_FDDI) - fprintf(fd, "\nFDDI address: %s", ptmp->un.desc.ascaddr); if (ptmp->un.desc.withdesc) fprintf(fd, " (%s)", ptmp->un.desc.desc); diff -ruN iptraf-2.7.0-old/src/options.c iptraf-2.7.0-new/src/options.c --- iptraf-2.7.0-old/src/options.c 2001-12-28 10:39:15.000000000 +0100 +++ iptraf-2.7.0-new/src/options.c 2005-10-04 21:58:15.000000000 +0200 @@ -67,8 +67,6 @@ tx_additem(menu, NULL, NULL); tx_additem(menu, " ^E^thernet/PLIP host descriptions...", "Manages descriptions for Ethernet and PLIP addresses"); - tx_additem(menu, " ^F^DDI/Token Ring host descriptions...", - "Manages descriptions for FDDI and FDDI addresses"); tx_additem(menu, NULL, NULL); tx_additem(menu, " E^x^it configuration", "Returns to main menu"); } @@ -366,9 +364,6 @@ case 14: ethdescmgr(LINK_ETHERNET); break; - case 15: - ethdescmgr(LINK_FDDI); - break; } indicatesetting(row, options, statwin); diff -ruN iptraf-2.7.0-old/src/othptab.c iptraf-2.7.0-new/src/othptab.c --- iptraf-2.7.0-old/src/othptab.c 2001-12-28 03:23:59.000000000 +0100 +++ iptraf-2.7.0-new/src/othptab.c 2005-10-04 21:58:33.000000000 +0200 @@ -19,7 +19,6 @@ #include <asm/types.h> #include <linux/if_ether.h> #include <linux/if_tr.h> -#include <linux/if_fddi.h> #include <winops.h> #include "arphdr.h" #include "options.h" @@ -139,11 +138,6 @@ new_entry->smacaddr); convmacaddr(((struct ethhdr *) packet)->h_dest, new_entry->dmacaddr); - } else if (linkproto == LINK_FDDI) { - convmacaddr(((struct fddihdr *) packet)->saddr, - new_entry->smacaddr); - convmacaddr(((struct fddihdr *) packet)->daddr, - new_entry->dmacaddr); } else if (linkproto == LINK_TR) { convmacaddr(((struct trh_hdr *) packet)->saddr, new_entry->smacaddr); @@ -373,8 +367,7 @@ strcat(msgstring, scratchpad); if ((entry->linkproto == LINK_ETHERNET) || - (entry->linkproto == LINK_PLIP) || - (entry->linkproto == LINK_FDDI)) { + (entry->linkproto == LINK_PLIP)) { sprintf(scratchpad, " from %s to %s on %s", entry->smacaddr, entry->dmacaddr, entry->iface); diff -ruN iptraf-2.7.0-old/src/packet.c iptraf-2.7.0-new/src/packet.c --- iptraf-2.7.0-old/src/packet.c 2002-05-08 11:44:08.000000000 +0200 +++ iptraf-2.7.0-new/src/packet.c 2005-10-04 21:59:12.000000000 +0200 @@ -35,7 +35,6 @@ #include <sys/ioctl.h> #include <linux/if_packet.h> #include <linux/if_ether.h> -#include <linux/if_fddi.h> #include <linux/if_tr.h> #include <linux/isdn.h> #include <linux/sockios.h> @@ -80,10 +79,10 @@ case ARPHRD_ETHER: if (strncmp(ifname, "eth", 3) == 0) result = LINK_ETHERNET; + else if (strncmp(ifname, "vlan", 4) == 0) + result = LINK_ETHERNET; else if (strncmp(ifname, "plip", 4) == 0) result = LINK_PLIP; - else if (strncmp(ifname, "fddi", 4) == 0) /* For some Ethernet- */ - result = LINK_ETHERNET; /* emulated FDDI ifaces */ else if (strncmp(ifname, "dvb", 3) == 0) result = LINK_ETHERNET; else if (strncmp(ifname, "sbni", 4) == 0) @@ -127,9 +126,6 @@ case ARPHRD_PPP: result = LINK_PPP; break; - case ARPHRD_FDDI: - result = LINK_FDDI; - break; case ARPHRD_IEEE802: case ARPHRD_IEEE802_TR: result = LINK_TR; @@ -179,19 +175,6 @@ *packet = tpacket + 4; *readlen -= 4; break; - case LINK_FDDI: - *packet = tpacket + sizeof(struct fddihdr); - *readlen -= sizeof(struct fddihdr); - - /* - * Move IP data into an aligned buffer. 96 bytes should be sufficient - * for IP and TCP headers with reasonable numbers of options and some - * data. - */ - - memmove(aligned_buf, *packet, min(SNAPSHOT_LEN, *readlen)); - *packet = aligned_buf; - break; case LINK_TR: /* * Token Ring patch supplied by Tomas Dvorak diff -ruN iptraf-2.7.0-old/src/promisc.c iptraf-2.7.0-new/src/promisc.c --- iptraf-2.7.0-old/src/promisc.c 2002-01-16 02:51:03.000000000 +0100 +++ iptraf-2.7.0-new/src/promisc.c 2005-10-04 22:05:25.000000000 +0200 @@ -81,7 +81,7 @@ */ if ((strncmp(buf, "eth", 3) == 0) || - (strncmp(buf, "fddi", 4) == 0) || + (strncmp(buf, "vlan", 4) == 0) || (strncmp(ptmp->params.ifname, "wvlan", 4) == 0) || (strncmp(ptmp->params.ifname, "lec", 3) == 0) || (accept_unsupported_interfaces)) { @@ -194,7 +194,7 @@ while (ptmp != NULL) { if (((strncmp(ptmp->params.ifname, "eth", 3) == 0) || - (strncmp(ptmp->params.ifname, "fddi", 4) == 0) || + (strncmp(ptmp->params.ifname, "vlan", 4) == 0) || (strncmp(ptmp->params.ifname, "wvlan", 4) == 0) || (strncmp(ptmp->params.ifname, "lec", 3) == 0)) && (ptmp->params.state_valid)) { diff -ruN iptraf-2.7.0-old/src/promisc.~c iptraf-2.7.0-new/src/promisc.~c --- iptraf-2.7.0-old/src/promisc.~c 1970-01-01 01:00:00.000000000 +0100 +++ iptraf-2.7.0-new/src/promisc.~c 2005-10-04 22:00:02.000000000 +0200 @@ -0,0 +1,238 @@ +/*** + +promisc.c - handles the promiscuous mode flag for the Ethernet/FDDI + interfaces + +Written by Gerard Paul Java +Copyright (c) Gerard Paul Java 1997, 1998 + +This module contains functions that manage the promiscuous states of +the interfaces. + +This software is open source; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2 of the License, or +(at your option) any later version. + +This program is distributed WITHOUT ANY WARRANTY; without even the +implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +See the GNU General Public License in the included COPYING file for +details. + +***/ + +#include <curses.h> +#include <panel.h> +#include <sys/ioctl.h> +#include <sys/socket.h> +#include <sys/types.h> +#include <sys/stat.h> +#include <fcntl.h> +#include <unistd.h> +#include <stdlib.h> +#include <string.h> +#include <netinet/in.h> +#include <net/if.h> +#include <linux/if_ether.h> +#include "ifstats.h" +#include "ifaces.h" +#include "error.h" +#include "promisc.h" +#include "dirs.h" + +#define PROMISC_MSG_MAX 80 + +extern int daemonized; +extern int accept_unsupported_interfaces; + +void init_promisc_list(struct promisc_states **list) +{ + FILE *fd; + int ifd; + char buf[8]; + struct promisc_states *ptmp; + struct promisc_states *tail = NULL; + struct ifreq ifr; + int istat; + char err_msg[80]; + + ifd = socket(PF_INET, SOCK_DGRAM, 0); + + *list = NULL; + fd = open_procnetdev(); + + do { + get_next_iface(fd, buf); + + if (strcmp(buf, "") != 0) { + ptmp = malloc(sizeof(struct promisc_states)); + strcpy(ptmp->params.ifname, buf); + + if (*list == NULL) { + *list = ptmp; + } else + tail->next_entry = ptmp; + + tail = ptmp; + ptmp->next_entry = NULL; + + /* + * Retrieve and save interface flags + */ + + if ((strncmp(buf, "eth", 3) == 0) || + (strncmp(buf, "vlan", 4) == 0) || + (strncmp(buf, "fddi", 4) == 0) || + (strncmp(ptmp->params.ifname, "wvlan", 4) == 0) || + (strncmp(ptmp->params.ifname, "lec", 3) == 0) || + (accept_unsupported_interfaces)) { + strcpy(ifr.ifr_name, buf); + + istat = ioctl(ifd, SIOCGIFFLAGS, &ifr); + + if (istat < 0) { + sprintf(err_msg, + "Unable to obtain interface parameters for %s", + buf); + write_error(err_msg, daemonized); + ptmp->params.state_valid = 0; + } else { + ptmp->params.saved_state = ifr.ifr_flags; + ptmp->params.state_valid = 1; + } + } + } + } while (strcmp(buf, "") != 0); +} + +/* + * Save interfaces and their states to a temporary file. Used only by the + * first IPTraf instance. Needed in case there are subsequent, simultaneous + * instances of IPTraf, which may still need promiscuous mode even after + * the first instance exits. These subsequent instances will need to restore + * the promiscuous state from this file. + */ + +void save_promisc_list(struct promisc_states *list) +{ + int fd; + struct promisc_states *ptmp = list; + + fd = open(PROMISCLISTFILE, O_WRONLY | O_CREAT, S_IRUSR | S_IWUSR); + + if (fd < 0) { + write_error("Unable to save interface flags", daemonized); + return; + } + + while (ptmp != NULL) { + write(fd, &(ptmp->params), sizeof(struct promisc_params)); + ptmp = ptmp->next_entry; + } + + close(fd); +} + +/* + * Load promiscuous states into list + */ + +void load_promisc_list(struct promisc_states **list) +{ + int fd; + struct promisc_states *ptmp = NULL; + struct promisc_states *tail = NULL; + int br; + + fd = open(PROMISCLISTFILE, O_RDONLY); + + if (fd < 0) { + write_error("Unable to retrieve saved interface flags", + daemonized); + *list = NULL; + return; + } + + do { + ptmp = malloc(sizeof(struct promisc_states)); + br = read(fd, &(ptmp->params), sizeof(struct promisc_params)); + + if (br > 0) { + if (tail != NULL) + tail->next_entry = ptmp; + else + *list = ptmp; + + ptmp->next_entry = NULL; + tail = ptmp; + } else + free(ptmp); + } while (br > 0); + + close(fd); +} + +/* + * Set/restore interface promiscuous mode. + */ + +void srpromisc(int mode, struct promisc_states *list) +{ + int fd; + struct ifreq ifr; + struct promisc_states *ptmp; + int istat; + char fullmsg[PROMISC_MSG_MAX]; + + ptmp = list; + + fd = socket(PF_INET, SOCK_DGRAM, 0); + + if (fd < 0) { + write_error("Unable to open socket for flag change", daemonized); + return; + } + + while (ptmp != NULL) { + if (((strncmp(ptmp->params.ifname, "eth", 3) == 0) || + (strncmp(ptmp->params.ifname, "vlan", 4) == 0) || + (strncmp(ptmp->params.ifname, "wvlan", 4) == 0) || + (strncmp(ptmp->params.ifname, "lec", 3) == 0)) && + (ptmp->params.state_valid)) { + + strcpy(ifr.ifr_name, ptmp->params.ifname); + + if (mode) + ifr.ifr_flags = ptmp->params.saved_state | IFF_PROMISC; + else + ifr.ifr_flags = ptmp->params.saved_state; + + istat = ioctl(fd, SIOCSIFFLAGS, &ifr); + + if (istat < 0) { + sprintf(fullmsg, "Promisc change failed for %s", + ptmp->params.ifname); + write_error(fullmsg, daemonized); + } + } + ptmp = ptmp->next_entry; + } + + close(fd); +} + +void destroy_promisc_list(struct promisc_states **list) +{ + struct promisc_states *ptmp = *list; + struct promisc_states *ctmp; + + if (ptmp != NULL) + ctmp = ptmp->next_entry; + + while (ptmp != NULL) { + free(ptmp); + ptmp = ctmp; + if (ctmp != NULL) + ctmp = ctmp->next_entry; + } +} diff -ruN iptraf-2.7.0-old/src/rvnamed.c iptraf-2.7.0-new/src/rvnamed.c --- iptraf-2.7.0-old/src/rvnamed.c 2002-05-02 03:37:34.000000000 +0200 +++ iptraf-2.7.0-new/src/rvnamed.c 2005-10-04 22:02:47.000000000 +0200 @@ -48,7 +48,6 @@ #include <signal.h> #include <sys/wait.h> #include "rvnamed.h" -#include "dirs.h" #define NUM_CACHE_ENTRIES 2048 #define TIME_TARGET_MAX 30 diff -ruN iptraf-2.7.0-old/src/rvnamed.h iptraf-2.7.0-new/src/rvnamed.h --- iptraf-2.7.0-old/src/rvnamed.h 2002-05-02 03:36:30.000000000 +0200 +++ iptraf-2.7.0-new/src/rvnamed.h 2005-10-04 22:03:29.000000000 +0200 @@ -1,9 +1,10 @@ #include <netinet/in.h> #include <arpa/inet.h> +#include "dirs.h" -#define CHILDSOCKNAME "/dev/rvndcldcomsk" -#define PARENTSOCKNAME "/dev/rvndpntcomsk" -#define IPTSOCKNAME "/dev/rvndiptcomsk" +#define CHILDSOCKNAME LOCKDIR "/rvndcldcomsk" +#define PARENTSOCKNAME LOCKDIR "/rvndpntcomsk" +#define IPTSOCKNAME LOCKDIR "/rvndiptcomsk" #define SOCKET_PREFIX "isock" diff -ruN iptraf-2.7.0-old/src/tcptable.c iptraf-2.7.0-new/src/tcptable.c --- iptraf-2.7.0-old/src/tcptable.c 2002-05-08 03:36:27.000000000 +0200 +++ iptraf-2.7.0-new/src/tcptable.c 2005-10-03 19:25:55.000000000 +0200 @@ -598,9 +598,6 @@ if ((linkproto == LINK_ETHERNET) || (linkproto == LINK_PLIP)) { convmacaddr(((struct ethhdr *) packet)->h_source, newmacaddr); - } else if (linkproto == LINK_FDDI) { - convmacaddr(((struct fddihdr *) packet)->saddr, - newmacaddr); } else if (linkproto == LINK_TR) { convmacaddr(((struct trh_hdr *) packet)->saddr, newmacaddr); } diff -ruN iptraf-2.7.0-old/src/tcptable.h iptraf-2.7.0-new/src/tcptable.h --- iptraf-2.7.0-old/src/tcptable.h 2001-12-28 03:16:39.000000000 +0100 +++ iptraf-2.7.0-new/src/tcptable.h 2005-10-03 19:26:01.000000000 +0200 @@ -22,7 +22,6 @@ #include <asm/types.h> #include <linux/if_packet.h> #include <linux/if_ether.h> -#include <linux/if_fddi.h> #include <linux/if_tr.h> #include <net/if.h> #include <netinet/ip.h>