1 /* 2 * CDDL HEADER START 3 * 4 * The contents of this file are subject to the terms of the 5 * Common Development and Distribution License (the "License"). 6 * You may not use this file except in compliance with the License. 7 * 8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 * or http://www.opensolaris.org/os/licensing. 10 * See the License for the specific language governing permissions 11 * and limitations under the License. 12 * 13 * When distributing Covered Code, include this CDDL HEADER in each 14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 * If applicable, add the following below this CDDL HEADER, with the 16 * fields enclosed by brackets "[]" replaced with your own identifying 17 * information: Portions Copyright [yyyy] [name of copyright owner] 18 * 19 * CDDL HEADER END 20 */ 21 22 /* 23 * Copyright 2006 Sun Microsystems, Inc. All rights reserved. 24 * Use is subject to license terms. 25 */ 26 /* 27 * Copyright 2013 Nexenta Systems, Inc. All rights reserved. 28 */ 29 30 #include <sys/types.h> 31 #include <sys/stat.h> 32 #include "pci_strings.h" 33 34 const pci_class_strings_t class_pci[] = { 35 { 0, 0, 0, "Unspecified class", "unknown" }, 36 { 0, 1, 0, "VGA compatible controller", "unknown" }, 37 38 { 1, 0, 0, "SCSI bus controller", "scsi" }, 39 { 1, 1, 0x80, "IDE controller", /* Special case */ "ide" }, 40 { 1, 2, 0, "Floppy controller", "flpydis" }, 41 { 1, 3, 0, "IPI bus controller", "ipi" }, 42 { 1, 4, 0, "RAID controller", "raid" }, 43 { 1, 5, 0x20, "ATA controller with single DMA", "ata" }, 44 { 1, 5, 0x30, "ATA controller with chained DMA", "ata" }, 45 { 1, 6, 0, "Serial ATA Direct Port Access (DPA)", "sata" }, 46 { 1, 6, 1, "SATA AHCI Interface", "sata" }, 47 { 1, 6, 2, "Serial Storage Bus Interface", "sata" }, 48 { 1, 7, 0, "Serial Attached SCSI Controller", "sas" }, 49 { 1, 7, 1, "Serial Storage Bus Interface", "sas" }, 50 { 1, 8, 0, "Non-Volatile memory controller", "unknown" }, 51 { 1, 8, 1, "NVMHCI", "unknown" }, 52 { 1, 8, 2, "NVM Express", "nvme" }, 53 { 1, 9, 0, "UFS controller", "unknown" }, 54 { 1, 9, 1, "UFS Host Controller Interface", "unknown" }, 55 { 1, 0x80, 0, "Mass storage controller", "unknown" }, 56 57 { 2, 0, 0, "Ethernet controller", "etherne" }, 58 { 2, 1, 0, "Token ring controller", "tokenrg" }, 59 { 2, 2, 0, "FDDI controller", "fddi" }, 60 { 2, 3, 0, "ATM controller", "atm" }, 61 { 2, 4, 0, "ISDN controller", "isdn" }, 62 { 2, 5, 0, "WorldFip controller", "unknown" }, 63 { 2, 6, 0, "PICMG 2.14 Multi computing controller", "mcd" }, 64 { 2, 7, 0, "InfiniBand controller", "ib", }, 65 { 2, 0x80, 0, "Network controller", "unknown" }, 66 67 { 3, 0, 0, "VGA compatible controller", "vga" }, 68 { 3, 0, 1, "8514-compatible display controller", "vgs8514" }, 69 { 3, 1, 0, "XGA video controller", "xga" }, 70 { 3, 2, 0, "3D controller", "3d" }, 71 { 3, 0x80, 0, "Video controller", "unknown" }, 72 73 { 4, 0, 0, "Video device", "video" }, 74 { 4, 1, 0, "Audio device", "audio" }, 75 { 4, 2, 0, "Computer Telephony device", "teleph" }, 76 { 4, 3, 0, "Mixed Mode device", "mixed" }, 77 { 4, 0x80, 0, "Multimedia device", "unknown" }, 78 79 { 5, 0, 0, "Ram", "ram" }, 80 { 5, 1, 0, "Flash memory", "flash" }, 81 { 5, 0x80, 0, "Memory controller", "unknown" }, 82 83 { 6, 0, 0, "Host bridge", "hostpci" }, 84 { 6, 1, 0, "ISA bridge", "pci-isa" }, 85 { 6, 2, 0, "EISA bridge", "pcieisa" }, 86 { 6, 3, 0, "MCA bridge", "pci-mca" }, 87 { 6, 4, 0, "PCI-PCI bridge", "pci-pci" }, 88 { 6, 4, 1, "Subtractive Decode PCI-PCI bridge", "unknown" }, 89 { 6, 5, 0, "PCMCIA bridge", "pcipcmc" }, 90 { 6, 6, 0, "NuBus bridge", "pcinubu" }, 91 { 6, 7, 0, "CardBus bridge", "pcicard" }, 92 { 6, 8, 0, "RACE-way bridge transport mode", "pcirace" }, 93 { 6, 8, 1, "RACE-way bridge endpoint mode", "pcirace" }, 94 { 6, 9, 0x40, "Semi-transparent PCI-PCI primary bridge", "stpci" }, 95 { 6, 9, 0x80, "Semi-transparent PCI-PCI secondary bridge", "stpci" }, 96 { 6, 0xA, 0, "Infiniband-PCI bridge", "ib-pci" }, 97 { 6, 0xB, 0, "AS Custom Interface bridge", "as-pci" }, 98 { 6, 0xB, 1, "ASI-SIG Defined Portal Interface", "as-pci" }, 99 { 6, 0x80, 0, "Bridge device", "unknown" }, 100 101 { 7, 0, 0, "Serial controller", "serial" }, 102 { 7, 0, 1, "16450-compatible serial controller", "paralle" }, 103 { 7, 0, 2, "16550-compatible serial controller", "paralle" }, 104 { 7, 0, 3, "16650-compatible serial controller", "paralle" }, 105 { 7, 0, 4, "16750-compatible serial controller", "paralle" }, 106 { 7, 0, 5, "16850-compatible serial controller", "paralle" }, 107 { 7, 0, 6, "16950-compatible serial controller", "paralle" }, 108 { 7, 1, 0, "Parallel port", "paralle" }, 109 { 7, 1, 1, "Bidirectional parallel port", "paralle" }, 110 { 7, 1, 2, "ECP 1.X parallel port", "paralle" }, 111 { 7, 1, 3, "IEEE 1284 parallel port", "paralle" }, 112 { 7, 1, 0xFE, "IEEE 1284 target device", "1284tar" }, 113 { 7, 2, 0, "Multiport serial controller", "multise" }, 114 { 7, 3, 0, "Modem controller", "mdmctrl" }, 115 { 7, 3, 1, "Hayes 16450-compatible modem", "modem" }, 116 { 7, 3, 2, "Hayes 16550-compatible modem", "modem" }, 117 { 7, 3, 3, "Hayes 16650-compatible modem", "modem" }, 118 { 7, 3, 4, "Hayes 16750-compatible modem", "modem" }, 119 { 7, 4, 0, "GPIB controller", "gpibctl" }, 120 { 7, 5, 0, "Smartcard controller", "smctrlr" }, 121 { 7, 0x80, 0, "Communication device", "commdev" }, 122 123 { 8, 0, 0, "8259 PIC", "pic" }, 124 { 8, 0, 1, "ISA PIC", "pic" }, 125 { 8, 0, 2, "EISA PIC", "pic" }, 126 { 8, 0, 0x10, "I/O APIC", "pic" }, 127 { 8, 0, 0x20, "I/O(x) APIC", "iopic" }, 128 { 8, 1, 0, "8237 DMA controller", "dma" }, 129 { 8, 1, 1, "ISA DMA controller", "dma" }, 130 { 8, 1, 2, "EISA DMA controller", "dma" }, 131 { 8, 2, 0, "8254 system timer", "timer" }, 132 { 8, 2, 1, "ISA system timer", "timer" }, 133 { 8, 2, 2, "EISA system timers", "timer" }, 134 { 8, 2, 3, "High Performance Event timer", "timer" }, 135 { 8, 3, 0, "Real time clock", "rtc" }, 136 { 8, 3, 1, "ISA real time clock", "rtc" }, 137 { 8, 4, 0, "PCI Hot-Plug controller", "pcihp" }, 138 { 8, 5, 0, "SD Host controller", "sd-hc" }, 139 { 8, 5, 1, "SD Host controller with DMA", "sd-hc" }, 140 { 8, 5, 2, "Vendor Unique SD Host controller", "sd-hc" }, 141 { 8, 6, 0, "IOMMU controller", "iommu" }, 142 { 8, 7, 0, "Root Complex Event Collector", "unknown" }, 143 { 8, 0x80, 0, "System peripheral", "unknown" }, 144 145 { 9, 0, 0, "Keyboard controller", "keyboar" }, 146 { 9, 1, 0, "Digitizer (pen)", "tablet" }, 147 { 9, 2, 0, "Mouse controller", "mouse" }, 148 { 9, 3, 0, "Scanner controller", "scanner" }, 149 { 9, 4, 0, "Gameport controller", "gamepor" }, 150 { 9, 4, 0x10, "Gameport Legacy controller", "gamepor" }, 151 { 9, 0x80, 0, "Input controller", "unknown" }, 152 153 { 10, 0, 0, "Generic Docking station", "docking" }, 154 { 10, 0x80, 0, "Docking station", "unknown" }, 155 156 { 11, 0, 0, "386", "386" }, 157 { 11, 1, 0, "486", "486" }, 158 { 11, 2, 0, "Pentium", "pentium" }, 159 { 11, 0x10, 0, "Alpha", "alpha" }, 160 { 11, 0x20, 0, "Power-PC", "powerpc" }, 161 { 11, 0x30, 0, "MIPS", "mips" }, 162 { 11, 0x40, 0, "Co-processor", "coproc" }, 163 { 11, 0x80, 0, "Processor", "unknown" }, 164 165 { 12, 0, 0, "FireWire (IEEE 1394)", "1394" }, 166 { 12, 0, 0x10, "FireWire (IEEE 1394) OpenHCI compliant", "1394" }, 167 { 12, 1, 0, "ACCESS.bus", "access" }, 168 { 12, 2, 0, "SSA", "ssa" }, 169 { 12, 3, 0, "Universal Serial Bus UHCI compliant", "usb" }, 170 { 12, 3, 0x10, "Universal Serial Bus OHCI compliant", "usb" }, 171 { 12, 3, 0x20, "Universal Serial Bus EHCI compliant", "usb" }, 172 { 12, 3, 0x30, "Universal Serial Bus XHCI compliant", "usb" }, 173 { 12, 3, 0x80, "Universal Serial Bus generic HCD", "usb" }, 174 { 12, 3, 0xFE, "Universal Serial Bus device", "usb" }, 175 { 12, 4, 0, "Fibre Channel", "fibre" }, 176 { 12, 5, 0, "SMBus (System Management Bus)", "smbus" }, 177 { 12, 6, 0, "InfiniBand", "ib" }, 178 { 12, 7, 0, "IPMI SMIC Interface", "ipmi" }, 179 { 12, 7, 1, "IPMI Keyboard Controller Style Interface", "ipmi" }, 180 { 12, 7, 2, "IPMI Block Transfer Interface", "ipmi" }, 181 { 12, 8, 0, "SERCOS Interface Standard", "sercos" }, 182 { 12, 9, 0, "CANbus", "canbus" }, 183 { 12, 10, 0, "MIPI I3C Host Controller Interface", "unknown" }, 184 { 12, 0x80, 0, "Serial Bus Controller", "unknown" }, 185 186 { 13, 0, 0, "IRDA Wireless controller", "irda" }, 187 { 13, 1, 0, "Consumer IR Wireless controller", "ir" }, 188 { 13, 1, 0x10, "UWB Radio controller", "ir-uwb" }, 189 { 13, 0x10, 0, "RF Wireless controller", "rf" }, 190 { 13, 0x11, 0, "Bluetooth Wireless controller", "btooth" }, 191 { 13, 0x12, 0, "Broadband Wireless controller", "brdband" }, 192 { 13, 0x20, 0, "802.11a Wireless controller", "802.11a" }, 193 { 13, 0x21, 0, "802.11b Wireless controller", "802.11b" }, 194 { 13, 0x40, 0, "Cellular controller/modem", "unknown" }, 195 { 13, 0x41, 0, "Cellular controller/modem w/ ethernet", "unknown" }, 196 { 13, 0x80, 0, "Wireless controller", "unknown" }, 197 198 { 14, 0, 0, "I2O controller", "i2o" }, 199 { 14, 0, 1, "I2O Arch Specification 1.0", "i2o" }, 200 201 { 15, 1, 0, "TV Satellite controller", "tv" }, 202 { 15, 2, 0, "Audio Satellite controller", "audio" }, 203 { 15, 3, 0, "Voice Satellite controller", "voice" }, 204 { 15, 4, 0, "Data Satellite controller", "data" }, 205 { 15, 0x80, 0, "Satellite Comm controller", "unknown" }, 206 207 { 16, 0, 0, "Network and computing en/decryption", "netcryp" }, 208 { 16, 1, 0, "Entertainment en/decryption", "entcryp" }, 209 { 16, 0x80, 0, "En/decryption controller", "unknown" }, 210 211 { 17, 0, 0, "DPIO modules", "dpio" }, 212 { 17, 1, 0, "Performance counters", "perfcnt" }, 213 { 17, 0x10, 0, "Comm Synch time and freq test/measurement", "cstftm" }, 214 { 17, 0x20, 0, "Management card", "mgmtcrd" }, 215 { 17, 0x80, 0, "DSP/DAP controllers", "unknown" }, 216 217 { 18, 0, 0, "Processing Accelerator", "unknown" }, 218 219 { 19, 0, 0, "Non-essential Instrumentation", "unknown" }, 220 }; 221 222 int class_pci_items = sizeof (class_pci) / sizeof (class_pci[0]); 223