xref: /illumos-gate/usr/src/lib/libprtdiag_psr/sparc/ontario/common/erie.h (revision 7ae111d47a973fff4c6e231cc31f271dd9cef473)
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, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 
27 /*
28  * Sun4v Platform header file.
29  *
30  * 	called when :
31  *      machine_type ==  erie
32  *
33  */
34 
35 #ifndef _ERIE_H
36 #define	_ERIE_H
37 
38 #pragma ident	"%Z%%M%	%I%	%E% SMI"
39 
40 #ifdef __cplusplus
41 extern "C" {
42 #endif
43 
44 #define	ERIE_PLATFORM			"SUNW,Sun-Fire-T1000"
45 #define	ERIE_PCIE_COMP			8
46 #define	ERIE_PCIX_COMP			20
47 #define	NO_SLOT 			-1
48 #define	NET_COMP_NUM			3
49 #define	IOBOARD				"IOBD"
50 #define	MOTHERBOARD			"MB"
51 #define	OPHIR				"GBE"
52 #define	NETWORK				"network"
53 #define	ERIE_NETWORK_0			"/pci@7c0/pci@0/network@4"
54 #define	ERIE_NETWORK_1			"/pci@7c0/pci@0/network@4,1"
55 #define	ERIE_NETWORK_2			"/pci@7c0/pci@0/pci@8/network@1"
56 #define	ERIE_NETWORK_3			"/pci@7c0/pci@0/pci@8/network@1,1"
57 #define	PCIX_BUS			"/pci@7c0/pci@0/pci@8"
58 #define	PCIE_PCIX			"/pci@7c0/pci@0/pci@8"
59 #define	PCIE_PCIE			"/pci@7c0/pci@0"
60 #define	ERIE_LSI_PATH			"/pci@7c0/pci@0/pci@8/scsi@2"
61 #define	FIRE0   			"/pci@780"
62 #define	FIRE1   			"/pci@7c0"
63 #define	IOBRIDGE			"IO-BRIDGE"
64 #define	PCI_BRIDGE			"PCI-BRIDGE"
65 #define	SAS_SATA_HBA			"SAS-SATA-HBA"
66 
67 
68 
69 /*
70  * Property names
71  */
72 #define	OBP_PROP_REG			"reg"
73 #define	OBP_PROP_CLOCK_FREQ		"clock-frequency"
74 #define	OBP_PROP_BOARD_NUM		"board#"
75 #define	OBP_PROP_REVISION_ID		"revision-id"
76 #define	OBP_PROP_VERSION_NUM		"version#"
77 #define	OBP_PROP_BOARD_TYPE		"board_type"
78 #define	OBP_PROP_ECACHE_SIZE		"ecache-size"
79 #define	OBP_PROP_IMPLEMENTATION		"implementation#"
80 #define	OBP_PROP_MASK			"mask#"
81 #define	OBP_PROP_COMPATIBLE		"compatible"
82 #define	OBP_PROP_BANNER_NAME		"banner-name"
83 #define	OBP_PROP_MODEL			"model"
84 #define	OBP_PROP_66MHZ_CAPABLE		"66mhz-capable"
85 #define	OBP_PROP_FBC_REG_ID		"fbc_reg_id"
86 #define	OBP_PROP_VERSION		"version"
87 #define	OBP_PROP_INSTANCE		"instance"
88 
89 /*
90  * Function Headers
91  */
92 
93 
94 /* local functions */
95 
96 int erie_pci_callback(picl_nodehdl_t pcih, void *args);
97 int erie_hw_rev_callback(picl_nodehdl_t pcih, void *args);
98 int erie_get_first_compatible_value(picl_nodehdl_t nodeh,
99     char **outbuf);
100 int64_t erie_get_int_propval(picl_nodehdl_t modh, char *prop_name,
101     int *ret);
102 void erie_get_bus_type(char path[], char bus_type[]);
103 void erie_get_nac(char bus_type[], char path[], int s,
104     char name[],  char loc[], int size);
105 int erie_get_slot_number(char path[]);
106 int erie_get_network_instance(char path[]);
107 int erie_get_name(picl_nodehdl_t nodeh, char name[], int size);
108 int erie_get_model(picl_nodehdl_t nodeh, char model[], int size);
109 int erie_get_path(picl_nodehdl_t nodeh, char path[], int size);
110 int erie_get_class(picl_nodehdl_t nodeh, char piclclass[], int size);
111 #ifdef __cplusplus
112 }
113 #endif
114 
115 #endif /* _ERIE_H */
116