Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/chs-ubc2]: src/sys Update from trunk.
details: https://anonhg.NetBSD.org/src/rev/835746459070
branches: chs-ubc2
changeset: 471436:835746459070
user: thorpej <thorpej%NetBSD.org@localhost>
date: Mon Aug 02 22:04:47 1999 +0000
description:
Update from trunk.
diffstat:
sys/dev/pcmcia/Makefile | 4 +-
sys/dev/pcmcia/files.pcmcia | 8 +-
sys/dev/pcmcia/if_wi.c | 1339 ++++++++++++++++++++++++++++++++++++
sys/dev/pcmcia/if_wi_ieee.h | 296 +++++++
sys/dev/pcmcia/if_wireg.h | 559 +++++++++++++++
sys/dev/pcmcia/if_wivar.h | 102 ++
sys/dev/pcmcia/pcmcia_cis.c | 34 +-
sys/dev/qbus/if_qe.c | 57 +-
sys/dev/qbus/ubareg.h | 241 ------
sys/dev/raidframe/rf_driver.c | 3 +-
sys/dev/raidframe/rf_layout.c | 9 +-
sys/dev/raidframe/rf_netbsdkintf.c | 44 +-
sys/dev/raidframe/rf_raid.h | 7 +-
sys/dev/raidframe/rf_states.c | 12 +-
sys/dev/raidframe/rf_threadstuff.h | 4 +-
sys/dev/rasops/rasops.c | 22 +-
sys/dev/rasops/rasops1.c | 8 +-
sys/dev/rasops/rasops2.c | 6 +-
sys/dev/rasops/rasops_bitops.h | 59 +-
sys/dev/rcons/files.rcons | 4 +-
sys/dev/sbus/stp4020.c | 6 +-
sys/dev/scsipi/atapiconf.c | 4 +-
sys/dev/scsipi/scsi_changer.h | 18 +-
sys/dev/scsipi/scsiconf.c | 6 +-
sys/dev/sun/ms.c | 35 +-
sys/dev/sun/ms_zs.c | 9 +-
sys/dev/tc/cfb.c | 189 ++--
sys/dev/tc/mfb.c | 27 +-
sys/dev/tc/tfb.c | 109 +-
sys/dev/usb/TODO | 4 -
sys/dev/usb/uhci.c | 35 +-
sys/dev/usb/ukbd.c | 18 +-
sys/dev/usb/ulpt.c | 16 +-
sys/dev/usb/usb.c | 6 +-
sys/dev/usb/usbdi.c | 15 +-
sys/dev/vme/xd.c | 3 +-
sys/dev/vme/xy.c | 3 +-
sys/dev/wscons/files.wscons | 5 +-
sys/dev/wscons/wscons_callbacks.h | 13 +-
sys/dev/wscons/wsconsio.h | 29 +-
sys/dev/wscons/wsdisplay.c | 117 +-
sys/dev/wscons/wskbd.c | 223 ++++-
sys/dev/wscons/wskbdvar.h | 4 +-
sys/dev/wscons/wsmouse.c | 132 +++-
sys/dev/wscons/wsmousevar.h | 8 +-
sys/dev/wscons/wsmux.c | 737 +++++++++++++++++++
sys/dev/wscons/wsmuxvar.h | 88 ++
sys/filecorefs/filecore_lookup.c | 33 +-
sys/filecorefs/filecore_node.c | 6 +-
sys/filecorefs/filecore_node.h | 6 +-
sys/filecorefs/filecore_vfsops.c | 3 +-
sys/filecorefs/filecore_vnops.c | 57 +-
sys/isofs/cd9660/cd9660_extern.h | 8 +-
sys/isofs/cd9660/cd9660_lookup.c | 34 +-
sys/isofs/cd9660/cd9660_mount.h | 3 +-
sys/isofs/cd9660/cd9660_node.c | 6 +-
sys/isofs/cd9660/cd9660_node.h | 3 +-
sys/isofs/cd9660/cd9660_rrip.c | 25 +-
sys/isofs/cd9660/cd9660_util.c | 82 +-
sys/isofs/cd9660/cd9660_vfsops.c | 99 ++-
sys/isofs/cd9660/cd9660_vnops.c | 83 +-
sys/isofs/cd9660/iso.h | 39 +-
62 files changed, 4282 insertions(+), 882 deletions(-)
diffs (truncated from 7340 to 300 lines):
diff -r 41414be519f1 -r 835746459070 sys/dev/pcmcia/Makefile
--- a/sys/dev/pcmcia/Makefile Mon Aug 02 22:04:40 1999 +0000
+++ b/sys/dev/pcmcia/Makefile Mon Aug 02 22:04:47 1999 +0000
@@ -1,9 +1,9 @@
-# $NetBSD: Makefile,v 1.2 1998/07/19 17:28:15 christos Exp $
+# $NetBSD: Makefile,v 1.2.10.1 1999/08/02 22:04:47 thorpej Exp $
# use 'make -f Makefile.pcmciadevs' to make pcmciadevs.h and pcmciadevs_data.h
INCSDIR= /usr/include/dev/pcmcia
-INCS= pcmciachip.h pcmciareg.h pcmciavar.h
+INCS= pcmciachip.h pcmciareg.h pcmciavar.h if_wi_ieee.h
.include <bsd.kinc.mk>
diff -r 41414be519f1 -r 835746459070 sys/dev/pcmcia/files.pcmcia
--- a/sys/dev/pcmcia/files.pcmcia Mon Aug 02 22:04:40 1999 +0000
+++ b/sys/dev/pcmcia/files.pcmcia Mon Aug 02 22:04:47 1999 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.pcmcia,v 1.14 1999/01/01 19:30:03 christos Exp $
+# $NetBSD: files.pcmcia,v 1.14.4.1 1999/08/02 22:04:47 thorpej Exp $
#
# Config.new file and device description for machine-independent PCMCIA code.
# Included by ports that need it.
@@ -63,3 +63,9 @@
device cnw: arp, ether, ifnet
attach cnw at pcmcia
file dev/pcmcia/if_cnw.c cnw
+
+# Lucent WaveLan IEEE (802.11)
+device wi: arp, ether, ifnet
+attach wi at pcmcia
+file dev/pcmcia/if_wi.c wi
+
diff -r 41414be519f1 -r 835746459070 sys/dev/pcmcia/if_wi.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/dev/pcmcia/if_wi.c Mon Aug 02 22:04:47 1999 +0000
@@ -0,0 +1,1339 @@
+/* $NetBSD: if_wi.c,v 1.2.2.2 1999/08/02 22:04:48 thorpej Exp $ */
+
+/*
+ * Copyright (c) 1997, 1998, 1999
+ * Bill Paul <wpaul%ctr.columbia.edu@localhost>. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ * must display the following acknowledgement:
+ * This product includes software developed by Bill Paul.
+ * 4. Neither the name of the author nor the names of any co-contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY Bill Paul AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL Bill Paul OR THE VOICES IN HIS HEAD
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
+ * THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * $Id: if_wi.c,v 1.2.2.2 1999/08/02 22:04:48 thorpej Exp $
+ */
+
+/*
+ * Lucent WaveLAN/IEEE 802.11 PCMCIA driver for NetBSD.
+ *
+ * Original FreeBSD driver written by Bill Paul <wpaul%ctr.columbia.edu@localhost>
+ * Electrical Engineering Department
+ * Columbia University, New York City
+ */
+
+/*
+ * The WaveLAN/IEEE adapter is the second generation of the WaveLAN
+ * from Lucent. Unlike the older cards, the new ones are programmed
+ * entirely via a firmware-driven controller called the Hermes.
+ * Unfortunately, Lucent will not release the Hermes programming manual
+ * without an NDA (if at all). What they do release is an API library
+ * called the HCF (Hardware Control Functions) which is supposed to
+ * do the device-specific operations of a device driver for you. The
+ * publically available version of the HCF library (the 'HCF Light') is
+ * a) extremely gross, b) lacks certain features, particularly support
+ * for 802.11 frames, and c) is contaminated by the GNU Public License.
+ *
+ * This driver does not use the HCF or HCF Light at all. Instead, it
+ * programs the Hermes controller directly, using information gleaned
+ * from the HCF Light code and corresponding documentation.
+ *
+ * This driver supports both the PCMCIA and ISA versions of the
+ * WaveLAN/IEEE cards. Note however that the ISA card isn't really
+ * anything of the sort: it's actually a PCMCIA bridge adapter
+ * that fits into an ISA slot, into which a PCMCIA WaveLAN card is
+ * inserted. Consequently, you need to use the pccard support for
+ * both the ISA and PCMCIA adapters.
+ */
+
+/*
+ * FreeBSD driver ported to NetBSD by Bill Sommerfeld in the back of the
+ * Oslo IETF plenary meeting.
+ */
+
+#define WI_HERMES_AUTOINC_WAR /* Work around data write autoinc bug. */
+#define WI_HERMES_STATS_WAR /* Work around stats counter bug. */
+
+#include "opt_inet.h"
+#include "bpfilter.h"
+
+#include <sys/param.h>
+#include <sys/systm.h>
+#include <sys/device.h>
+#include <sys/socket.h>
+#include <sys/mbuf.h>
+#include <sys/ioctl.h>
+#include <sys/kernel.h> /* for hz */
+
+#include <net/if.h>
+#include <net/if_dl.h>
+#include <net/if_media.h>
+#include <net/if_ether.h>
+
+#ifdef INET
+#include <netinet/in.h>
+#include <netinet/in_systm.h>
+#include <netinet/in_var.h>
+#include <netinet/ip.h>
+#include <netinet/if_inarp.h>
+#endif
+
+#if NBPFILTER > 0
+#include <net/bpf.h>
+#include <net/bpfdesc.h>
+#endif
+
+#include <dev/pcmcia/if_wireg.h>
+
+#include <dev/pcmcia/pcmciareg.h>
+#include <dev/pcmcia/pcmciavar.h>
+#include <dev/pcmcia/pcmciadevs.h>
+
+#include <dev/pcmcia/if_wivar.h>
+
+#include <dev/pcmcia/if_wi_ieee.h>
+
+#if !defined(lint)
+static const char rcsid[] =
+ "$Id: if_wi.c,v 1.2.2.2 1999/08/02 22:04:48 thorpej Exp $";
+#endif
+
+#ifdef foo
+static u_int8_t wi_mcast_addr[6] = { 0x01, 0x60, 0x1D, 0x00, 0x01, 0x00 };
+#endif
+
+static int wi_match __P((struct device *, struct cfdata *, void *));
+static void wi_attach __P((struct device *, struct device *, void *));
+
+
+static int wi_intr __P((void *arg));
+
+static void wi_reset __P((struct wi_softc *));
+static int wi_ioctl __P((struct ifnet *, u_long, caddr_t));
+static void wi_init __P((void *));
+static void wi_start __P((struct ifnet *));
+static void wi_stop __P((struct wi_softc *));
+static void wi_watchdog __P((struct ifnet *));
+static void wi_rxeof __P((struct wi_softc *));
+static void wi_txeof __P((struct wi_softc *, int));
+static void wi_update_stats __P((struct wi_softc *));
+static void wi_setmulti __P((struct wi_softc *));
+
+static int wi_cmd __P((struct wi_softc *, int, int));
+static int wi_read_record __P((struct wi_softc *, struct wi_ltv_gen *));
+static int wi_write_record __P((struct wi_softc *, struct wi_ltv_gen *));
+static int wi_read_data __P((struct wi_softc *, int,
+ int, caddr_t, int));
+static int wi_write_data __P((struct wi_softc *, int,
+ int, caddr_t, int));
+static int wi_seek __P((struct wi_softc *, int, int, int));
+static int wi_alloc_nicmem __P((struct wi_softc *, int, int *));
+static void wi_inquire __P((void *));
+static void wi_setdef __P((struct wi_softc *, struct wi_req *));
+static int wi_mgmt_xmit __P((struct wi_softc *, caddr_t, int));
+static void wi_shutdown __P((void *));
+
+static int wi_enable __P((struct wi_softc *));
+static int wi_disable __P((struct wi_softc *));
+
+
+struct cfattach wi_ca =
+{
+ sizeof(struct wi_softc), wi_match, wi_attach
+};
+
+static int
+wi_match(parent, match, aux)
+ struct device *parent;
+ struct cfdata *match;
+ void *aux;
+{
+ struct pcmcia_attach_args *pa = aux;
+
+ return (pa->manufacturer == PCMCIA_VENDOR_LUCENT &&
+ pa->product == PCMCIA_PRODUCT_LUCENT_WAVELAN_IEEE);
+}
+
+int
+wi_enable(sc)
+ struct wi_softc *sc;
+{
+ struct ifnet *ifp = &sc->sc_ethercom.ec_if;
+
+ sc->sc_ih = pcmcia_intr_establish(sc->sc_pf, IPL_NET, wi_intr, sc);
+ if (sc->sc_ih == NULL) {
+ printf("%s: couldn't establish interrupt handler\n",
+ sc->sc_dev.dv_xname);
+ return (EIO);
+ }
+ if (pcmcia_function_enable(sc->sc_pf) != 0) {
+ printf("%s: couldn't enable card\n", sc->sc_dev.dv_xname);
+ return (EIO);
+ }
+
+ wi_init(sc);
+ ifp->if_flags |= IFF_RUNNING;
+ return 0;
+}
+
+int
+wi_disable(sc)
+ struct wi_softc *sc;
+{
+ struct ifnet *ifp = &sc->sc_ethercom.ec_if;
+
+ if (ifp->if_flags & IFF_RUNNING) {
+ wi_stop(sc);
+ pcmcia_function_disable(sc->sc_pf);
+ pcmcia_intr_disestablish(sc->sc_pf, sc->sc_ih);
+ }
+ ifp->if_flags &= ~IFF_RUNNING;
+ ifp->if_timer = 0;
+
+ /* XXX */;
+ return 0;
+}
+
+
+/*
+ * Attach the card.
+ */
+void
+wi_attach(parent, self, aux)
+ struct device *parent, *self;
+ void *aux;
+{
+ struct wi_softc *sc = (void *) self;
+ struct pcmcia_attach_args *pa = aux;
+ struct ifnet *ifp = &sc->sc_ethercom.ec_if;
+ struct wi_ltv_macaddr mac;
+ struct wi_ltv_gen gen;
+
+ ifp = &sc->sc_ethercom.ec_if;
+
+ /* Enable the card */
+ sc->sc_pf = pa->pf;
+ pcmcia_function_init(sc->sc_pf, sc->sc_pf->cfe_head.sqh_first);
+ if (pcmcia_function_enable(sc->sc_pf)) {
+ printf(": function enable failed\n");
+ return;
+ }
+
+ /* allocate/map ISA I/O space */
+
+ if (pcmcia_io_alloc(sc->sc_pf, 0, WI_IOSIZ, WI_IOSIZ,
+ &sc->sc_pcioh) != 0) {
+ printf(": can't allocate i/o space\n");
+ return;
+ }
+ if (pcmcia_io_map(sc->sc_pf, PCMCIA_WIDTH_IO16, 0,
+ WI_IOSIZ, &sc->sc_pcioh, &sc->sc_iowin) != 0) {
+ printf(": can't map i/o space\n");
+ return;
+ }
+ sc->wi_btag = sc->sc_pcioh.iot;
+ sc->wi_bhandle = sc->sc_pcioh.ioh;
+
+ /* Make sure interrupts are disabled. */
+ CSR_WRITE_2(sc, WI_INT_EN, 0);
+ CSR_WRITE_2(sc, WI_EVENT_ACK, 0xFFFF);
+
+ /* Reset the NIC. */
+ wi_reset(sc);
Home |
Main Index |
Thread Index |
Old Index