[BACK]Return to netif.c CVS log [TXT][DIR] Up to [local] / sys / lib / libsa

Annotation of sys/lib/libsa/netif.c, Revision 1.1

1.1     ! nbrk        1: /*     $OpenBSD: netif.c,v 1.8 2003/08/11 06:23:09 deraadt Exp $       */
        !             2: /*     $NetBSD: netif.c,v 1.7 1996/10/13 02:29:03 christos Exp $       */
        !             3:
        !             4: /*
        !             5:  * Copyright (c) 1993 Adam Glass
        !             6:  * All rights reserved.
        !             7:  *
        !             8:  * Redistribution and use in source and binary forms, with or without
        !             9:  * modification, are permitted provided that the following conditions
        !            10:  * are met:
        !            11:  * 1. Redistributions of source code must retain the above copyright
        !            12:  *    notice, this list of conditions and the following disclaimer.
        !            13:  * 2. Redistributions in binary form must reproduce the above copyright
        !            14:  *    notice, this list of conditions and the following disclaimer in the
        !            15:  *    documentation and/or other materials provided with the distribution.
        !            16:  * 3. All advertising materials mentioning features or use of this software
        !            17:  *    must display the following acknowledgement:
        !            18:  *     This product includes software developed by Adam Glass.
        !            19:  * 4. The name of the Author may not be used to endorse or promote products
        !            20:  *    derived from this software without specific prior written permission.
        !            21:  *
        !            22:  * THIS SOFTWARE IS PROVIDED BY Adam Glass ``AS IS'' AND
        !            23:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
        !            24:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
        !            25:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
        !            26:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
        !            27:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
        !            28:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
        !            29:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
        !            30:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
        !            31:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
        !            32:  * SUCH DAMAGE.
        !            33:  */
        !            34:
        !            35: #include <sys/param.h>
        !            36: #include <sys/types.h>
        !            37: #include <sys/cdefs.h>
        !            38: #include <sys/mount.h>
        !            39:
        !            40: #include <netinet/in.h>
        !            41: #include <netinet/in_systm.h>
        !            42:
        !            43: #include "stand.h"
        !            44: #include "net.h"
        !            45: #include "netif.h"
        !            46:
        !            47: struct iodesc sockets[SOPEN_MAX];
        !            48: #ifdef NETIF_DEBUG
        !            49: int netif_debug = 0;
        !            50: #endif
        !            51:
        !            52: /*
        !            53:  * netif_init:
        !            54:  *
        !            55:  * initialize the generic network interface layer
        !            56:  */
        !            57:
        !            58: void
        !            59: netif_init(void)
        !            60: {
        !            61:        struct netif_driver *drv;
        !            62:        int d, i;
        !            63:
        !            64: #ifdef NETIF_DEBUG
        !            65:        if (netif_debug)
        !            66:                printf("netif_init: called\n");
        !            67: #endif
        !            68:        for (d = 0; d < n_netif_drivers; d++) {
        !            69:                drv = netif_drivers[d];
        !            70:                for (i = 0; i < drv->netif_nifs; i++)
        !            71:                        drv->netif_ifs[i].dif_used = 0;
        !            72:        }
        !            73: }
        !            74:
        !            75: static int
        !            76: netif_match(struct netif *nif, void *machdep_hint)
        !            77: {
        !            78:        struct netif_driver *drv = nif->nif_driver;
        !            79:
        !            80: #if 0
        !            81:        if (netif_debug)
        !            82:                printf("%s%d: netif_match (%d)\n", drv->netif_bname,
        !            83:                    nif->nif_unit, nif->nif_sel);
        !            84: #endif
        !            85:        return drv->netif_match(nif, machdep_hint);
        !            86: }
        !            87:
        !            88: struct netif *
        !            89: netif_select(void *machdep_hint)
        !            90: {
        !            91:        int d, u, unit_done, s;
        !            92:        struct netif_driver *drv;
        !            93:        struct netif cur_if;
        !            94:        static struct netif best_if;
        !            95:        int best_val;
        !            96:        int val;
        !            97:
        !            98:        best_val = 0;
        !            99:        best_if.nif_driver = NULL;
        !           100:
        !           101: #ifdef NETIF_DEBUG
        !           102:        if (netif_debug)
        !           103:                printf("netif_select: %d interfaces\n", n_netif_drivers);
        !           104: #endif
        !           105:
        !           106:        for (d = 0; d < n_netif_drivers; d++) {
        !           107:                cur_if.nif_driver = netif_drivers[d];
        !           108:                drv = cur_if.nif_driver;
        !           109:
        !           110:                for (u = 0; u < drv->netif_nifs; u++) {
        !           111:                        cur_if.nif_unit = u;
        !           112:                        unit_done = 0;
        !           113:
        !           114: #ifdef NETIF_DEBUG
        !           115:                        if (netif_debug)
        !           116:                                printf("\t%s%d:", drv->netif_bname,
        !           117:                                    cur_if.nif_unit);
        !           118: #endif
        !           119:
        !           120:                        for (s = 0; s < drv->netif_ifs[u].dif_nsel; s++) {
        !           121:                                cur_if.nif_sel = s;
        !           122:
        !           123:                                if (drv->netif_ifs[u].dif_used & (1 << s)) {
        !           124: #ifdef NETIF_DEBUG
        !           125:                                        if (netif_debug)
        !           126:                                                printf(" [%d used]", s);
        !           127: #endif
        !           128:                                        continue;
        !           129:                                }
        !           130:
        !           131:                                val = netif_match(&cur_if, machdep_hint);
        !           132: #ifdef NETIF_DEBUG
        !           133:                                if (netif_debug)
        !           134:                                        printf(" [%d -> %d]", s, val);
        !           135: #endif
        !           136:                                if (val > best_val) {
        !           137:                                        best_val = val;
        !           138:                                        best_if = cur_if;
        !           139:                                }
        !           140:                        }
        !           141: #ifdef NETIF_DEBUG
        !           142:                        if (netif_debug)
        !           143:                                printf("\n");
        !           144: #endif
        !           145:                }
        !           146:        }
        !           147:
        !           148:        if (best_if.nif_driver == NULL)
        !           149:                return NULL;
        !           150:
        !           151:        best_if.nif_driver->netif_ifs[best_if.nif_unit].dif_used |=
        !           152:            (1 << best_if.nif_sel);
        !           153:
        !           154: #ifdef NETIF_DEBUG
        !           155:        if (netif_debug)
        !           156:                printf("netif_select: %s%d(%d) wins\n",
        !           157:                    best_if.nif_driver->netif_bname,
        !           158:                    best_if.nif_unit, best_if.nif_sel);
        !           159: #endif
        !           160:        return &best_if;
        !           161: }
        !           162:
        !           163: int
        !           164: netif_probe(struct netif *nif, void *machdep_hint)
        !           165: {
        !           166:        struct netif_driver *drv = nif->nif_driver;
        !           167:
        !           168: #ifdef NETIF_DEBUG
        !           169:        if (netif_debug)
        !           170:                printf("%s%d: netif_probe\n", drv->netif_bname, nif->nif_unit);
        !           171: #endif
        !           172:        return drv->netif_probe(nif, machdep_hint);
        !           173: }
        !           174:
        !           175: void
        !           176: netif_attach(struct netif *nif, struct iodesc *desc, void *machdep_hint)
        !           177: {
        !           178:        struct netif_driver *drv = nif->nif_driver;
        !           179:
        !           180: #ifdef NETIF_DEBUG
        !           181:        if (netif_debug)
        !           182:                printf("%s%d: netif_attach\n", drv->netif_bname, nif->nif_unit);
        !           183: #endif
        !           184:        desc->io_netif = nif;
        !           185: #ifdef PARANOID
        !           186:        if (drv->netif_init == NULL)
        !           187:                panic("%s%d: no netif_init support", drv->netif_bname,
        !           188:                    nif->nif_unit);
        !           189: #endif
        !           190:        drv->netif_init(desc, machdep_hint);
        !           191:        bzero(drv->netif_ifs[nif->nif_unit].dif_stats,
        !           192:            sizeof(struct netif_stats));
        !           193: }
        !           194:
        !           195: void
        !           196: netif_detach(struct netif *nif)
        !           197: {
        !           198:        struct netif_driver *drv = nif->nif_driver;
        !           199:
        !           200: #ifdef NETIF_DEBUG
        !           201:        if (netif_debug)
        !           202:                printf("%s%d: netif_detach\n", drv->netif_bname, nif->nif_unit);
        !           203: #endif
        !           204: #ifdef PARANOID
        !           205:        if (drv->netif_end == NULL)
        !           206:                panic("%s%d: no netif_end support", drv->netif_bname,
        !           207:                    nif->nif_unit);
        !           208: #endif
        !           209:        drv->netif_end(nif);
        !           210: }
        !           211:
        !           212: ssize_t
        !           213: netif_get(struct iodesc *desc, void *pkt, size_t len, time_t timo)
        !           214: {
        !           215: #ifdef NETIF_DEBUG
        !           216:        struct netif *nif = desc->io_netif;
        !           217: #endif
        !           218:        struct netif_driver *drv = desc->io_netif->nif_driver;
        !           219:        ssize_t rv;
        !           220:
        !           221: #ifdef NETIF_DEBUG
        !           222:        if (netif_debug)
        !           223:                printf("%s%d: netif_get\n", drv->netif_bname, nif->nif_unit);
        !           224: #endif
        !           225: #ifdef PARANOID
        !           226:        if (drv->netif_get == NULL)
        !           227:                panic("%s%d: no netif_get support", drv->netif_bname,
        !           228:                    nif->nif_unit);
        !           229: #endif
        !           230:        rv = drv->netif_get(desc, pkt, len, timo);
        !           231: #ifdef NETIF_DEBUG
        !           232:        if (netif_debug)
        !           233:                printf("%s%d: netif_get returning %d\n", drv->netif_bname,
        !           234:                    nif->nif_unit, rv);
        !           235: #endif
        !           236:        return rv;
        !           237: }
        !           238:
        !           239: ssize_t
        !           240: netif_put(struct iodesc *desc, void *pkt, size_t len)
        !           241: {
        !           242: #ifdef NETIF_DEBUG
        !           243:        struct netif *nif = desc->io_netif;
        !           244: #endif
        !           245:        struct netif_driver *drv = desc->io_netif->nif_driver;
        !           246:        ssize_t rv;
        !           247:
        !           248: #ifdef NETIF_DEBUG
        !           249:        if (netif_debug)
        !           250:                printf("%s%d: netif_put\n", drv->netif_bname, nif->nif_unit);
        !           251: #endif
        !           252: #ifdef PARANOID
        !           253:        if (drv->netif_put == NULL)
        !           254:                panic("%s%d: no netif_put support", drv->netif_bname,
        !           255:                    nif->nif_unit);
        !           256: #endif
        !           257:        rv = drv->netif_put(desc, pkt, len);
        !           258: #ifdef NETIF_DEBUG
        !           259:        if (netif_debug)
        !           260:                printf("%s%d: netif_put returning %d\n", drv->netif_bname,
        !           261:                    nif->nif_unit, rv);
        !           262: #endif
        !           263:        return rv;
        !           264: }
        !           265:
        !           266: struct iodesc *
        !           267: socktodesc(sock)
        !           268:        int sock;
        !           269: {
        !           270:        if (sock >= SOPEN_MAX) {
        !           271:                errno = EBADF;
        !           272:                return (NULL);
        !           273:        }
        !           274:        return (&sockets[sock]);
        !           275: }
        !           276:
        !           277: int
        !           278: netif_open(void *machdep_hint)
        !           279: {
        !           280:        int fd;
        !           281:        struct iodesc *s;
        !           282:        struct netif *nif;
        !           283:
        !           284:        /* find a free socket */
        !           285:        for (fd = 0, s = sockets; fd < SOPEN_MAX; fd++, s++)
        !           286:                if (s->io_netif == (struct netif *)0)
        !           287:                        goto fnd;
        !           288:        errno = EMFILE;
        !           289:        return (-1);
        !           290:
        !           291: fnd:
        !           292:        bzero(s, sizeof(*s));
        !           293:        netif_init();
        !           294:        nif = netif_select(machdep_hint);
        !           295:        if (!nif)
        !           296:                panic("netboot: no interfaces left untried");
        !           297:        if (netif_probe(nif, machdep_hint)) {
        !           298:                printf("netboot: couldn't probe %s%d\n",
        !           299:                    nif->nif_driver->netif_bname, nif->nif_unit);
        !           300:                errno = EINVAL;
        !           301:                return(-1);
        !           302:        }
        !           303:        netif_attach(nif, s, machdep_hint);
        !           304:
        !           305:        return(fd);
        !           306: }
        !           307:
        !           308: int
        !           309: netif_close(int sock)
        !           310: {
        !           311:        if (sock >= SOPEN_MAX) {
        !           312:                errno = EBADF;
        !           313:                return(-1);
        !           314:        }
        !           315:        netif_detach(sockets[sock].io_netif);
        !           316:        sockets[sock].io_netif = (struct netif *)0;
        !           317:
        !           318:        return(0);
        !           319: }

CVSweb