Annotation of 43BSDReno/sbin/routed/if.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1983 Regents of the University of California.
                      3:  * All rights reserved.
                      4:  *
                      5:  * Redistribution and use in source and binary forms are permitted
                      6:  * provided that: (1) source distributions retain this entire copyright
                      7:  * notice and comment, and (2) distributions including binaries display
                      8:  * the following acknowledgement:  ``This product includes software
                      9:  * developed by the University of California, Berkeley and its contributors''
                     10:  * in the documentation or other materials provided with the distribution
                     11:  * and in all advertising materials mentioning features or use of this
                     12:  * software. Neither the name of the University nor the names of its
                     13:  * contributors may be used to endorse or promote products derived
                     14:  * from this software without specific prior written permission.
                     15:  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
                     16:  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
                     17:  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
                     18:  */
                     19: 
                     20: #ifndef lint
                     21: static char sccsid[] = "@(#)if.c       5.6 (Berkeley) 6/1/90";
                     22: #endif /* not lint */
                     23: 
                     24: /*
                     25:  * Routing Table Management Daemon
                     26:  */
                     27: #include "defs.h"
                     28: 
                     29: extern struct interface *ifnet;
                     30: 
                     31: /*
                     32:  * Find the interface with address addr.
                     33:  */
                     34: struct interface *
                     35: if_ifwithaddr(addr)
                     36:        struct sockaddr *addr;
                     37: {
                     38:        register struct interface *ifp;
                     39: 
                     40: #define        same(a1, a2) \
                     41:        (bcmp((caddr_t)((a1)->sa_data), (caddr_t)((a2)->sa_data), 14) == 0)
                     42:        for (ifp = ifnet; ifp; ifp = ifp->int_next) {
                     43:                if (ifp->int_flags & IFF_REMOTE)
                     44:                        continue;
                     45:                if (ifp->int_addr.sa_family != addr->sa_family)
                     46:                        continue;
                     47:                if (same(&ifp->int_addr, addr))
                     48:                        break;
                     49:                if ((ifp->int_flags & IFF_BROADCAST) &&
                     50:                    same(&ifp->int_broadaddr, addr))
                     51:                        break;
                     52:        }
                     53:        return (ifp);
                     54: }
                     55: 
                     56: /*
                     57:  * Find the point-to-point interface with destination address addr.
                     58:  */
                     59: struct interface *
                     60: if_ifwithdstaddr(addr)
                     61:        struct sockaddr *addr;
                     62: {
                     63:        register struct interface *ifp;
                     64: 
                     65:        for (ifp = ifnet; ifp; ifp = ifp->int_next) {
                     66:                if ((ifp->int_flags & IFF_POINTOPOINT) == 0)
                     67:                        continue;
                     68:                if (same(&ifp->int_dstaddr, addr))
                     69:                        break;
                     70:        }
                     71:        return (ifp);
                     72: }
                     73: 
                     74: /*
                     75:  * Find the interface on the network 
                     76:  * of the specified address.
                     77:  */
                     78: struct interface *
                     79: if_ifwithnet(addr)
                     80:        register struct sockaddr *addr;
                     81: {
                     82:        register struct interface *ifp;
                     83:        register int af = addr->sa_family;
                     84:        register int (*netmatch)();
                     85: 
                     86:        if (af >= af_max)
                     87:                return (0);
                     88:        netmatch = afswitch[af].af_netmatch;
                     89:        for (ifp = ifnet; ifp; ifp = ifp->int_next) {
                     90:                if (ifp->int_flags & IFF_REMOTE)
                     91:                        continue;
                     92:                if (af != ifp->int_addr.sa_family)
                     93:                        continue;
                     94:                if ((*netmatch)(addr, &ifp->int_addr))
                     95:                        break;
                     96:        }
                     97:        return (ifp);
                     98: }
                     99: 
                    100: /*
                    101:  * Find an interface from which the specified address
                    102:  * should have come from.  Used for figuring out which
                    103:  * interface a packet came in on -- for tracing.
                    104:  */
                    105: struct interface *
                    106: if_iflookup(addr)
                    107:        struct sockaddr *addr;
                    108: {
                    109:        register struct interface *ifp, *maybe;
                    110:        register int af = addr->sa_family;
                    111:        register int (*netmatch)();
                    112: 
                    113:        if (af >= af_max)
                    114:                return (0);
                    115:        maybe = 0;
                    116:        netmatch = afswitch[af].af_netmatch;
                    117:        for (ifp = ifnet; ifp; ifp = ifp->int_next) {
                    118:                if (ifp->int_addr.sa_family != af)
                    119:                        continue;
                    120:                if (same(&ifp->int_addr, addr))
                    121:                        break;
                    122:                if ((ifp->int_flags & IFF_BROADCAST) &&
                    123:                    same(&ifp->int_broadaddr, addr))
                    124:                        break;
                    125:                if ((ifp->int_flags & IFF_POINTOPOINT) &&
                    126:                    same(&ifp->int_dstaddr, addr))
                    127:                        break;
                    128:                if (maybe == 0 && (*netmatch)(addr, &ifp->int_addr))
                    129:                        maybe = ifp;
                    130:        }
                    131:        if (ifp == 0)
                    132:                ifp = maybe;
                    133:        return (ifp);
                    134: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.