1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-11 14:10:34 +00:00
freebsd/sys/dev/usb/usbdevs.h

528 lines
23 KiB
C
Raw Normal View History

/* $FreeBSD$ */
/*
* THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
*
* generated from:
2000-03-20 19:49:50 +00:00
* FreeBSD: src/sys/dev/usb/usbdevs,v 1.14 2000/03/20 19:49:20 gehenna Exp
*/
/*
* Copyright (c) 1998 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
* by Lennart Augustsson (augustss@carlstedt.se) at
* Carlstedt Research & Technology.
*
* 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 the NetBSD
* Foundation, Inc. and its contributors.
* 4. Neither the name of The NetBSD Foundation nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. 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 THE FOUNDATION OR CONTRIBUTORS
* 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.
*/
/*
* List of known USB vendors
*/
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AOX 0x03e8 /* AOX Inc. */
#define USB_VENDOR_ATMEL 0x03eb /* Atmel Corporation */
#define USB_VENDOR_HP 0x03f0 /* Hewlett Packard */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ADAPTEC 0x03f3 /* Adaptec, Inc. */
#define USB_VENDOR_ACERLABS 0x0402 /* Acer Labs Inc. */
#define USB_VENDOR_NEC 0x0409 /* NEC */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_KODAK 0x040a /* Eastman Kodak Corp. */
This commit adds device driver support for the ADMtek AN986 Pegasus USB ethernet chip. Adapters that use this chip include the LinkSys USB100TX. There are a few others, but I'm not certain of their availability in the U.S. I used an ADMtek eval board for development. Note that while the ADMtek chip is a 100Mbps device, you can't really get 100Mbps speeds over USB. Regardless, this driver uses miibus to allow speed and duplex mode selection as well as autonegotiation. Building and kldloading the driver as a module is also supported. Note that in order to make this driver work, I had to make what some may consider an ugly hack to sys/dev/usb/usbdi.c. The usbd_transfer() function will use tsleep() for synchronous transfers that don't complete right away. This is a problem since there are times when we need to do sync transfers from an interrupt context (i.e. when reading registers from the MAC via the control endpoint), where tsleep() us a no-no. My hack allows the driver to have the code poll for transfer completion subject to the xfer->timeout timeout rather that calling tsleep(). This hack is controlled by a quirk entry and is only enabled for the ADMtek device. Now, I'm sure there are a few of you out there ready to jump on me and suggest some other approach that doesn't involve a busy wait. The only solution that might work is to handle the interrupts in a kernel thread, where you may have something resembling a process context that makes it okay to tsleep(). This is lovely, except we don't have any mechanism like that now, and I'm not about to implement such a thing myself since it's beyond the scope of driver development. (Translation: I'll be damned if I know how to do it.) If FreeBSD ever aquires such a mechanism, I'll be glad to revisit the driver to take advantage of it. In the meantime, I settled for what I perceived to be the solution that involved the least amount of code changes. In general, the hit is pretty light. Also note that my only USB test box has a UHCI controller: I haven't I don't have a machine with an OHCI controller available. Highlights: - Updated usb_quirks.* to add UQ_NO_TSLEEP quirk for ADMtek part. - Updated usbdevs and regenerated generated files - Updated HARDWARE.TXT and RELNOTES.TXT files - Updated sysinstall/device.c and userconfig.c - Updated kernel configs -- device aue0 is commented out by default - Updated /sys/conf/files - Added new kld module directory
1999-12-28 02:01:18 +00:00
#define USB_VENDOR_MELCO 0x0411 /* Melco Inc. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ADI 0x0422 /* ADI Systems Inc. */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_CATC 0x0423 /* Computer Access Technology Corp. */
#define USB_VENDOR_GRAVIS 0x0428 /* Advanced Gravis Computer Tech. Ltd. */
2000-01-13 20:17:11 +00:00
#define USB_VENDOR_SUN 0x0430 /* Sun Microsystems */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AMD 0x0438 /* Advanced Micro Devices */
#define USB_VENDOR_LEXMARK 0x043d /* Lexmark International Inc. */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_NANAO 0x0440 /* NANAO Corp. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ALPS 0x044e /* Alps Electric Co., Ltd. */
#define USB_VENDOR_THRUST 0x044f /* Thrustmaster */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_TI 0x0451 /* Texas Instruments */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ANALOGDEVICES 0x0456 /* Analog Devices, Inc. */
#define USB_VENDOR_KYE 0x0458 /* KYE Systems Corp. */
#define USB_VENDOR_MICROSOFT 0x045e /* Microsoft */
#define USB_VENDOR_PRIMAX 0x0461 /* Primax Electronics */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AMP 0x0464 /* AMP Incorporated */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_CHERRY 0x046a /* Cherry Mikroschalter GmbH */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_MEGATRENDS 0x046b /* American Megatrends */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_LOGITECH 0x046d /* Logitech Inc. */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BTC 0x046e /* Behavior Tech. Computer Corporation */
#define USB_VENDOR_PHILIPS 0x0471 /* Philips */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_CONNECTIX 0x0478 /* Connectix Corp. */
#define USB_VENDOR_LUCENT 0x047e /* Lucent */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_STMICRO 0x0483 /* STMicroelectronics */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ACERP 0x04a5 /* Acer Peripherals Inc. */
#define USB_VENDOR_CANON 0x04a9 /* Canon Inc. */
#define USB_VENDOR_CYPRESS 0x04b4 /* Cypress Semiconductor */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_EPSON 0x04b8 /* Seiko Epson Corp. */
#define USB_VENDOR_3COMUSR 0x04c1 /* U.S. Robotics */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_KONICA 0x04c8 /* Konica Corp. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ALTEC 0x04d2 /* Altec Lansing Technologies, Inc. */
#define USB_VENDOR_SHUTTLE 0x04e6 /* Shuttle Technology */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ANNABOOKS 0x04ed /* Annabooks */
#define USB_VENDOR_CHICONY 0x04f2 /* Chicony Electronics Co., Ltd. */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BROTHER 0x04f9 /* Brother Industries, Ltd. */
#define USB_VENDOR_DALLAS 0x04fa /* Dallas Semiconductor */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ACER 0x0502 /* Acer, Inc. */
#define USB_VENDOR_3COM 0x0506 /* 3Com Corporation */
#define USB_VENDOR_AZTECH 0x0509 /* Aztech Systems Ltd */
#define USB_VENDOR_BELKIN 0x050d /* Belkin Components */
#define USB_VENDOR_KAWATSU 0x050f /* Kawatsu Semiconductor, Inc. */
#define USB_VENDOR_APC 0x051d /* American Power Conversion */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_CONNECTEK 0x0522 /* Advanced Connectek USA Inc. */
2000-01-13 20:17:11 +00:00
#define USB_VENDOR_NETCHIP 0x0525 /* NetChip Technology */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ALTRA 0x0527 /* ALTRA */
#define USB_VENDOR_ATI 0x0528 /* ATI Technologies, Inc. */
#define USB_VENDOR_AKS 0x0529 /* Aladdin Knowledge Systems */
#define USB_VENDOR_UNIACCESS 0x0540 /* Universal Access */
#define USB_VENDOR_ANCHOR 0x0547 /* Anchor Chips Inc. */
#define USB_VENDOR_VISION 0x0553 /* VLSI Vision Ltd. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ASAHIKASEI 0x0556 /* Asahi Kasei Microsystems Co., Ltd */
#define USB_VENDOR_ATEN 0x0557 /* ATEN International Co. Ltd. */
#define USB_VENDOR_MUSTEK 0x055f /* Mustek Systems Inc. */
#define USB_VENDOR_TELEX 0x0562 /* Telex Communications Inc. */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_PERACOM 0x0565 /* Peracom Networks Inc. */
#define USB_VENDOR_WACOM 0x056a /* WACOM Corp. Ltd. */
#define USB_VENDOR_ETEK 0x056c /* e-TEK Labs */
#define USB_VENDOR_EIZO 0x056d /* EIZO */
#define USB_VENDOR_ELECOM 0x056e /* Elecom Corp. Ltd. */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BAFO 0x0576 /* BAFO/Quality Computer Accessories */
2000-03-15 22:04:01 +00:00
#define USB_VENDOR_YEDATA 0x057b /* Y-E Data */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_AVM 0x057c /* AVM GmbH */
#define USB_VENDOR_ROCKFIRE 0x0583 /* Rockfire */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ALCOR 0x058f /* Alcor Micro, Inc. */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_IOMEGA 0x059b /* Iomega Corp. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ATREND 0x059c /* A-Trend Technology Co., Ltd. */
#define USB_VENDOR_AID 0x059d /* Advanced Input Devices */
1999-05-01 13:16:35 +00:00
#define USB_VENDOR_OMNIVISION 0x05a9 /* OmniVision */
#define USB_VENDOR_INSYSTEM 0x05ab /* In-System Design */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_APPLE 0x05ac /* Apple Computer */
#define USB_VENDOR_QTRONIX 0x05c7 /* Qtronix Corp */
Synchronisation with NetBSD as of 1999/11/16: Cleaning up the code: - Declare many functions static - Change variable names to make them more self explanatory - Change usbd_request_handle -> usbd_xfer_handle - Syntactical changes - Remove some unused code - Other KNF changes Interrupt context handling - Change delay to usbd_delay_ms were possible (takes polling mode into account) - Change detection mechanism for interrupt context Add support for pre-allocation DMA-able memory by device driver Add preliminary support for isochronous to the UHCI driver (not for OHCI yet). usb.c, uhci.c, ohci.c - Initial attempt at detachable USB host controllers - Handle the use_polling flag with a lttle more care and only set it if we are cold booting. usb.c, uhci.c ohci.c, usbdi.c usbdi_util.c usb_subr.c - Make sure an aborted pipe is marked as not running. - Start queued request in the right order. - Insert some more DIAGNOSTIC sanity checks. - Remove (almost) unused definitions USBD_XFER_OUT and USBD_XFER_IN. usb.c, usb_subr.c - Add an event mechanism so that a userland process can watch devices come and go. ohci.c - Handle the case when a USB transfer is so long that it crosses two page (4K) boundaries. OHCI cannot do that with a single TD so we make a chain. ulpt.c - Use a bigger buffer when transferring data. - Pre-allocate the DMA buffer. This makes the driver slightly more efficient. - Comment out the GET_DEVICE_ID code, because for some unknown reason it causes printing to fail sometimes. usb.h - Add a macro to extract the isoc type. - Add a macro to check whether the routine has been entered after splusb and if not, complain. usbdi.c - Fix a glitch in dequeueing and aborting requests on interrupt pipes. - Add a flag in the request to determine if the data copying is done by the driver or the usbdi layer.
1999-11-17 22:33:51 +00:00
#define USB_VENDOR_ELSA 0x05cc /* ELSA Gmbh */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BRAINBOXES 0x05d1 /* Brainboxes Limited */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AXIOHM 0x05d9 /* Axiohm Transaction Solutions */
#define USB_VENDOR_EIZONANAO 0x05e7 /* EIZO Nanao */
#define USB_VENDOR_KLSI 0x05e9 /* Kawasaki LSI */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ANKO 0x05ef /* Anko Electronic Co., Ltd. */
#define USB_VENDOR_PIENGINEERING 0x05f3 /* P.I. Engineering */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AOC 0x05f6 /* AOC International */
#define USB_VENDOR_CHIC 0x05fe /* Chic Technology */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BARCO 0x0600 /* Barco Display Systems */
#define USB_VENDOR_BRIDGE 0x0607 /* Bridge Information Co., Ltd. */
2000-01-20 07:39:19 +00:00
#define USB_VENDOR_SOLIDYEAR 0x060b /* Solid Year */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BIORAD 0x0614 /* Bio-Rad Laboratories */
#define USB_VENDOR_MACALLY 0x0618 /* Macally */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ACTLABS 0x061c /* Act Labs, Ltd. */
#define USB_VENDOR_ALARIS 0x0620 /* Alaris, Inc. */
#define USB_VENDOR_APEX 0x0624 /* Apex, Inc. */
#define USB_VENDOR_AVISION 0x0638 /* Avision, Inc. */
2000-01-20 07:39:19 +00:00
#define USB_VENDOR_LINKSYS 0x066b /* Linksys Inc. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ACERSA 0x066e /* Acer Semiconductor America, Inc. */
#define USB_VENDOR_AIWA 0x0677 /* Aiwa Co., Ltd. */
#define USB_VENDOR_ACARD 0x0678 /* ACARD Technology Corp. */
#define USB_VENDOR_ADVANCELOGIC 0x0680 /* Avance Logic, Inc. */
#define USB_VENDOR_ASKEY 0x069a /* Askey Computer Corporation */
#define USB_VENDOR_ALCATELT 0x06b9 /* Alcatel Telecom */
#define USB_VENDOR_AGFA 0x06bd /* AGFA-Gevaert NV */
#define USB_VENDOR_ASIAMD 0x06be /* Asia Microelectronic Development, Inc. */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BIZLINK 0x06c4 /* Bizlink International Corporation */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AASHIMA 0x06d6 /* Aashima Technology B.V. */
1999-06-27 22:28:02 +00:00
#define USB_VENDOR_MULTITECH 0x06e0 /* MultiTech */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ADS 0x06e1 /* ADS Technologies, Inc. */
#define USB_VENDOR_ALCATELM 0x06e4 /* Alcatel Microelectronics */
2000-01-20 07:39:19 +00:00
#define USB_VENDOR_SIRIUS 0x06ea /* Sirius Technologies */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BOSTON 0x06fd /* Boston Acoustics */
#define USB_VENDOR_SMC 0x0707 /* Standard Microsystems Corp */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AUREAL 0x0755 /* Aureal Semiconductor */
#define USB_VENDOR_MIDIMAN 0x0763 /* Midiman */
#define USB_VENDOR_SANDISK 0x0781 /* SanDisk Corp */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BRIMAX 0x078e /* Brimax Inc. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AXIS 0x0792 /* Axis Communications AB */
#define USB_VENDOR_ABL 0x0794 /* ABL Electronics Corporation */
#define USB_VENDOR_ALFADATA 0x079d /* Alfadata Computer Corp. */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BE 0x07a4 /* Be Incorporated */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ADMTEK 0x07a6 /* ADMtek Incorporated */
2000-01-13 20:17:11 +00:00
#define USB_VENDOR_COREGA 0x07aa /* Corega */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ABOCOM 0x07b8 /* AboCom Systems, Inc. */
#define USB_VENDOR_APG 0x07c5 /* APG Cash Drawer */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BUG 0x07c8 /* B.U.G., Inc. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ALLIEDTELESYN 0x07c9 /* Allied Telesyn International */
#define USB_VENDOR_AVERMEDIA 0x07ca /* AVerMedia Technologies, Inc. */
#define USB_VENDOR_SIIG 0x07cc /* SIIG */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_APTIO 0x07d2 /* Aptio Products Inc. */
#define USB_VENDOR_ARASAN 0x07da /* Arasan Chip Systems */
#define USB_VENDOR_ALLIEDCABLE 0x07e6 /* Allied Cable Corporation */
2000-01-20 07:39:19 +00:00
#define USB_VENDOR_ZOOM 0x0803 /* Zoom Telephonics Inc. */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BROADLOGIC 0x0827 /* BroadLogic, Inc. */
#define USB_VENDOR_HANDSPRING 0x082d /* Handspring Inc. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ACTIONSTAR 0x0835 /* Action Star Enterprise Co., Ltd. */
#define USB_VENDOR_ACCTON 0x083a /* Accton Technology Corporation */
2000-01-20 07:39:19 +00:00
#define USB_VENDOR_DIAMOND 0x0841 /* Diamond */
#define USB_VENDOR_NETGEAR 0x0846 /* BayNETGEAR Inc. */
2000-01-20 07:39:19 +00:00
#define USB_VENDOR_ACTIVEWIRE 0x0854 /* ActiveWire Inc. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ADESSOKBTEK 0x087c /* ADESSO/Kbtek America Inc. */
#define USB_VENDOR_APT 0x0880 /* APT Technologies Inc. */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BOCARESEARCH 0x0885 /* Boca Research, Inc. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ANDREA 0x08a8 /* Andrea Electronics */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BURRBROWN 0x08bb /* Burr-Brown Japan, Ltd. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_2WIRE 0x08c8 /* 2Wire, Inc */
#define USB_VENDOR_AIPTEK 0x08ca /* AIPTEK International Inc. */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BILLIONTON 0x08dd /* Billionton Systems, Inc. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AUTHENTEC 0x08ff /* AuthenTec, Inc. */
#define USB_VENDOR_ALATION 0x0910 /* Alation Systems, Inc. */
#define USB_VENDOR_BIOMETRIC 0x0929 /* American Biometric Company */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BLUEWATER 0x0956 /* BlueWater Systems, Inc. */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_AGILENT 0x0957 /* Agilent Technologies, Inc. */
#define USB_VENDOR_ADIRONDACK 0x0976 /* Adirondack Wire & Cable */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BECKHOFF 0x0978 /* Beckhoff Gmbh */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ALTIUS 0x09b3 /* Altius Solutions, Inc. */
#define USB_VENDOR_ARRIS 0x09c1 /* Arris Interactive LLC */
#define USB_VENDOR_ACTIVCARD 0x09c3 /* ACTIVCARD, INC. */
#define USB_VENDOR_ACTISYS 0x09c4 /* ACTiSYS Corporation */
#define USB_VENDOR_AFOURTECH 0x09da /* A-FOUR TECH CO., LTD. */
#define USB_VENDOR_AIMEX 0x09dc /* AIMEX Corporation */
#define USB_VENDOR_ADDONICS 0x09df /* Addonics Technologies Corp. */
#define USB_VENDOR_AKAI 0x09e8 /* AKAI professional M.I. Corp. */
#define USB_VENDOR_ARESCOM 0x09f5 /* ARESCOM */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BAY 0x09f9 /* Bay Associates */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ALTERA 0x09fb /* Altera */
#define USB_VENDOR_ASAHIOPTICAL 0x0a17 /* Asahi Optical Co., Ltd. */
2000-03-20 19:49:50 +00:00
#define USB_VENDOR_BOCASYSTEMS 0x0a43 /* Boca Systems Inc. */
#define USB_VENDOR_BROADCOM 0x0a5c /* Broadcom Corp. */
#define USB_VENDOR_MOTOROLA 0x1063 /* Motorola */
#define USB_VENDOR_PLX 0x10b5 /* PLX */
#define USB_VENDOR_INSIDEOUT 0x1608 /* Inside Out Networks */
1999-08-28 09:39:54 +00:00
#define USB_VENDOR_ENTREGA 0x1645 /* Entrega */
2000-03-20 18:30:34 +00:00
#define USB_VENDOR_ACTIONTEC 0x1668 /* Actiontec Electronics, Inc. */
#define USB_VENDOR_DLINK 0x2001 /* D-Link Corp */
#define USB_VENDOR_INTEL 0x8086 /* Intel */
/*
* List of known products. Grouped by vendor.
*/
2000-01-20 07:39:19 +00:00
/* 3Com products */
#define USB_PRODUCT_3COM_HOMECONN 0x009d /* HomeConnect USB Camera */
#define USB_PRODUCT_3COM_3C19250 0x03E8 /* 3C19250 Ethernet adapter */
#define USB_PRODUCT_3COM_USR56K 0x3021 /* U.S.Robotics 56000 Voice Faxmodem Pro */
2000-01-20 07:39:19 +00:00
#define USB_PRODUCT_3COMUSR_USR56K 0x3021 /* U.S.Robotics 56000 Voice Faxmodem Pro */
2000-03-20 18:30:34 +00:00
/* Acer Peripherals Inc. products */
#define USB_PRODUCT_ACERP_ACERSCAN_C310U 0x12a6 /* Acerscan C310U */
2000-01-20 07:39:19 +00:00
/* ActiveWire Inc. products */
#define USB_PRODUCT_ACTIVEWIRE_IOBOARD 0x0100 /* I/O Board */
#define USB_PRODUCT_ACTIVEWIRE_IOBOARD_FW1 0x0101 /* I/O Board, rev. 1 firmware */
2000-01-20 07:39:19 +00:00
/* ADMtek products */
#define USB_PRODUCT_ADMTEK_PEGASUS 0x0986 /* AN986 USB Ethernet adapter */
This commit adds device driver support for the ADMtek AN986 Pegasus USB ethernet chip. Adapters that use this chip include the LinkSys USB100TX. There are a few others, but I'm not certain of their availability in the U.S. I used an ADMtek eval board for development. Note that while the ADMtek chip is a 100Mbps device, you can't really get 100Mbps speeds over USB. Regardless, this driver uses miibus to allow speed and duplex mode selection as well as autonegotiation. Building and kldloading the driver as a module is also supported. Note that in order to make this driver work, I had to make what some may consider an ugly hack to sys/dev/usb/usbdi.c. The usbd_transfer() function will use tsleep() for synchronous transfers that don't complete right away. This is a problem since there are times when we need to do sync transfers from an interrupt context (i.e. when reading registers from the MAC via the control endpoint), where tsleep() us a no-no. My hack allows the driver to have the code poll for transfer completion subject to the xfer->timeout timeout rather that calling tsleep(). This hack is controlled by a quirk entry and is only enabled for the ADMtek device. Now, I'm sure there are a few of you out there ready to jump on me and suggest some other approach that doesn't involve a busy wait. The only solution that might work is to handle the interrupts in a kernel thread, where you may have something resembling a process context that makes it okay to tsleep(). This is lovely, except we don't have any mechanism like that now, and I'm not about to implement such a thing myself since it's beyond the scope of driver development. (Translation: I'll be damned if I know how to do it.) If FreeBSD ever aquires such a mechanism, I'll be glad to revisit the driver to take advantage of it. In the meantime, I settled for what I perceived to be the solution that involved the least amount of code changes. In general, the hit is pretty light. Also note that my only USB test box has a UHCI controller: I haven't I don't have a machine with an OHCI controller available. Highlights: - Updated usb_quirks.* to add UQ_NO_TSLEEP quirk for ADMtek part. - Updated usbdevs and regenerated generated files - Updated HARDWARE.TXT and RELNOTES.TXT files - Updated sysinstall/device.c and userconfig.c - Updated kernel configs -- device aue0 is commented out by default - Updated /sys/conf/files - Added new kld module directory
1999-12-28 02:01:18 +00:00
2000-01-20 07:39:19 +00:00
/* ADS products */
#define USB_PRODUCT_ADS_UBS10BT 0x0008 /* UBS-10BT Ethernet adapter */
2000-01-20 07:39:19 +00:00
/* Agiler products */
#define USB_PRODUCT_ELECOM_MOUSE29UO 0x0002 /* mouse 29UO */
1999-08-28 09:39:54 +00:00
2000-01-20 07:39:19 +00:00
/* AKS products */
#define USB_PRODUCT_AKS_USBHASP 0x0001 /* USB-HASP 0.06 */
2000-01-13 20:17:11 +00:00
2000-01-20 07:39:19 +00:00
/* Altec Lansing products */
#define USB_PRODUCT_ALTEC_ASC495 0xff05 /* ASC495 Speakers */
2000-01-20 07:39:19 +00:00
/* American Power Conversion products */
#define USB_PRODUCT_APC_UPSPRO500 0x0002 /* Back-UPS Pro 500 */
2000-01-20 07:39:19 +00:00
/* Anchor products */
#define USB_PRODUCT_ANCHOR_EZUSB 0x2131 /* EZUSB */
2000-01-20 07:39:19 +00:00
/* AOX Inc. products */
#define USB_PRODUCT_AOX_USB101 0x0008 /* USB ethernet controller engine */
2000-01-20 07:39:19 +00:00
/* ATen products */
#define USB_PRODUCT_ATEN_UC1284 0x2001 /* Parallel printer adapter */
#define USB_PRODUCT_ATEN_UC10T 0x2002 /* 10Mbps ethernet adapter */
2000-01-20 07:39:19 +00:00
/* Belkin products */
/*product BELKIN F5U111 0x???? F5U111 Ethernet adapter*/
2000-01-20 07:39:19 +00:00
/* Billionton products */
#define USB_PRODUCT_BILLIONTON_USB100 0x0986 /* USB100N 10/100 FastEthernet Adapter */
/* Brother Industries products */
#define USB_PRODUCT_BROTHER_HL1050 0x0002 /* HL-1050 laser printer */
1999-08-28 09:39:54 +00:00
/* Behavior Technology Computer products */
#define USB_PRODUCT_BTC_BTC7932 0x6782 /* Keyboard with mouse port */
/* Canon Inc. products */
#define USB_PRODUCT_CANON_S10 0x3041 /* PowerShot S10 */
2000-01-20 07:39:19 +00:00
/* CATC products */
#define USB_PRODUCT_CATC_NETMATE 0x000a /* Netmate ethernet adapter */
#define USB_PRODUCT_CATC_NETMATE2 0x000c /* Netmate2 ethernet adapter */
#define USB_PRODUCT_CATC_CHIEF 0x000d /* USB Chief Bus & Protocol Analyzer */
#define USB_PRODUCT_CATC_ANDROMEDA 0x1237 /* Andromeda hub */
2000-01-20 07:39:19 +00:00
/* Cherry products */
#define USB_PRODUCT_CHERRY_MY3000KBD 0x0001 /* My3000 keyboard */
#define USB_PRODUCT_CHERRY_MY3000HUB 0x0003 /* My3000 hub */
2000-01-20 07:39:19 +00:00
/* Chic Technology products */
#define USB_PRODUCT_CHIC_MOUSE1 0x0001 /* mouse */
/* Chicony products */
#define USB_PRODUCT_CHICONY_KB8933 0x0001 /* KB-8933 keyboard */
2000-01-20 07:39:19 +00:00
/* Connectix products */
#define USB_PRODUCT_CONNECTIX_QUICKCAM 0x0001 /* QuickCam */
2000-01-20 07:39:19 +00:00
/* Corega products */
#define USB_PRODUCT_COREGA_ETHER_USB_T 0x0001 /* Ether USB-T */
2000-03-09 16:29:49 +00:00
#define USB_PRODUCT_COREGA_FETHER_USB_TX 0x0004 /* FEther USB-TX */
2000-01-20 07:39:19 +00:00
/* Cypress Semiconductor products */
#define USB_PRODUCT_CYPRESS_MOUSE 0x0001 /* mouse */
#define USB_PRODUCT_CYPRESS_THERMO 0x0002 /* thermometer */
2000-01-20 07:39:19 +00:00
/* D-Link products */
/*product DLINK DSBS25 0x0100 DSB-S25 serial adapter*/
#define USB_PRODUCT_DLINK_DSB650C 0x4000 /* 10Mbps ethernet adapter */
#define USB_PRODUCT_DLINK_DSB650TX 0x4002 /* 10/100 ethernet adapter */
#define USB_PRODUCT_DLINK_DSB650TX_PNA 0x4003 /* 1/10/100 ethernet adapter */
2000-01-13 20:17:11 +00:00
2000-01-20 07:39:19 +00:00
/* Dallas Semiconductor products */
#define USB_PRODUCT_DALLAS_J6502 0x4201 /* J-6502 speakers */
2000-01-20 07:39:19 +00:00
/* Diamond products */
#define USB_PRODUCT_DIAMOND_RIO500USB 0x0001 /* Rio 500 USB */
2000-01-20 07:39:19 +00:00
/* EIZO products */
#define USB_PRODUCT_EIZO_HUB 0x0000 /* hub */
#define USB_PRODUCT_EIZO_MONITOR 0x0001 /* monitor */
2000-01-20 07:39:19 +00:00
/* Elsa products */
#define USB_PRODUCT_ELSA_MODEM1 0x2265 /* ELSA Modem Board */
2000-01-20 07:39:19 +00:00
/* Entrega products */
#define USB_PRODUCT_ENTREGA_1S 0x0001 /* 1S serial connector */
#define USB_PRODUCT_ENTREGA_2S 0x0002 /* 2S serial connector */
#define USB_PRODUCT_ENTREGA_1S25 0x0003 /* 1S25 serial connector */
#define USB_PRODUCT_ENTREGA_4S 0x0004 /* 4S serial connector */
#define USB_PRODUCT_ENTREGA_E45 0x0005 /* E45 Ethernet adapter */
#define USB_PRODUCT_ENTREGA_CENTRONICS 0x0006 /* Centronics connector */
#define USB_PRODUCT_ENTREGA_1S9 0x0093 /* 1S9 serial connector */
#define USB_PRODUCT_ENTREGA_EZUSB 0x8000 /* EZ-USB */
/*product ENTREGA SERIAL 0x8001 DB25 Serial connector*/
/*product ENTREGA SERIAL_DB9 0x8093 DB9 Serial connector*/
2000-01-20 07:39:19 +00:00
/* e-TEK Labs products */
#define USB_PRODUCT_ETEK_1COM 0x8007 /* Serial port */
2000-01-20 07:39:19 +00:00
/* Epson products */
#define USB_PRODUCT_EPSON_PRINTER2 0x0002 /* ISD USB Smart Cable for Mac */
#define USB_PRODUCT_EPSON_PRINTER3 0x0003 /* ISD USB Smart Cable */
2000-01-20 07:39:19 +00:00
/* Gravis products */
#define USB_PRODUCT_GRAVIS_GAMEPADPRO 0x4001 /* GamePad Pro */
2000-01-20 07:39:19 +00:00
/* Handspring Inc. */
#define USB_PRODUCT_HANDSPRING_VISOR 0x0100 /* Handspring Visor */
1999-08-28 09:39:54 +00:00
2000-01-20 07:39:19 +00:00
/* HP products */
#define USB_PRODUCT_HP_4100C 0x0101 /* Scanjet 4100C */
#define USB_PRODUCT_HP_S20 0x0102 /* Photosmart S20 */
#define USB_PRODUCT_HP_5200 0x0401 /* Scanjet 5200 */
#define USB_PRODUCT_HP_6300C 0x0601 /* Scanjet 6300C */
#define USB_PRODUCT_HP_970CSE 0x1004 /* Deskjet 970Cse */
#define USB_PRODUCT_HP_P1100 0x3102 /* Photosmart P1100 */
2000-01-20 07:39:19 +00:00
/* Inside Out Networks products */
#define USB_PRODUCT_INSIDEOUT_EDGEPORT4 0x0001 /* EdgePort/4 serial ports */
2000-01-20 07:39:19 +00:00
/* In-System products */
#define USB_PRODUCT_INSYSTEM_F5U002 0x0002 /* Parallel printer adapter */
#define USB_PRODUCT_INSYSTEM_ISD110 0x0200 /* IDE adapter */
2000-01-20 07:39:19 +00:00
/* Intel products */
#define USB_PRODUCT_INTEL_TESTBOARD 0x9890 /* 82930 test board */
/* Iomega products */
#define USB_PRODUCT_IOMEGA_ZIP100 0x0001 /* Zip 100 */
2000-01-20 07:39:19 +00:00
/* Kawatsu products */
#define USB_PRODUCT_KAWATSU_MH4000P 0x0003 /* MiniHub 4000P */
1999-05-01 13:16:35 +00:00
2000-01-20 07:39:19 +00:00
/* Kodak products */
#define USB_PRODUCT_KODAK_DC260 0x0110 /* Digital Science DC260 */
#define USB_PRODUCT_KODAK_DC265 0x0111 /* Digital Science DC265 */
2000-01-28 10:31:12 +00:00
#define USB_PRODUCT_KODAK_DC290 0x0112 /* Digital Science DC290 */
2000-01-20 07:39:19 +00:00
#define USB_PRODUCT_KODAK_DC240 0x0120 /* Digital Science DC240 */
#define USB_PRODUCT_KODAK_DC280 0x0130 /* Digital Science DC280 */
2000-01-20 07:39:19 +00:00
/* Konica Corp. Products */
#define USB_PRODUCT_KONICA_CAMERA 0x0720 /* Digital Color Camera */
2000-01-20 07:39:19 +00:00
/* KYE products */
#define USB_PRODUCT_KYE_NICHE 0x0001 /* Niche mouse */
#define USB_PRODUCT_KYE_FLIGHT2000 0x1004 /* Flight 2000 joystick */
/* Lexmark products */
#define USB_PRODUCT_LEXMARK_S2450 0x0009 /* Optra S 2450 */
/* Linksys products */
#define USB_PRODUCT_LINKSYS_USB100TX 0x2203 /* USB100TX Ethernet */
Synchronisation with NetBSD as of 1999/11/16: Cleaning up the code: - Declare many functions static - Change variable names to make them more self explanatory - Change usbd_request_handle -> usbd_xfer_handle - Syntactical changes - Remove some unused code - Other KNF changes Interrupt context handling - Change delay to usbd_delay_ms were possible (takes polling mode into account) - Change detection mechanism for interrupt context Add support for pre-allocation DMA-able memory by device driver Add preliminary support for isochronous to the UHCI driver (not for OHCI yet). usb.c, uhci.c, ohci.c - Initial attempt at detachable USB host controllers - Handle the use_polling flag with a lttle more care and only set it if we are cold booting. usb.c, uhci.c ohci.c, usbdi.c usbdi_util.c usb_subr.c - Make sure an aborted pipe is marked as not running. - Start queued request in the right order. - Insert some more DIAGNOSTIC sanity checks. - Remove (almost) unused definitions USBD_XFER_OUT and USBD_XFER_IN. usb.c, usb_subr.c - Add an event mechanism so that a userland process can watch devices come and go. ohci.c - Handle the case when a USB transfer is so long that it crosses two page (4K) boundaries. OHCI cannot do that with a single TD so we make a chain. ulpt.c - Use a bigger buffer when transferring data. - Pre-allocate the DMA buffer. This makes the driver slightly more efficient. - Comment out the GET_DEVICE_ID code, because for some unknown reason it causes printing to fail sometimes. usb.h - Add a macro to extract the isoc type. - Add a macro to check whether the routine has been entered after splusb and if not, complain. usbdi.c - Fix a glitch in dequeueing and aborting requests on interrupt pipes. - Add a flag in the request to determine if the data copying is done by the driver or the usbdi layer.
1999-11-17 22:33:51 +00:00
/* Logitech products */
#define USB_PRODUCT_LOGITECH_M2452 0x0203 /* M2452 keyboard */
1999-08-28 09:39:54 +00:00
#define USB_PRODUCT_LOGITECH_M4848 0x0301 /* M4848 mouse */
#define USB_PRODUCT_LOGITECH_QUICKCAM 0x0801 /* QuickCam */
#define USB_PRODUCT_LOGITECH_QUICKCAMPRO 0x0810 /* QuickCam Pro */
#define USB_PRODUCT_LOGITECH_N48 0xc001 /* N48 mouse */
#define USB_PRODUCT_LOGITECH_MBA47 0xc002 /* M-BA47 mouse */
2000-01-20 07:39:19 +00:00
/* Lucent products */
#define USB_PRODUCT_LUCENT_EVALKIT 0x1001 /* USS-720 evaluation kit */
/* Macally products */
#define USB_PRODUCT_MACALLY_MOUSE1 0x0101 /* mouse */
2000-01-20 07:39:19 +00:00
/* Melco Inc products */
#define USB_PRODUCT_MELCO_LUATX 0x0001 /* LU-ATX Ethernet */
/* Microsoft products */
#define USB_PRODUCT_MICROSOFT_INTELLIMOUSE 0x0009 /* IntelliMouse */
#define USB_PRODUCT_MICROSOFT_NATURALKBD 0x000b /* Natural Keyboard Elite */
#define USB_PRODUCT_MICROSOFT_DDS80 0x0014 /* Digital Sound System 80 */
#define USB_PRODUCT_MICROSOFT_SIDEWINDER 0x001a /* Sidewinder Precision Racing Wheel */
/* Midiman products */
#define USB_PRODUCT_MIDIMAN_MIDISPORT2X2 0x1001 /* Midisport 2x2 */
/* Motorola products */
#define USB_PRODUCT_MOTOROLA_MC141555 0x1555 /* MC141555 hub controller */
/* MultiTech products */
1999-06-27 22:28:02 +00:00
#define USB_PRODUCT_MULTITECH_ATLAS 0xf101 /* MT5634ZBA-USB modem */
2000-01-20 07:39:19 +00:00
/* Mustek products */
#define USB_PRODUCT_MUSTEK_MDC800 0xa800 /* MDC-800 digital camera */
2000-01-20 07:39:19 +00:00
/* NEC products */
#define USB_PRODUCT_NEC_HUB 0x55aa /* hub */
#define USB_PRODUCT_NEC_HUB_B 0x55ab /* hub */
2000-01-20 07:39:19 +00:00
/* NetChip Technology Products */
#define USB_PRODUCT_NETCHIP_TURBOCONNECT 0x1080 /* Turbo-Connect */
2000-01-20 07:39:19 +00:00
/* Netgear products */
#define USB_PRODUCT_NETGEAR_EA101 0x1001 /* Ethernet adapter */
/* OmniVision Technologies Inc. products */
#define USB_PRODUCT_OMNIVISION_OV511 0x0511 /* OV511 Camera */
/* Peracom products */
#define USB_PRODUCT_PERACOM_SERIAL1 0x0001 /* Serial Converter */
#define USB_PRODUCT_PERACOM_ENET 0x0002 /* Ethernet adapter */
#define USB_PRODUCT_PERACOM_ENET2 0x0005 /* Ethernet adapter */
/* Philips products */
#define USB_PRODUCT_PHILIPS_DSS350 0x0101 /* DSS 350 Digital Speaker System */
#define USB_PRODUCT_PHILIPS_DSS 0x0104 /* DSS XXX Digital Speaker System */
#define USB_PRODUCT_PHILIPS_HUB 0x0201 /* hub */
#define USB_PRODUCT_PHILIPS_DSS150 0x0471 /* DSS XXX Digital Speaker System */
/* P.I. Engineering products */
#define USB_PRODUCT_PIENGINEERING_PS2USB 0x020b /* PS2 to Mac USB Adapter */
/* PLX products */
#define USB_PRODUCT_PLX_TESTBOARD 0x9060 /* test board */
/* Primax products */
#define USB_PRODUCT_PRIMAX_COMFORT 0x4d01 /* Comfort */
#define USB_PRODUCT_PRIMAX_MOUSEINABOX 0x4d02 /* Mouse-in-a-Box */
/* Rockfire products */
#define USB_PRODUCT_ROCKFIRE_GAMEPAD 0x2033 /* gamepad 203USB */
/* Qtronix products */
#define USB_PRODUCT_QTRONIX_980N 0x2011 /* Scorpion-980N keyboard */
/* SanDisk products */
#define USB_PRODUCT_SANDISK_IMAGEMATE 0x0001 /* USB ImageMate */
2000-01-20 07:39:19 +00:00
/* Shuttle Technology products */
#define USB_PRODUCT_SHUTTLE_EUSB 0x0001 /* E-USB Bridge */
2000-01-13 20:17:11 +00:00
/* SIIG products */
#define USB_PRODUCT_SIIG_DIGIFILMREADER 0x0004 /* DigiFilm-Combo Reader */
2000-01-20 07:39:19 +00:00
/* Sirius Technologies products */
#define USB_PRODUCT_SIRIUS_ROADSTER 0x0001 /* NetComm Roadster II 56 USB */
2000-01-20 07:39:19 +00:00
/* SMC products */
#define USB_PRODUCT_SMC_2102USB 0x0100 /* 10Mbps ethernet adapter */
#define USB_PRODUCT_SMC_2202USB 0x0200 /* 10/100 ethernet adapter */
2000-01-20 07:39:19 +00:00
/* SOLID YEAR products */
#define USB_PRODUCT_SOLIDYEAR_KEYBOARD 0x2101 /* Solid Year USB keyboard */
2000-01-20 07:39:19 +00:00
/* STMicroelectronics products */
#define USB_PRODUCT_STMICRO_COMMUNICATOR 0x7554 /* USB Communicator */
This commit adds device driver support for the ADMtek AN986 Pegasus USB ethernet chip. Adapters that use this chip include the LinkSys USB100TX. There are a few others, but I'm not certain of their availability in the U.S. I used an ADMtek eval board for development. Note that while the ADMtek chip is a 100Mbps device, you can't really get 100Mbps speeds over USB. Regardless, this driver uses miibus to allow speed and duplex mode selection as well as autonegotiation. Building and kldloading the driver as a module is also supported. Note that in order to make this driver work, I had to make what some may consider an ugly hack to sys/dev/usb/usbdi.c. The usbd_transfer() function will use tsleep() for synchronous transfers that don't complete right away. This is a problem since there are times when we need to do sync transfers from an interrupt context (i.e. when reading registers from the MAC via the control endpoint), where tsleep() us a no-no. My hack allows the driver to have the code poll for transfer completion subject to the xfer->timeout timeout rather that calling tsleep(). This hack is controlled by a quirk entry and is only enabled for the ADMtek device. Now, I'm sure there are a few of you out there ready to jump on me and suggest some other approach that doesn't involve a busy wait. The only solution that might work is to handle the interrupts in a kernel thread, where you may have something resembling a process context that makes it okay to tsleep(). This is lovely, except we don't have any mechanism like that now, and I'm not about to implement such a thing myself since it's beyond the scope of driver development. (Translation: I'll be damned if I know how to do it.) If FreeBSD ever aquires such a mechanism, I'll be glad to revisit the driver to take advantage of it. In the meantime, I settled for what I perceived to be the solution that involved the least amount of code changes. In general, the hit is pretty light. Also note that my only USB test box has a UHCI controller: I haven't I don't have a machine with an OHCI controller available. Highlights: - Updated usb_quirks.* to add UQ_NO_TSLEEP quirk for ADMtek part. - Updated usbdevs and regenerated generated files - Updated HARDWARE.TXT and RELNOTES.TXT files - Updated sysinstall/device.c and userconfig.c - Updated kernel configs -- device aue0 is commented out by default - Updated /sys/conf/files - Added new kld module directory
1999-12-28 02:01:18 +00:00
2000-01-20 07:39:19 +00:00
/* Sun Microsystems products */
#define USB_PRODUCT_SUN_KEYBOARD 0x0005 /* Type 6 USB */
/* XXX The above is a North American PC style keyboard possibly */
2000-01-20 07:39:19 +00:00
/* Telex Communications products */
#define USB_PRODUCT_TELEX_MIC1 0x0001 /* Enhanced USB Microphone */
2000-01-20 07:39:19 +00:00
/* Texas Intel products */
#define USB_PRODUCT_TI_UTUSB41 0x1446 /* UT-USB41 hub */
2000-01-20 07:39:19 +00:00
/* Thrustmaster products */
#define USB_PRODUCT_THRUST_FUSION_PAD 0xa0a3 /* Fusion Digital Gamepad */
2000-01-20 07:39:19 +00:00
/* Universal Access products */
#define USB_PRODUCT_UNIACCESS_PANACHE 0x0101 /* Panache Surf USB ISDN Adapter */
/* Vision products */
#define USB_PRODUCT_VISION_VC6452V002 0x0002 /* VC6452V002 Camera */
/* Wacom products */
#define USB_PRODUCT_WACOM_CT0405U 0x0000 /* CT-0405-U Tablet */
2000-03-15 22:04:01 +00:00
/* Y-E Data products */
#define USB_PRODUCT_YEDATA_FLASHBUSTERU 0x0000 /* Flashbuster-U */
2000-01-20 07:39:19 +00:00
/* Zoom Telephonics Inc. products */
#define USB_PRODUCT_ZOOM_2986L 0x9700 /* 2986L Fax modem */