Lines Matching +full:usb +full:- +full:hub

1 /* SPDX-License-Identifier: GPL-2.0+ */
4 * USBVEND.H Vendor-specific USB definitions
7 * must be kept backward-compatible with older firmware.
25 // Definitions of USB product IDs
33 // Definitions of USB product IDs (PID)
34 // We break the USB-defined PID into an OEM Id field (upper 6 bits)
40 // ION-device OEM IDs
50 // ION-device Device IDs
51 // Product IDs - assigned to match middle digit of serial number (No longer true)
62 #define ION_DEVICE_ID_HUB_MASK 0x0080 // This bit in the PID designates a HUB device
63 // for example 8C would be a 421 4 port hub
64 // and 8D would be a 2 port embedded hub
77 // ION_DEVICE_ID_EDGEPORT_8_HANDBUILT 0x009 // Hand-built Edgeport/8 (Placeholder, used in middle d…
80 #define ION_DEVICE_ID_EDGEPORT_421 0x00C // Edgeport/421 Hub+RS232+Parallel
83 #define ION_DEVICE_ID_EDGEPORT_8 0x00F // Edgeport/8 (single-CPU)
88 #define ION_DEVICE_ID_EDGEPORT_8I 0x014 // Edgeport/8 RS422 (single-CPU)
97 #define ION_DEVICE_ID_EDGEPORT_2C 0x01B // Edgeport/2c is a TI based Edgeport/2 - Small I2c
99 // 2 external hub ports - Large I2C
101 // 2 external hub ports - Large I2C
113 // Generation 3 devices -- 3410 based edgport/1 (256 byte I2C)
115 #define ION_DEVICE_ID_TI3410_EDGEPORT_1I 0x041 // Edgeport/1i- RS422 model
118 #define ION_DEVICE_ID_EDGEPORT_4S 0x042 // Edgeport/4s - software switchable model
119 #define ION_DEVICE_ID_EDGEPORT_8S 0x043 // Edgeport/8s - software switchable model
121 // Usb to Ethernet dongle
122 #define ION_DEVICE_ID_EDGEPORT_E 0x0E0 // Edgeport/E Usb to Ethernet
129 …DEVICE_ID_TI_EDGEPORT_421 0x020C // Edgeport/421 4 hub 2 RS232 + Parallel (lucent on a different
130 …DEVICE_ID_TI_EDGEPORT_21 0x020D // Edgeport/21 2 RS232 + Parallel (lucent on a different hub port)
133 #define ION_DEVICE_ID_TI_EDGEPORT_42 0x0217 // Edgeport/42 4 hub 2 RS232
137 // 2 external hub ports - Large I2C
139 // 2 external hub ports - Large I2C
142 // Generation 3 devices -- 3410 based edgport/1 (256 byte I2C)
144 #define ION_DEVICE_ID_TI_TI3410_EDGEPORT_1I 0x0241 // Edgeport/1i- RS422 model
147 #define ION_DEVICE_ID_TI_EDGEPORT_4S 0x0242 // Edgeport/4s - software switchable model
148 #define ION_DEVICE_ID_TI_EDGEPORT_8S 0x0243 // Edgeport/8s - software switchable model
149 #define ION_DEVICE_ID_TI_EDGEPORT_8 0x0244 // Edgeport/8 (single-CPU)
159 // Watchport based on 3410 both 1-wire and binary products (16K I2C)
160 #define ION_DEVICE_ID_WP_UNSERIALIZED 0x300 // Watchport based on 3410 both 1-wire and binary prod…
181 // Definitions for AXIOHM USB product IDs
192 // Definitions for NCR USB product IDs
205 // Definitions for SYMBOL USB product IDs
250 // Definitions of I/O Networks vendor-specific requests
253 // bmRequestType = 01000000 Set vendor-specific, to device
254 // bmRequestType = 11000000 Get vendor-specific, to device
261 // wValue = 16-bit address
266 #define USB_REQUEST_ION_RESET_DEVICE 0 // Warm reboot Edgeport, retaining USB address
273 #define USB_REQUEST_ION_EXEC_DL_CODE 7 // Begin execution of RAM-based download
289 // Define parameter values for our vendor-specific commands
295 // This descriptor is only returned by Edgeport-compatible devices
303 // This __u32 defines which Vendor-specific commands/functionality
341 __u8 Length; // Descriptor Length (per USB spec)
342 __u8 DescType; // Descriptor Type (per USB spec, =DEVICE type)
392 // Notes for the following two ION vendor-specific param descriptors:
394 // 1. These have a standard USB descriptor header so they look like a
396 // 2. Any strings in the structures are in USB-defined string
405 // This structure is ver 2 format. It contains ALL USB descriptors as
409 // xC00-xFBF (length 3C0h) in the ROM.
417 // area for general USB descriptors and the descriptor tables (the root
429 // Start of v1-compatible section
430 __u8 Length; // F00 Desc length for what follows, per USB (= C0h )
431 __u8 DescType; // F01 Desc type, per USB (=DEVICE type)
442 // so host can track changes to USB-only descriptors.
444 __u8 SerNumLength; // F0C USB string descriptor len
445 __u8 SerNumDescType; // F0D USB descriptor type (=STRING type)
446 __le16 SerialNumber[MAX_SERIALNUMBER_LEN]; // F0E "01-01-000100" Unicode Serial Number
448 __u8 AssemblyNumLength; // F26 USB string descriptor len
449 __u8 AssemblyNumDescType; // F27 USB descriptor type (=STRING type)
450 __le16 AssemblyNumber[MAX_ASSEMBLYNUMBER_LEN]; // F28 "350-1000-01-A " assembly number
452 __u8 OemAssyNumLength; // F44 USB string descriptor len
453 __u8 OemAssyNumDescType; // F45 USB descriptor type (=STRING type)
456 __u8 ManufDateLength; // F62 USB string descriptor len
457 __u8 ManufDateDescType; // F63 USB descriptor type (=STRING type)
460 __u8 Reserved3[0x4D]; // F70 -- unused, set to 0 --
463 __u8 IonPid; // FBE Product ID, == LSB of USB DevDesc.PID
487 // changes in a software-visible way, such that the 930 software or
492 // Implementation 0 (ie, 930-based)
505 // Implementation 1 (ie, 251+Netchip-based)
510 #define MANUF_SERNUM_LENGTH sizeof(((struct edge_manuf_descriptor *)0)->SerialNumber)
511 #define MANUF_ASSYNUM_LENGTH sizeof(((struct edge_manuf_descriptor *)0)->AssemblyNumber)
512 #define MANUF_OEMASSYNUM_LENGTH sizeof(((struct edge_manuf_descriptor *)0)->OemAssyNumber)
513 #define MANUF_MANUFDATE_LENGTH sizeof(((struct edge_manuf_descriptor *)0)->ManufDate)
526 // - FF:xFFF. Note that the 930-mandated UCONFIG bytes are
530 __u8 Length; // C0 Desc length, per USB (= 40h)
531 __u8 DescType; // C1 Desc type, per USB (= DEVICE type)
533 __u8 Reserved1; // C3 -- unused, set to 0 --
535 __le16 BootCodeLength; // C4 Boot code goes from FF:0000 to FF:(len-1)
542 __u16 EnumRootDescTable; // CA Root of ROM-based descriptor table
547 __le16 Capabilities; // CE-CF Capabilities flags (LE format)
548 __u8 Reserved2[0x28]; // D0 -- unused, set to 0 --
549 __u8 UConfig0; // F8 930-defined CPU configuration byte 0
550 __u8 UConfig1; // F9 930-defined CPU configuration byte 1
551 __u8 Reserved3[6]; // FA -- unused, set to 0 --
624 // bit 7: 1 - power switching supported
625 // 0 - power switching not supported
627 // bit 0: 1 - self powered
628 // 0 - bus powered
631 __u16 HubVid; // VID HUB
632 __u16 HubPid; // PID HUB
635 __u8 HubCurrent; // HUB Current = 100ma
674 __u8 HubConfig1; // Used to configure the Hub
675 __u8 HubConfig2; // Used to configure the Hub