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 (c) 2006, 2010, Oracle and/or its affiliates. All rights reserved.
24  */
25 
26 #ifndef _TOPO_HC_H
27 #define	_TOPO_HC_H
28 
29 #ifdef	__cplusplus
30 extern "C" {
31 #endif
32 
33 /*
34  * Allowable hardware component names for hc FMRIs
35  */
36 #define	BANK		"bank"
37 #define	BAY		"bay"
38 #define	BLADE		"blade"
39 #define	BRANCH		"branch"
40 #define	CMP		"CMP"
41 #define	CENTERPLANE	"centerplane"
42 #define	CHASSIS		"chassis"
43 #define	CHIP		"chip"
44 #define	CORE		"core"
45 #define	STRAND		"strand"
46 #define	CHIP_SELECT	"chip-select"
47 #define	CONTROLLER	"controller"
48 #define	CPU		"cpu"
49 #define	CPUBOARD	"cpuboard"
50 #define	DIMM		"dimm"
51 #define	DISK		"disk"
52 #define	DRAM		"dram"
53 #define	DRAMCHANNEL	"dram-channel"
54 #define	FAN		"fan"
55 #define	FANMODULE	"fanmodule"
56 #define	HOSTBRIDGE	"hostbridge"
57 #define	INTERCONNECT	"interconnect"
58 #define	IOBOARD		"ioboard"
59 #define	IPORT		"iport"
60 #define	MEMBOARD	"memboard"
61 #define	MEMORYBUFFER	"memory-buffer"
62 #define	MEMORYCONTROL	"memory-controller"
63 #define	MICROCORE	"micro-core"
64 #define	MOTHERBOARD	"motherboard"
65 #define	NIU		"niu"
66 #define	NIUFN		"niufn"
67 #define	PCI_BUS		"pcibus"
68 #define	PCI_DEVICE	"pcidev"
69 #define	PCI_FUNCTION    "pcifn"
70 #define	PCIEX_BUS	"pciexbus"
71 #define	PCIEX_DEVICE	"pciexdev"
72 #define	PCIEX_FUNCTION  "pciexfn"
73 #define	PCIEX_ROOT	"pciexrc"
74 #define	PCIEX_SWUP	"pciexswu"
75 #define	PCIEX_SWDWN	"pciexswd"
76 #define	POWERMODULE	"powermodule"
77 #define	PSU		"psu"
78 #define	RANK		"rank"
79 #define	RECEPTACLE	"receptacle"
80 #define	RISER		"riser"
81 #define	SASEXPANDER	"sas-expander"
82 #define	SHELF		"shelf"
83 #define	SCSI_DEVICE	"scsi-device"
84 #define	SES_ENCLOSURE	"ses-enclosure"
85 #define	SMP_DEVICE	"smp-device"
86 #define	SP		"sp"
87 #define	SUBCHASSIS	"subchassis"
88 #define	SYSTEMBOARD	"systemboard"
89 #define	XAUI		"xaui"
90 #define	XFP		"xfp"
91 
92 /*
93  * Allowable hc node property group and property names
94  */
95 #define	TOPO_PGROUP_IO		"io"
96 #define	TOPO_IO_DEVTYPE		"devtype"
97 #define	TOPO_IO_DRIVER		"driver"
98 #define	TOPO_IO_MODULE		"module"
99 #define	TOPO_IO_DEV		"dev"
100 #define	TOPO_IO_DEVID		"devid"
101 #define	TOPO_IO_DEV_PATH	"devfs-path"
102 #define	TOPO_IO_AP_PATH		"ap-path"
103 #define	TOPO_IO_PHYS_PATH	"phys-path"
104 
105 #define	TOPO_PGROUP_PCI		"pci"
106 #define	TOPO_PCI_VENDID		"vendor-id"
107 #define	TOPO_PCI_DEVID		"device-id"
108 #define	TOPO_PCI_EXCAP		"extended-capabilities"
109 #define	TOPO_PCI_BDF		"BDF"
110 #define	TOPO_PCI_CLASS		"class-code"
111 #define	TOPO_PCI_AADDR		"assigned-addresses"
112 
113 #define	TOPO_PGROUP_BINDING	"binding"
114 #define	TOPO_BINDING_OCCUPANT	"occupant-path"
115 
116 #define	TOPO_PGROUP_STORAGE	"storage"
117 #define	TOPO_STORAGE_INITIATOR_PORT	"initiator-port"
118 #define	TOPO_STORAGE_INITIATOR_PORT_PM	"initiator-port-pm"
119 #define	TOPO_STORAGE_TARGET_PORT	"target-port"
120 #define	TOPO_STORAGE_TARGET_PORT_L0ID	"target-port-l0id"
121 #define	TOPO_STORAGE_TARGET_PORT_L0IDS	"target-port-l0ids"
122 #define	TOPO_STORAGE_ATTACHED_PORT	"attached-port"
123 #define	TOPO_STORAGE_TARGET_PORT_PM	"target-port-pm"
124 #define	TOPO_STORAGE_ATTACHED_PORT_PM	"attached-port-pm"
125 #define	TOPO_STORAGE_DEVID		"devid"
126 #define	TOPO_STORAGE_LUN64		"lun64"
127 #define	TOPO_STORAGE_DEVICE_TYPE	"inquiry-device-type"
128 #define	TOPO_STORAGE_MANUFACTURER	"manufacturer"
129 #define	TOPO_STORAGE_MODEL		"model"
130 #define	TOPO_STORAGE_FIRMWARE_REV	"firmware-revision"
131 #define	TOPO_STORAGE_TARGET_PORT_L0ID	"target-port-l0id"
132 #define	TOPO_STORAGE_TARGET_PORT_L0IDS	"target-port-l0ids"
133 #define	TOPO_STORAGE_SAS_PHY_MASK	"receptacle-pm"
134 #define	TOPO_STORAGE_SAS_CONNECTOR_TYPE	"sas-connector-type"
135 
136 #ifdef	__cplusplus
137 }
138 #endif
139 
140 #endif	/* _TOPO_HC_H */
141