xref: /openbmc/skeleton/configs/Palmetto.py (revision 53066750)
1HOME_PATH = './'
2GPIO_BASE = 320
3SYSTEM_NAME = "Palmetto"
4
5
6## System states
7##   state can change to next state in 2 ways:
8##   - a process emits a GotoSystemState signal with state name to goto
9##   - objects specified in EXIT_STATE_DEPEND have started
10SYSTEM_STATES = [
11	'BASE_APPS',
12	'BMC_STARTING',
13	'BMC_READY',
14	'HOST_POWERING_ON',
15	'HOST_POWERED_ON',
16	'HOST_BOOTING',
17	'HOST_BOOTED',
18	'HOST_POWERED_OFF',
19]
20
21EXIT_STATE_DEPEND = {
22	'BASE_APPS' : {
23		'/org/openbmc/sensors': 0,
24	},
25	'BMC_STARTING' : {
26		'/org/openbmc/control/chassis0': 0,
27		'/org/openbmc/control/power0' : 0,
28		'/org/openbmc/control/led/identify' : 0,
29		'/org/openbmc/control/host0' : 0,
30		'/org/openbmc/control/flash/bios' : 0,
31	}
32}
33
34CACHED_INTERFACES = {
35		"org.openbmc.InventoryItem" : True,
36		"org.openbmc.control.Chassis" : True,
37	}
38INVENTORY_ROOT = '/org/openbmc/inventory'
39
40ID_LOOKUP = {
41	'FRU' : {
42		0x0d : '<inventory_root>/system/chassis',
43		0x34 : '<inventory_root>/system/chassis/motherboard',
44		0x01 : '<inventory_root>/system/chassis/motherboard/cpu',
45		0x02 : '<inventory_root>/system/chassis/motherboard/membuf',
46		0x03 : '<inventory_root>/system/chassis/motherboard/dimm0',
47		0x04 : '<inventory_root>/system/chassis/motherboard/dimm1',
48		0x05 : '<inventory_root>/system/chassis/motherboard/dimm2',
49		0x06 : '<inventory_root>/system/chassis/motherboard/dimm3',
50		0x35 : '<inventory_root>/system',
51	},
52	'FRU_STR' : {
53		'PRODUCT_15' : '<inventory_root>/system',
54		'CHASSIS_2' : '<inventory_root>/system/chassis',
55		'BOARD_1'   : '<inventory_root>/system/chassis/motherboard/cpu',
56		'BOARD_2'   : '<inventory_root>/system/chassis/motherboard/membuf',
57		'BOARD_14'   : '<inventory_root>/system/chassis/motherboard',
58		'PRODUCT_3'   : '<inventory_root>/system/chassis/motherboard/dimm0',
59		'PRODUCT_4'   : '<inventory_root>/system/chassis/motherboard/dimm1',
60		'PRODUCT_5'   : '<inventory_root>/system/chassis/motherboard/dimm2',
61		'PRODUCT_6'   : '<inventory_root>/system/chassis/motherboard/dimm3',
62	},
63	'SENSOR' : {
64		0x34 : '<inventory_root>/system/chassis/motherboard',
65		0x37 : '<inventory_root>/system/chassis/motherboard/refclock',
66		0x38 : '<inventory_root>/system/chassis/motherboard/pcieclock',
67		0x39 : '<inventory_root>/system/chassis/motherboard/todclock',
68		0x3A : '<inventory_root>/system/chassis/apss',
69		0x2f : '<inventory_root>/system/chassis/motherboard/cpu',
70		0x22 : '<inventory_root>/system/chassis/motherboard/cpu/core1',
71		0x23 : '<inventory_root>/system/chassis/motherboard/cpu/core2',
72		0x24 : '<inventory_root>/system/chassis/motherboard/cpu/core3',
73		0x25 : '<inventory_root>/system/chassis/motherboard/cpu/core4',
74		0x26 : '<inventory_root>/system/chassis/motherboard/cpu/core5',
75		0x27 : '<inventory_root>/system/chassis/motherboard/cpu/core6',
76		0x28 : '<inventory_root>/system/chassis/motherboard/cpu/core9',
77		0x29 : '<inventory_root>/system/chassis/motherboard/cpu/core10',
78		0x2a : '<inventory_root>/system/chassis/motherboard/cpu/core11',
79		0x2b : '<inventory_root>/system/chassis/motherboard/cpu/core12',
80		0x2c : '<inventory_root>/system/chassis/motherboard/cpu/core13',
81		0x2d : '<inventory_root>/system/chassis/motherboard/cpu/core14',
82		0x2e : '<inventory_root>/system/chassis/motherboard/membuf',
83		0x1e : '<inventory_root>/system/chassis/motherboard/dimm0',
84		0x1f : '<inventory_root>/system/chassis/motherboard/dimm1',
85		0x20 : '<inventory_root>/system/chassis/motherboard/dimm2',
86		0x21 : '<inventory_root>/system/chassis/motherboard/dimm3',
87		0x09 : '/org/openbmc/sensors/host/BootCount',
88		0x05 : '/org/openbmc/sensors/host/BootProgress',
89		0x08 : '/org/openbmc/sensors/host/cpu0/OccStatus',
90		0x32 : '/org/openbmc/sensors/host/OperatingSystemStatus',
91		0x33 : '/org/openbmc/sensors/host/PowerCap',
92	},
93	'GPIO_PRESENT' : {
94		'SLOT0_PRESENT' : '<inventory_root>/system/chassis/motherboard/pciecard_x16',
95		'SLOT1_PRESENT' : '<inventory_root>/system/chassis/motherboard/pciecard_x8',
96	}
97}
98
99GPIO_CONFIG = {}
100GPIO_CONFIG['FSI_CLK']    =   { 'gpio_pin': 'A4', 'direction': 'out' }
101GPIO_CONFIG['FSI_DATA']   =   { 'gpio_pin': 'A5', 'direction': 'out' }
102GPIO_CONFIG['FSI_ENABLE'] =   { 'gpio_pin': 'D0', 'direction': 'out' }
103GPIO_CONFIG['POWER_PIN']  =   { 'gpio_pin': 'E1', 'direction': 'out'  }
104GPIO_CONFIG['CRONUS_SEL'] =   { 'gpio_pin': 'A6', 'direction': 'out'  }
105GPIO_CONFIG['PGOOD']      =   { 'gpio_pin': 'C7', 'direction': 'in'  }
106GPIO_CONFIG['BMC_THROTTLE'] = { 'gpio_pin': 'J3', 'direction': 'out' }
107GPIO_CONFIG['IDBTN']       = { 'gpio_pin': 'Q7', 'direction': 'out' }
108GPIO_CONFIG['POWER_BUTTON'] = { 'gpio_pin': 'E0', 'direction': 'both' }
109GPIO_CONFIG['PCIE_RESET']   = { 'gpio_pin': 'B5', 'direction': 'out' }
110GPIO_CONFIG['USB_RESET']    = { 'gpio_pin': 'B6', 'direction': 'out' }
111GPIO_CONFIG['SLOT0_RISER_PRESENT'] =   { 'gpio_pin': 'N0', 'direction': 'in' }
112GPIO_CONFIG['SLOT1_RISER_PRESENT'] =   { 'gpio_pin': 'N1', 'direction': 'in' }
113GPIO_CONFIG['SLOT2_RISER_PRESENT'] =   { 'gpio_pin': 'N2', 'direction': 'in' }
114GPIO_CONFIG['SLOT0_PRESENT'] =         { 'gpio_pin': 'N3', 'direction': 'in' }
115GPIO_CONFIG['SLOT1_PRESENT'] =         { 'gpio_pin': 'N4', 'direction': 'in' }
116GPIO_CONFIG['SLOT2_PRESENT'] =         { 'gpio_pin': 'N5', 'direction': 'in' }
117GPIO_CONFIG['MEZZ0_PRESENT'] =         { 'gpio_pin': 'O0', 'direction': 'in' }
118GPIO_CONFIG['MEZZ1_PRESENT'] =         { 'gpio_pin': 'O1', 'direction': 'in' }
119GPIO_CONFIG['CHECKSTOP']      =   { 'gpio_pin': 'P5', 'direction': 'falling' }
120
121def convertGpio(name):
122	name = name.upper()
123	c = name[0:1]
124	offset = int(name[1:])
125	a = ord(c)-65
126	base = a*8+GPIO_BASE
127	return base+offset
128
129HWMON_CONFIG = {
130	'2-004c' :  {
131		'names' : {
132			'temp1_input' : { 'object_path' : 'temperature/ambient','poll_interval' : 5000,'scale' : -3,'units' : 'C' },
133		}
134	},
135	'3-0050' : {
136		'names' : {
137			'caps_curr_powercap' : { 'object_path' : 'powercap/curr_cap','poll_interval' : 10000,'scale' : 1,'units' : 'W' },
138			'caps_curr_powerreading' : { 'object_path' : 'powercap/system_power','poll_interval' : 10000,'scale' : 1,'units' : 'W' },
139			'caps_max_powercap' : { 'object_path' : 'powercap/max_cap','poll_interval' : 10000,'scale' : 1,'units' : 'W' },
140			'caps_min_powercap' : { 'object_path' : 'powercap/min_cap','poll_interval' : 10000,'scale' : 1,'units' : 'W' },
141			'caps_norm_powercap' : { 'object_path' : 'powercap/n_cap','poll_interval' : 10000,'scale' : 1,'units' : 'W' },
142			'caps_user_powerlimit' : { 'object_path' : 'powercap/user_cap','poll_interval' : 10000,'scale' : 1,'units' : 'W' },
143		}
144	}
145}
146
147# Miscellaneous non-poll sensor with system specific properties.
148# The sensor id is the same as those defined in ID_LOOKUP['SENSOR'].
149MISC_SENSORS = {
150	0x09 : { 'class' : 'BootCountSensor' },
151	0x05 : { 'class' : 'BootProgressSensor' },
152	0x08 : { 'class' : 'OccStatusSensor',
153		'os_path' : '/sys/class/i2c-adapter/i2c-3/3-0050/online' },
154	0x32 : { 'class' : 'OperatingSystemStatusSensor' },
155	0x33 : { 'class' : 'PowerCap',
156		'os_path' : '/sys/class/hwmon/hwmon1/user_powercap' },
157}
158
159# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
160