diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2007-04-17 01:28:15 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2007-04-17 01:28:15 +0000 |
commit | 37e53adf29fff30cacd9094f1fd0be791c732c10 (patch) | |
tree | c06214e3c43d6b9dfccb6e3a4ae245a1f2051841 /sys/dev | |
parent | d7792e19db0a20a8c6fe2811933dfc4c4955bbb2 (diff) |
initial bits for the network interface glue.
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/pci/if_tht.c | 55 |
1 files changed, 54 insertions, 1 deletions
diff --git a/sys/dev/pci/if_tht.c b/sys/dev/pci/if_tht.c index 61fa862db75..a2e7d295aa0 100644 --- a/sys/dev/pci/if_tht.c +++ b/sys/dev/pci/if_tht.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_tht.c,v 1.14 2007/04/16 22:17:54 dlg Exp $ */ +/* $OpenBSD: if_tht.c,v 1.15 2007/04/17 01:28:14 dlg Exp $ */ /* * Copyright (c) 2007 David Gwynne <dlg@openbsd.org> @@ -43,6 +43,8 @@ #include <net/if.h> #include <net/if_dl.h> +#include <net/if_media.h> +#include <net/if_types.h> #ifdef INET #include <netinet/in.h> @@ -136,6 +138,9 @@ struct tht_attach_args { }; /* port operations */ +int tht_ioctl(struct ifnet *, u_long, caddr_t); +void tht_start(struct ifnet *); +void tht_watchdog(struct ifnet *); void tht_read_lladdr(struct tht_softc *); /* bus space operations */ @@ -254,6 +259,7 @@ tht_attach(struct device *parent, struct device *self, void *aux) struct thtc_softc *csc = (struct thtc_softc *)parent; struct tht_softc *sc = (struct tht_softc *)self; struct tht_attach_args *taa = aux; + struct ifnet *ifp; sc->sc_thtc = csc; @@ -275,6 +281,21 @@ tht_attach(struct device *parent, struct device *self, void *aux) tht_read_lladdr(sc); bcopy(sc->sc_lladdr, sc->sc_ac.ac_enaddr, ETHER_ADDR_LEN); + ifp = &sc->sc_ac.ac_if; + ifp->if_softc = sc; + ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST; + ifp->if_capabilities = IFCAP_VLAN_MTU; + ifp->if_ioctl = tht_ioctl; + ifp->if_start = tht_start; + ifp->if_watchdog = tht_watchdog; + ifp->if_hardmtu = 1500; /* XXX */ + strlcpy(ifp->if_xname, DEVNAME(sc), IFNAMSIZ); + IFQ_SET_MAXLEN(&ifp->if_snd, 400); + IFQ_SET_READY(&ifp->if_snd); + + if_attach(ifp); + ether_ifattach(ifp); + printf(" address %s\n", ether_sprintf(sc->sc_ac.ac_enaddr)); } @@ -284,6 +305,38 @@ tht_intr(void *arg) return (0); } +int +tht_ioctl(struct ifnet *ifp, u_long cmd, caddr_t addr) +{ + struct tht_softc *sc = ifp->if_softc; + int error; + int s; + + s = splnet(); + + error = ether_ioctl(ifp, &sc->sc_ac, cmd, addr); + if (error > 0) { + splx(s); + return (error); + } + + splx(s); + + return (ENOTTY); +} + +void +tht_start(struct ifnet *ifp) +{ + /* do nothing */ +} + +void +tht_watchdog(struct ifnet *ifp) +{ + /* do nothing */ +} + void tht_read_lladdr(struct tht_softc *sc) { |