Blame view

arch/powerpc/include/asm/opal.h 27.1 KB
27f448887   Benjamin Herrenschmidt   powerpc/powernv: ...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
  /*
   * PowerNV OPAL definitions.
   *
   * Copyright 2011 IBM Corp.
   *
   * This program is free software; you can redistribute it and/or
   * modify it under the terms of the GNU General Public License
   * as published by the Free Software Foundation; either version
   * 2 of the License, or (at your option) any later version.
   */
  
  #ifndef __OPAL_H
  #define __OPAL_H
  
  /****** Takeover interface ********/
  
  /* PAPR H-Call used to querty the HAL existence and/or instanciate
   * it from within pHyp (tech preview only).
   *
   * This is exclusively used in prom_init.c
   */
  
  #ifndef __ASSEMBLY__
  
  struct opal_takeover_args {
  	u64	k_image;		/* r4 */
  	u64	k_size;			/* r5 */
  	u64	k_entry;		/* r6 */
  	u64	k_entry2;		/* r7 */
  	u64	hal_addr;		/* r8 */
  	u64	rd_image;		/* r9 */
  	u64	rd_size;		/* r10 */
  	u64	rd_loc;			/* r11 */
  };
7e1ce5a49   Vasant Hegde   powerpc/powernv: ...
35
36
37
38
39
40
41
42
  /*
   * SG entry
   *
   * WARNING: The current implementation requires each entry
   * to represent a block that is 4k aligned *and* each block
   * size except the last one in the list to be as well.
   */
  struct opal_sg_entry {
3441f04b4   Anton Blanchard   powerpc/powernv: ...
43
44
  	__be64 data;
  	__be64 length;
7e1ce5a49   Vasant Hegde   powerpc/powernv: ...
45
  };
3441f04b4   Anton Blanchard   powerpc/powernv: ...
46
  /* SG list */
7e1ce5a49   Vasant Hegde   powerpc/powernv: ...
47
  struct opal_sg_list {
3441f04b4   Anton Blanchard   powerpc/powernv: ...
48
49
  	__be64 length;
  	__be64 next;
7e1ce5a49   Vasant Hegde   powerpc/powernv: ...
50
51
52
53
54
  	struct opal_sg_entry entry[];
  };
  
  /* We calculate number of sg entries based on PAGE_SIZE */
  #define SG_ENTRIES_PER_NODE ((PAGE_SIZE - 16) / sizeof(struct opal_sg_entry))
27f448887   Benjamin Herrenschmidt   powerpc/powernv: ...
55
56
57
  extern long opal_query_takeover(u64 *hal_size, u64 *hal_align);
  
  extern long opal_do_takeover(struct opal_takeover_args *args);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
58
  struct rtas_args;
27f448887   Benjamin Herrenschmidt   powerpc/powernv: ...
59
60
61
  extern int opal_enter_rtas(struct rtas_args *args,
  			   unsigned long data,
  			   unsigned long entry);
27f448887   Benjamin Herrenschmidt   powerpc/powernv: ...
62
63
64
  #endif /* __ASSEMBLY__ */
  
  /****** OPAL APIs ******/
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
  /* Return codes */
  #define OPAL_SUCCESS 		0
  #define OPAL_PARAMETER		-1
  #define OPAL_BUSY		-2
  #define OPAL_PARTIAL		-3
  #define OPAL_CONSTRAINED	-4
  #define OPAL_CLOSED		-5
  #define OPAL_HARDWARE		-6
  #define OPAL_UNSUPPORTED	-7
  #define OPAL_PERMISSION		-8
  #define OPAL_NO_MEM		-9
  #define OPAL_RESOURCE		-10
  #define OPAL_INTERNAL_ERROR	-11
  #define OPAL_BUSY_EVENT		-12
  #define OPAL_HARDWARE_FROZEN	-13
8d7248232   Neelesh Gupta   powerpc/powernv: ...
80
81
  #define OPAL_WRONG_STATE	-14
  #define OPAL_ASYNC_COMPLETION	-15
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
82
83
  
  /* API Tokens (in r0) */
e28b05e7a   Joel Stanley   powerpc/powernv: ...
84
  #define OPAL_INVALID_CALL			-1
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
  #define OPAL_CONSOLE_WRITE			1
  #define OPAL_CONSOLE_READ			2
  #define OPAL_RTC_READ				3
  #define OPAL_RTC_WRITE				4
  #define OPAL_CEC_POWER_DOWN			5
  #define OPAL_CEC_REBOOT				6
  #define OPAL_READ_NVRAM				7
  #define OPAL_WRITE_NVRAM			8
  #define OPAL_HANDLE_INTERRUPT			9
  #define OPAL_POLL_EVENTS			10
  #define OPAL_PCI_SET_HUB_TCE_MEMORY		11
  #define OPAL_PCI_SET_PHB_TCE_MEMORY		12
  #define OPAL_PCI_CONFIG_READ_BYTE		13
  #define OPAL_PCI_CONFIG_READ_HALF_WORD  	14
  #define OPAL_PCI_CONFIG_READ_WORD		15
  #define OPAL_PCI_CONFIG_WRITE_BYTE		16
  #define OPAL_PCI_CONFIG_WRITE_HALF_WORD		17
  #define OPAL_PCI_CONFIG_WRITE_WORD		18
  #define OPAL_SET_XIVE				19
  #define OPAL_GET_XIVE				20
  #define OPAL_GET_COMPLETION_TOKEN_STATUS	21 /* obsolete */
  #define OPAL_REGISTER_OPAL_EXCEPTION_HANDLER	22
  #define OPAL_PCI_EEH_FREEZE_STATUS		23
  #define OPAL_PCI_SHPC				24
  #define OPAL_CONSOLE_WRITE_BUFFER_SPACE		25
  #define OPAL_PCI_EEH_FREEZE_CLEAR		26
  #define OPAL_PCI_PHB_MMIO_ENABLE		27
  #define OPAL_PCI_SET_PHB_MEM_WINDOW		28
  #define OPAL_PCI_MAP_PE_MMIO_WINDOW		29
  #define OPAL_PCI_SET_PHB_TABLE_MEMORY		30
  #define OPAL_PCI_SET_PE				31
  #define OPAL_PCI_SET_PELTV			32
  #define OPAL_PCI_SET_MVE			33
  #define OPAL_PCI_SET_MVE_ENABLE			34
  #define OPAL_PCI_GET_XIVE_REISSUE		35
  #define OPAL_PCI_SET_XIVE_REISSUE		36
  #define OPAL_PCI_SET_XIVE_PE			37
  #define OPAL_GET_XIVE_SOURCE			38
  #define OPAL_GET_MSI_32				39
  #define OPAL_GET_MSI_64				40
  #define OPAL_START_CPU				41
  #define OPAL_QUERY_CPU_STATUS			42
  #define OPAL_WRITE_OPPANEL			43
  #define OPAL_PCI_MAP_PE_DMA_WINDOW		44
  #define OPAL_PCI_MAP_PE_DMA_WINDOW_REAL		45
  #define OPAL_PCI_RESET				49
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
131
132
133
134
135
136
137
138
  #define OPAL_PCI_GET_HUB_DIAG_DATA		50
  #define OPAL_PCI_GET_PHB_DIAG_DATA		51
  #define OPAL_PCI_FENCE_PHB			52
  #define OPAL_PCI_REINIT				53
  #define OPAL_PCI_MASK_PE_ERROR			54
  #define OPAL_SET_SLOT_LED_STATUS		55
  #define OPAL_GET_EPOW_STATUS			56
  #define OPAL_SET_SYSTEM_ATTENTION_LED		57
23773230c   Gavin Shan   powerpc/eeh: Sync...
139
140
141
142
143
  #define OPAL_RESERVED1				58
  #define OPAL_RESERVED2				59
  #define OPAL_PCI_NEXT_ERROR			60
  #define OPAL_PCI_EEH_FREEZE_STATUS2		61
  #define OPAL_PCI_POLL				62
137436c9a   Gavin Shan   powerpc/powernv: ...
144
  #define OPAL_PCI_MSI_EOI			63
23773230c   Gavin Shan   powerpc/eeh: Sync...
145
  #define OPAL_PCI_GET_PHB_DIAG_DATA2		64
cc0efb57e   Benjamin Herrenschmidt   powerpc/powernv: ...
146
147
148
149
  #define OPAL_XSCOM_READ				65
  #define OPAL_XSCOM_WRITE			66
  #define OPAL_LPC_READ				67
  #define OPAL_LPC_WRITE				68
13906db67   Benjamin Herrenschmidt   powerpc/powernv: ...
150
  #define OPAL_RETURN_CPU				69
774fea1a3   Stewart Smith   powerpc/powernv: ...
151
152
153
154
155
  #define OPAL_ELOG_READ				71
  #define OPAL_ELOG_WRITE				72
  #define OPAL_ELOG_ACK				73
  #define OPAL_ELOG_RESEND			74
  #define OPAL_ELOG_SIZE				75
50bd6153d   Vasant Hegde   powerpc/powernv: ...
156
157
158
  #define OPAL_FLASH_VALIDATE			76
  #define OPAL_FLASH_MANAGE			77
  #define OPAL_FLASH_UPDATE			78
97eb001f0   Vaidyanathan Srinivasan   powerpc/powernv: ...
159
  #define OPAL_RESYNC_TIMEBASE			79
c7e64b9ce   Stewart Smith   powerpc/powernv P...
160
161
162
163
  #define OPAL_DUMP_INIT				81
  #define OPAL_DUMP_INFO				82
  #define OPAL_DUMP_READ				83
  #define OPAL_DUMP_ACK				84
243663600   Mahesh Salgaonkar   powerpc/powernv: ...
164
165
  #define OPAL_GET_MSG				85
  #define OPAL_CHECK_ASYNC_COMPLETION		86
f7d98d18a   Vasant Hegde   powerpc/powernv: ...
166
  #define OPAL_SYNC_HOST_REBOOT			87
7224adbbb   Neelesh Gupta   powerpc/powernv: ...
167
  #define OPAL_SENSOR_READ			88
4029cd665   Neelesh Gupta   powerpc/powernv: ...
168
169
170
  #define OPAL_GET_PARAM				89
  #define OPAL_SET_PARAM				90
  #define OPAL_DUMP_RESEND			91
c7e64b9ce   Stewart Smith   powerpc/powernv P...
171
  #define OPAL_DUMP_INFO2				94
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
172
173
  
  #ifndef __ASSEMBLY__
bfd25d72a   Michael Neuling   powerpc/opal: Add...
174
  #include <linux/notifier.h>
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
175
176
177
178
  /* Other enums */
  enum OpalVendorApiTokens {
  	OPAL_START_VENDOR_API_RANGE = 1000, OPAL_END_VENDOR_API_RANGE = 1999
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
179

14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
180
181
182
183
184
185
186
187
188
  enum OpalFreezeState {
  	OPAL_EEH_STOPPED_NOT_FROZEN = 0,
  	OPAL_EEH_STOPPED_MMIO_FREEZE = 1,
  	OPAL_EEH_STOPPED_DMA_FREEZE = 2,
  	OPAL_EEH_STOPPED_MMIO_DMA_FREEZE = 3,
  	OPAL_EEH_STOPPED_RESET = 4,
  	OPAL_EEH_STOPPED_TEMP_UNAVAIL = 5,
  	OPAL_EEH_STOPPED_PERM_UNAVAIL = 6
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
189

14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
190
191
192
193
194
  enum OpalEehFreezeActionToken {
  	OPAL_EEH_ACTION_CLEAR_FREEZE_MMIO = 1,
  	OPAL_EEH_ACTION_CLEAR_FREEZE_DMA = 2,
  	OPAL_EEH_ACTION_CLEAR_FREEZE_ALL = 3
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
195

14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
196
  enum OpalPciStatusToken {
23773230c   Gavin Shan   powerpc/eeh: Sync...
197
198
199
200
201
202
  	OPAL_EEH_NO_ERROR	= 0,
  	OPAL_EEH_IOC_ERROR	= 1,
  	OPAL_EEH_PHB_ERROR	= 2,
  	OPAL_EEH_PE_ERROR	= 3,
  	OPAL_EEH_PE_MMIO_ERROR	= 4,
  	OPAL_EEH_PE_DMA_ERROR	= 5
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
203
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
204
205
206
207
208
209
210
211
212
  
  enum OpalPciErrorSeverity {
  	OPAL_EEH_SEV_NO_ERROR	= 0,
  	OPAL_EEH_SEV_IOC_DEAD	= 1,
  	OPAL_EEH_SEV_PHB_DEAD	= 2,
  	OPAL_EEH_SEV_PHB_FENCED	= 3,
  	OPAL_EEH_SEV_PE_ER	= 4,
  	OPAL_EEH_SEV_INF	= 5
  };
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
213
214
215
216
  enum OpalShpcAction {
  	OPAL_SHPC_GET_LINK_STATE = 0,
  	OPAL_SHPC_GET_SLOT_STATE = 1
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
217

14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
218
219
220
221
  enum OpalShpcLinkState {
  	OPAL_SHPC_LINK_DOWN = 0,
  	OPAL_SHPC_LINK_UP = 1
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
222

14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
223
224
225
226
227
  enum OpalMmioWindowType {
  	OPAL_M32_WINDOW_TYPE = 1,
  	OPAL_M64_WINDOW_TYPE = 2,
  	OPAL_IO_WINDOW_TYPE = 3
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
228

14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
229
230
231
232
  enum OpalShpcSlotState {
  	OPAL_SHPC_DEV_NOT_PRESENT = 0,
  	OPAL_SHPC_DEV_PRESENT = 1
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
233

14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
234
235
236
237
238
  enum OpalExceptionHandler {
  	OPAL_MACHINE_CHECK_HANDLER = 1,
  	OPAL_HYPERVISOR_MAINTENANCE_HANDLER = 2,
  	OPAL_SOFTPATCH_HANDLER = 3
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
239

14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
240
  enum OpalPendingState {
23773230c   Gavin Shan   powerpc/eeh: Sync...
241
242
243
244
245
246
247
248
249
  	OPAL_EVENT_OPAL_INTERNAL	= 0x1,
  	OPAL_EVENT_NVRAM		= 0x2,
  	OPAL_EVENT_RTC			= 0x4,
  	OPAL_EVENT_CONSOLE_OUTPUT	= 0x8,
  	OPAL_EVENT_CONSOLE_INPUT	= 0x10,
  	OPAL_EVENT_ERROR_LOG_AVAIL	= 0x20,
  	OPAL_EVENT_ERROR_LOG		= 0x40,
  	OPAL_EVENT_EPOW			= 0x80,
  	OPAL_EVENT_LED_STATUS		= 0x100,
243663600   Mahesh Salgaonkar   powerpc/powernv: ...
250
  	OPAL_EVENT_PCI_ERROR		= 0x200,
c7e64b9ce   Stewart Smith   powerpc/powernv P...
251
  	OPAL_EVENT_DUMP_AVAIL		= 0x400,
243663600   Mahesh Salgaonkar   powerpc/powernv: ...
252
253
254
255
  	OPAL_EVENT_MSG_PENDING		= 0x800,
  };
  
  enum OpalMessageType {
8d7248232   Neelesh Gupta   powerpc/powernv: ...
256
257
258
  	OPAL_MSG_ASYNC_COMP = 0,	/* params[0] = token, params[1] = rc,
  					 * additional params function-specific
  					 */
243663600   Mahesh Salgaonkar   powerpc/powernv: ...
259
260
261
262
  	OPAL_MSG_MEM_ERR,
  	OPAL_MSG_EPOW,
  	OPAL_MSG_SHUTDOWN,
  	OPAL_MSG_TYPE_MAX,
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
  };
  
  /* Machine check related definitions */
  enum OpalMCE_Version {
  	OpalMCE_V1 = 1,
  };
  
  enum OpalMCE_Severity {
  	OpalMCE_SEV_NO_ERROR = 0,
  	OpalMCE_SEV_WARNING = 1,
  	OpalMCE_SEV_ERROR_SYNC = 2,
  	OpalMCE_SEV_FATAL = 3,
  };
  
  enum OpalMCE_Disposition {
  	OpalMCE_DISPOSITION_RECOVERED = 0,
  	OpalMCE_DISPOSITION_NOT_RECOVERED = 1,
  };
  
  enum OpalMCE_Initiator {
  	OpalMCE_INITIATOR_UNKNOWN = 0,
  	OpalMCE_INITIATOR_CPU = 1,
  };
  
  enum OpalMCE_ErrorType {
  	OpalMCE_ERROR_TYPE_UNKNOWN = 0,
  	OpalMCE_ERROR_TYPE_UE = 1,
  	OpalMCE_ERROR_TYPE_SLB = 2,
  	OpalMCE_ERROR_TYPE_ERAT = 3,
  	OpalMCE_ERROR_TYPE_TLB = 4,
  };
  
  enum OpalMCE_UeErrorType {
  	OpalMCE_UE_ERROR_INDETERMINATE = 0,
  	OpalMCE_UE_ERROR_IFETCH = 1,
  	OpalMCE_UE_ERROR_PAGE_TABLE_WALK_IFETCH = 2,
  	OpalMCE_UE_ERROR_LOAD_STORE = 3,
  	OpalMCE_UE_ERROR_PAGE_TABLE_WALK_LOAD_STORE = 4,
  };
  
  enum OpalMCE_SlbErrorType {
  	OpalMCE_SLB_ERROR_INDETERMINATE = 0,
  	OpalMCE_SLB_ERROR_PARITY = 1,
  	OpalMCE_SLB_ERROR_MULTIHIT = 2,
  };
  
  enum OpalMCE_EratErrorType {
  	OpalMCE_ERAT_ERROR_INDETERMINATE = 0,
  	OpalMCE_ERAT_ERROR_PARITY = 1,
  	OpalMCE_ERAT_ERROR_MULTIHIT = 2,
  };
  
  enum OpalMCE_TlbErrorType {
  	OpalMCE_TLB_ERROR_INDETERMINATE = 0,
  	OpalMCE_TLB_ERROR_PARITY = 1,
  	OpalMCE_TLB_ERROR_MULTIHIT = 2,
  };
  
  enum OpalThreadStatus {
  	OPAL_THREAD_INACTIVE = 0x0,
75b93da43   Benjamin Herrenschmidt   powerpc/powernv: ...
323
324
  	OPAL_THREAD_STARTED = 0x1,
  	OPAL_THREAD_UNAVAILABLE = 0x2 /* opal-v3 */
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
  };
  
  enum OpalPciBusCompare {
  	OpalPciBusAny	= 0,	/* Any bus number match */
  	OpalPciBus3Bits	= 2,	/* Match top 3 bits of bus number */
  	OpalPciBus4Bits	= 3,	/* Match top 4 bits of bus number */
  	OpalPciBus5Bits	= 4,	/* Match top 5 bits of bus number */
  	OpalPciBus6Bits	= 5,	/* Match top 6 bits of bus number */
  	OpalPciBus7Bits	= 6,	/* Match top 7 bits of bus number */
  	OpalPciBusAll	= 7,	/* Match bus number exactly */
  };
  
  enum OpalDeviceCompare {
  	OPAL_IGNORE_RID_DEVICE_NUMBER = 0,
  	OPAL_COMPARE_RID_DEVICE_NUMBER = 1
  };
  
  enum OpalFuncCompare {
  	OPAL_IGNORE_RID_FUNCTION_NUMBER = 0,
  	OPAL_COMPARE_RID_FUNCTION_NUMBER = 1
  };
  
  enum OpalPeAction {
  	OPAL_UNMAP_PE = 0,
  	OPAL_MAP_PE = 1
  };
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
351
352
353
354
355
356
357
358
359
  enum OpalPeltvAction {
  	OPAL_REMOVE_PE_FROM_DOMAIN = 0,
  	OPAL_ADD_PE_TO_DOMAIN = 1
  };
  
  enum OpalMveEnableAction {
  	OPAL_DISABLE_MVE = 0,
  	OPAL_ENABLE_MVE = 1
  };
9be3becc2   Gavin Shan   powerpc/eeh: Call...
360
  enum OpalPciResetScope {
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
361
362
  	OPAL_PHB_COMPLETE = 1, OPAL_PCI_LINK = 2, OPAL_PHB_ERROR = 3,
  	OPAL_PCI_HOT_RESET = 4, OPAL_PCI_FUNDAMENTAL_RESET = 5,
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
363
364
  	OPAL_PCI_IODA_TABLE_RESET = 6,
  };
9be3becc2   Gavin Shan   powerpc/eeh: Call...
365
366
367
  enum OpalPciReinitScope {
  	OPAL_REINIT_PCI_DEV = 1000
  };
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
368
369
370
  enum OpalPciResetState {
  	OPAL_DEASSERT_RESET = 0,
  	OPAL_ASSERT_RESET = 1
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
371
  };
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
  enum OpalPciMaskAction {
  	OPAL_UNMASK_ERROR_TYPE = 0,
  	OPAL_MASK_ERROR_TYPE = 1
  };
  
  enum OpalSlotLedType {
  	OPAL_SLOT_LED_ID_TYPE = 0,
  	OPAL_SLOT_LED_FAULT_TYPE = 1
  };
  
  enum OpalLedAction {
  	OPAL_TURN_OFF_LED = 0,
  	OPAL_TURN_ON_LED = 1,
  	OPAL_QUERY_LED_STATE_AFTER_BUSY = 2
  };
  
  enum OpalEpowStatus {
  	OPAL_EPOW_NONE = 0,
  	OPAL_EPOW_UPS = 1,
  	OPAL_EPOW_OVER_AMBIENT_TEMP = 2,
  	OPAL_EPOW_OVER_INTERNAL_TEMP = 3
  };
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
394

cc0efb57e   Benjamin Herrenschmidt   powerpc/powernv: ...
395
396
397
398
399
400
401
402
403
404
  /*
   * Address cycle types for LPC accesses. These also correspond
   * to the content of the first cell of the "reg" property for
   * device nodes on the LPC bus
   */
  enum OpalLPCAddressType {
  	OPAL_LPC_MEM	= 0,
  	OPAL_LPC_IO	= 1,
  	OPAL_LPC_FW	= 2,
  };
4029cd665   Neelesh Gupta   powerpc/powernv: ...
405
406
407
408
409
410
  /* System parameter permission */
  enum OpalSysparamPerm {
  	OPAL_SYSPARAM_READ      = 0x1,
  	OPAL_SYSPARAM_WRITE     = 0x2,
  	OPAL_SYSPARAM_RW        = (OPAL_SYSPARAM_READ | OPAL_SYSPARAM_WRITE),
  };
243663600   Mahesh Salgaonkar   powerpc/powernv: ...
411
  struct opal_msg {
bb4398e1d   Anton Blanchard   powerpc/powernv: ...
412
413
414
  	__be32 msg_type;
  	__be32 reserved;
  	__be64 params[8];
243663600   Mahesh Salgaonkar   powerpc/powernv: ...
415
  };
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
  struct opal_machine_check_event {
  	enum OpalMCE_Version	version:8;	/* 0x00 */
  	uint8_t			in_use;		/* 0x01 */
  	enum OpalMCE_Severity	severity:8;	/* 0x02 */
  	enum OpalMCE_Initiator	initiator:8;	/* 0x03 */
  	enum OpalMCE_ErrorType	error_type:8;	/* 0x04 */
  	enum OpalMCE_Disposition disposition:8; /* 0x05 */
  	uint8_t			reserved_1[2];	/* 0x06 */
  	uint64_t		gpr3;		/* 0x08 */
  	uint64_t		srr0;		/* 0x10 */
  	uint64_t		srr1;		/* 0x18 */
  	union {					/* 0x20 */
  		struct {
  			enum OpalMCE_UeErrorType ue_error_type:8;
  			uint8_t		effective_address_provided;
  			uint8_t		physical_address_provided;
  			uint8_t		reserved_1[5];
  			uint64_t	effective_address;
  			uint64_t	physical_address;
  			uint8_t		reserved_2[8];
  		} ue_error;
  
  		struct {
  			enum OpalMCE_SlbErrorType slb_error_type:8;
  			uint8_t		effective_address_provided;
  			uint8_t		reserved_1[6];
  			uint64_t	effective_address;
  			uint8_t		reserved_2[16];
  		} slb_error;
  
  		struct {
  			enum OpalMCE_EratErrorType erat_error_type:8;
  			uint8_t		effective_address_provided;
  			uint8_t		reserved_1[6];
  			uint64_t	effective_address;
  			uint8_t		reserved_2[16];
  		} erat_error;
  
  		struct {
  			enum OpalMCE_TlbErrorType tlb_error_type:8;
  			uint8_t		effective_address_provided;
  			uint8_t		reserved_1[6];
  			uint64_t	effective_address;
  			uint8_t		reserved_2[16];
  		} tlb_error;
  	} u;
  };
75eb3d9b6   Mahesh Salgaonkar   powerpc/powernv: ...
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
  /* FSP memory errors handling */
  enum OpalMemErr_Version {
  	OpalMemErr_V1 = 1,
  };
  
  enum OpalMemErrType {
  	OPAL_MEM_ERR_TYPE_RESILIENCE	= 0,
  	OPAL_MEM_ERR_TYPE_DYN_DALLOC,
  	OPAL_MEM_ERR_TYPE_SCRUB,
  };
  
  /* Memory Reilience error type */
  enum OpalMemErr_ResilErrType {
  	OPAL_MEM_RESILIENCE_CE		= 0,
  	OPAL_MEM_RESILIENCE_UE,
  	OPAL_MEM_RESILIENCE_UE_SCRUB,
  };
  
  /* Dynamic Memory Deallocation type */
  enum OpalMemErr_DynErrType {
  	OPAL_MEM_DYNAMIC_DEALLOC	= 0,
  };
  
  /* OpalMemoryErrorData->flags */
  #define OPAL_MEM_CORRECTED_ERROR	0x0001
  #define OPAL_MEM_THRESHOLD_EXCEEDED	0x0002
  #define OPAL_MEM_ACK_REQUIRED		0x8000
  
  struct OpalMemoryErrorData {
  	enum OpalMemErr_Version	version:8;	/* 0x00 */
  	enum OpalMemErrType	type:8;		/* 0x01 */
  	uint16_t		flags;		/* 0x02 */
  	uint8_t			reserved_1[4];	/* 0x04 */
  
  	union {
  		/* Memory Resilience corrected/uncorrected error info */
  		struct {
  			enum OpalMemErr_ResilErrType resil_err_type:8;
  			uint8_t		reserved_1[7];
  			uint64_t	physical_address_start;
  			uint64_t	physical_address_end;
  		} resilience;
  		/* Dynamic memory deallocation error info */
  		struct {
  			enum OpalMemErr_DynErrType dyn_err_type:8;
  			uint8_t		reserved_1[7];
  			uint64_t	physical_address_start;
  			uint64_t	physical_address_end;
  		} dyn_dealloc;
  	} u;
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
  enum {
  	OPAL_P7IOC_DIAG_TYPE_NONE	= 0,
  	OPAL_P7IOC_DIAG_TYPE_RGC	= 1,
  	OPAL_P7IOC_DIAG_TYPE_BI		= 2,
  	OPAL_P7IOC_DIAG_TYPE_CI		= 3,
  	OPAL_P7IOC_DIAG_TYPE_MISC	= 4,
  	OPAL_P7IOC_DIAG_TYPE_I2C	= 5,
  	OPAL_P7IOC_DIAG_TYPE_LAST	= 6
  };
  
  struct OpalIoP7IOCErrorData {
  	uint16_t type;
  
  	/* GEM */
  	uint64_t gemXfir;
  	uint64_t gemRfir;
  	uint64_t gemRirqfir;
  	uint64_t gemMask;
  	uint64_t gemRwof;
  
  	/* LEM */
  	uint64_t lemFir;
  	uint64_t lemErrMask;
  	uint64_t lemAction0;
  	uint64_t lemAction1;
  	uint64_t lemWof;
  
  	union {
  		struct OpalIoP7IOCRgcErrorData {
  			uint64_t rgcStatus;		/* 3E1C10 */
  			uint64_t rgcLdcp;		/* 3E1C18 */
  		}rgc;
  		struct OpalIoP7IOCBiErrorData {
  			uint64_t biLdcp0;		/* 3C0100, 3C0118 */
  			uint64_t biLdcp1;		/* 3C0108, 3C0120 */
  			uint64_t biLdcp2;		/* 3C0110, 3C0128 */
  			uint64_t biFenceStatus;		/* 3C0130, 3C0130 */
  
  			uint8_t  biDownbound;		/* BI Downbound or Upbound */
  		}bi;
  		struct OpalIoP7IOCCiErrorData {
  			uint64_t ciPortStatus;		/* 3Dn008 */
  			uint64_t ciPortLdcp;		/* 3Dn010 */
  
  			uint8_t	 ciPort;		/* Index of CI port: 0/1 */
  		}ci;
  	};
  };
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
562
563
564
565
566
  /**
   * This structure defines the overlay which will be used to store PHB error
   * data upon request.
   */
  enum {
23773230c   Gavin Shan   powerpc/eeh: Sync...
567
568
569
570
571
  	OPAL_PHB_ERROR_DATA_VERSION_1 = 1,
  };
  
  enum {
  	OPAL_PHB_ERROR_DATA_TYPE_P7IOC = 1,
8c6852e03   Gavin Shan   powerpc/eeh: Outp...
572
  	OPAL_PHB_ERROR_DATA_TYPE_PHB3 = 2
23773230c   Gavin Shan   powerpc/eeh: Sync...
573
574
575
  };
  
  enum {
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
576
  	OPAL_P7IOC_NUM_PEST_REGS = 128,
8c6852e03   Gavin Shan   powerpc/eeh: Outp...
577
  	OPAL_PHB3_NUM_PEST_REGS = 256
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
578
  };
23773230c   Gavin Shan   powerpc/eeh: Sync...
579
580
581
582
583
  struct OpalIoPhbErrorCommon {
  	uint32_t version;
  	uint32_t ioType;
  	uint32_t len;
  };
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
584
  struct OpalIoP7IOCPhbErrorData {
23773230c   Gavin Shan   powerpc/eeh: Sync...
585
  	struct OpalIoPhbErrorCommon common;
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
  	uint32_t brdgCtl;
  
  	// P7IOC utl regs
  	uint32_t portStatusReg;
  	uint32_t rootCmplxStatus;
  	uint32_t busAgentStatus;
  
  	// P7IOC cfg regs
  	uint32_t deviceStatus;
  	uint32_t slotStatus;
  	uint32_t linkStatus;
  	uint32_t devCmdStatus;
  	uint32_t devSecStatus;
  
  	// cfg AER regs
  	uint32_t rootErrorStatus;
  	uint32_t uncorrErrorStatus;
  	uint32_t corrErrorStatus;
  	uint32_t tlpHdr1;
  	uint32_t tlpHdr2;
  	uint32_t tlpHdr3;
  	uint32_t tlpHdr4;
  	uint32_t sourceId;
  
  	uint32_t rsv3;
  
  	// Record data about the call to allocate a buffer.
  	uint64_t errorClass;
  	uint64_t correlator;
  
  	//P7IOC MMIO Error Regs
  	uint64_t p7iocPlssr;                // n120
  	uint64_t p7iocCsr;                  // n110
  	uint64_t lemFir;                    // nC00
  	uint64_t lemErrorMask;              // nC18
  	uint64_t lemWOF;                    // nC40
  	uint64_t phbErrorStatus;            // nC80
  	uint64_t phbFirstErrorStatus;       // nC88
  	uint64_t phbErrorLog0;              // nCC0
  	uint64_t phbErrorLog1;              // nCC8
  	uint64_t mmioErrorStatus;           // nD00
  	uint64_t mmioFirstErrorStatus;      // nD08
  	uint64_t mmioErrorLog0;             // nD40
  	uint64_t mmioErrorLog1;             // nD48
  	uint64_t dma0ErrorStatus;           // nD80
  	uint64_t dma0FirstErrorStatus;      // nD88
  	uint64_t dma0ErrorLog0;             // nDC0
  	uint64_t dma0ErrorLog1;             // nDC8
  	uint64_t dma1ErrorStatus;           // nE00
  	uint64_t dma1FirstErrorStatus;      // nE08
  	uint64_t dma1ErrorLog0;             // nE40
  	uint64_t dma1ErrorLog1;             // nE48
  	uint64_t pestA[OPAL_P7IOC_NUM_PEST_REGS];
  	uint64_t pestB[OPAL_P7IOC_NUM_PEST_REGS];
  };
8c6852e03   Gavin Shan   powerpc/eeh: Outp...
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
  struct OpalIoPhb3ErrorData {
  	struct OpalIoPhbErrorCommon common;
  
  	uint32_t brdgCtl;
  
  	/* PHB3 UTL regs */
  	uint32_t portStatusReg;
  	uint32_t rootCmplxStatus;
  	uint32_t busAgentStatus;
  
  	/* PHB3 cfg regs */
  	uint32_t deviceStatus;
  	uint32_t slotStatus;
  	uint32_t linkStatus;
  	uint32_t devCmdStatus;
  	uint32_t devSecStatus;
  
  	/* cfg AER regs */
  	uint32_t rootErrorStatus;
  	uint32_t uncorrErrorStatus;
  	uint32_t corrErrorStatus;
  	uint32_t tlpHdr1;
  	uint32_t tlpHdr2;
  	uint32_t tlpHdr3;
  	uint32_t tlpHdr4;
  	uint32_t sourceId;
  
  	uint32_t rsv3;
  
  	/* Record data about the call to allocate a buffer */
  	uint64_t errorClass;
  	uint64_t correlator;
  
  	uint64_t nFir;			/* 000 */
  	uint64_t nFirMask;		/* 003 */
  	uint64_t nFirWOF;		/* 008 */
  
  	/* PHB3 MMIO Error Regs */
  	uint64_t phbPlssr;		/* 120 */
  	uint64_t phbCsr;		/* 110 */
  	uint64_t lemFir;		/* C00 */
  	uint64_t lemErrorMask;		/* C18 */
  	uint64_t lemWOF;		/* C40 */
  	uint64_t phbErrorStatus;	/* C80 */
  	uint64_t phbFirstErrorStatus;	/* C88 */
  	uint64_t phbErrorLog0;		/* CC0 */
  	uint64_t phbErrorLog1;		/* CC8 */
  	uint64_t mmioErrorStatus;	/* D00 */
  	uint64_t mmioFirstErrorStatus;	/* D08 */
  	uint64_t mmioErrorLog0;		/* D40 */
  	uint64_t mmioErrorLog1;		/* D48 */
  	uint64_t dma0ErrorStatus;	/* D80 */
  	uint64_t dma0FirstErrorStatus;	/* D88 */
  	uint64_t dma0ErrorLog0;		/* DC0 */
  	uint64_t dma0ErrorLog1;		/* DC8 */
  	uint64_t dma1ErrorStatus;	/* E00 */
  	uint64_t dma1FirstErrorStatus;	/* E08 */
  	uint64_t dma1ErrorLog0;		/* E40 */
  	uint64_t dma1ErrorLog1;		/* E48 */
  	uint64_t pestA[OPAL_PHB3_NUM_PEST_REGS];
  	uint64_t pestB[OPAL_PHB3_NUM_PEST_REGS];
  };
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
703
  typedef struct oppanel_line {
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
704
705
  	const char * 	line;
  	uint64_t 	line_len;
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
706
  } oppanel_line_t;
6f68b5e2c   Vasant Hegde   powerpc/powernv: ...
707
708
  /* /sys/firmware/opal */
  extern struct kobject *opal_kobj;
bfc36894a   Joel Stanley   powerpc/powernv: ...
709
710
  /* /ibm,opal */
  extern struct device_node *opal_node;
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
711
  /* API functions */
e28b05e7a   Joel Stanley   powerpc/powernv: ...
712
  int64_t opal_invalid_call(void);
4f89363b1   Benjamin Herrenschmidt   powerpc/powernv: ...
713
  int64_t opal_console_write(int64_t term_number, __be64 *length,
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
714
  			   const uint8_t *buffer);
4f89363b1   Benjamin Herrenschmidt   powerpc/powernv: ...
715
  int64_t opal_console_read(int64_t term_number, __be64 *length,
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
716
717
  			  uint8_t *buffer);
  int64_t opal_console_write_buffer_space(int64_t term_number,
4f89363b1   Benjamin Herrenschmidt   powerpc/powernv: ...
718
  					__be64 *length);
6feff6d4a   Anton Blanchard   powerpc/powernv: ...
719
720
  int64_t opal_rtc_read(__be32 *year_month_day,
  		      __be64 *hour_minute_second_millisecond);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
721
722
723
724
725
726
  int64_t opal_rtc_write(uint32_t year_month_day,
  		       uint64_t hour_minute_second_millisecond);
  int64_t opal_cec_power_down(uint64_t request);
  int64_t opal_cec_reboot(void);
  int64_t opal_read_nvram(uint64_t buffer, uint64_t size, uint64_t offset);
  int64_t opal_write_nvram(uint64_t buffer, uint64_t size, uint64_t offset);
5e4da530a   Anton Blanchard   powerpc/powernv: ...
727
  int64_t opal_handle_interrupt(uint64_t isn, __be64 *outstanding_event_mask);
4f89363b1   Benjamin Herrenschmidt   powerpc/powernv: ...
728
  int64_t opal_poll_events(__be64 *outstanding_event_mask);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
729
730
731
732
733
734
735
  int64_t opal_pci_set_hub_tce_memory(uint64_t hub_id, uint64_t tce_mem_addr,
  				    uint64_t tce_mem_size);
  int64_t opal_pci_set_phb_tce_memory(uint64_t phb_id, uint64_t tce_mem_addr,
  				    uint64_t tce_mem_size);
  int64_t opal_pci_config_read_byte(uint64_t phb_id, uint64_t bus_dev_func,
  				  uint64_t offset, uint8_t *data);
  int64_t opal_pci_config_read_half_word(uint64_t phb_id, uint64_t bus_dev_func,
5e4da530a   Anton Blanchard   powerpc/powernv: ...
736
  				       uint64_t offset, __be16 *data);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
737
  int64_t opal_pci_config_read_word(uint64_t phb_id, uint64_t bus_dev_func,
5e4da530a   Anton Blanchard   powerpc/powernv: ...
738
  				  uint64_t offset, __be32 *data);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
739
740
741
742
743
744
745
  int64_t opal_pci_config_write_byte(uint64_t phb_id, uint64_t bus_dev_func,
  				   uint64_t offset, uint8_t data);
  int64_t opal_pci_config_write_half_word(uint64_t phb_id, uint64_t bus_dev_func,
  					uint64_t offset, uint16_t data);
  int64_t opal_pci_config_write_word(uint64_t phb_id, uint64_t bus_dev_func,
  				   uint64_t offset, uint32_t data);
  int64_t opal_set_xive(uint32_t isn, uint16_t server, uint8_t priority);
5e4da530a   Anton Blanchard   powerpc/powernv: ...
746
  int64_t opal_get_xive(uint32_t isn, __be16 *server, uint8_t *priority);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
747
748
749
750
751
  int64_t opal_register_exception_handler(uint64_t opal_exception,
  					uint64_t handler_address,
  					uint64_t glue_cache_line);
  int64_t opal_pci_eeh_freeze_status(uint64_t phb_id, uint64_t pe_number,
  				   uint8_t *freeze_state,
5e4da530a   Anton Blanchard   powerpc/powernv: ...
752
753
  				   __be16 *pci_error_type,
  				   __be64 *phb_status);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
  int64_t opal_pci_eeh_freeze_clear(uint64_t phb_id, uint64_t pe_number,
  				  uint64_t eeh_action_token);
  int64_t opal_pci_shpc(uint64_t phb_id, uint64_t shpc_action, uint8_t *state);
  
  
  
  int64_t opal_pci_phb_mmio_enable(uint64_t phb_id, uint16_t window_type,
  				 uint16_t window_num, uint16_t enable);
  int64_t opal_pci_set_phb_mem_window(uint64_t phb_id, uint16_t window_type,
  				    uint16_t window_num,
  				    uint64_t starting_real_address,
  				    uint64_t starting_pci_address,
  				    uint16_t segment_size);
  int64_t opal_pci_map_pe_mmio_window(uint64_t phb_id, uint16_t pe_number,
  				    uint16_t window_type, uint16_t window_num,
  				    uint16_t segment_num);
  int64_t opal_pci_set_phb_table_memory(uint64_t phb_id, uint64_t rtt_addr,
  				      uint64_t ivt_addr, uint64_t ivt_len,
  				      uint64_t reject_array_addr,
  				      uint64_t peltv_addr);
  int64_t opal_pci_set_pe(uint64_t phb_id, uint64_t pe_number, uint64_t bus_dev_func,
  			uint8_t bus_compare, uint8_t dev_compare, uint8_t func_compare,
  			uint8_t pe_action);
  int64_t opal_pci_set_peltv(uint64_t phb_id, uint32_t parent_pe, uint32_t child_pe,
  			   uint8_t state);
  int64_t opal_pci_set_mve(uint64_t phb_id, uint32_t mve_number, uint32_t pe_number);
  int64_t opal_pci_set_mve_enable(uint64_t phb_id, uint32_t mve_number,
  				uint32_t state);
  int64_t opal_pci_get_xive_reissue(uint64_t phb_id, uint32_t xive_number,
  				  uint8_t *p_bit, uint8_t *q_bit);
  int64_t opal_pci_set_xive_reissue(uint64_t phb_id, uint32_t xive_number,
  				  uint8_t p_bit, uint8_t q_bit);
137436c9a   Gavin Shan   powerpc/powernv: ...
786
  int64_t opal_pci_msi_eoi(uint64_t phb_id, uint32_t hw_irq);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
787
788
789
  int64_t opal_pci_set_xive_pe(uint64_t phb_id, uint32_t pe_number,
  			     uint32_t xive_num);
  int64_t opal_get_xive_source(uint64_t phb_id, uint32_t xive_num,
5e4da530a   Anton Blanchard   powerpc/powernv: ...
790
  			     __be32 *interrupt_source_number);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
791
  int64_t opal_get_msi_32(uint64_t phb_id, uint32_t mve_number, uint32_t xive_num,
5e4da530a   Anton Blanchard   powerpc/powernv: ...
792
793
  			uint8_t msi_range, __be32 *msi_address,
  			__be32 *message_data);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
794
795
  int64_t opal_get_msi_64(uint64_t phb_id, uint32_t mve_number,
  			uint32_t xive_num, uint8_t msi_range,
5e4da530a   Anton Blanchard   powerpc/powernv: ...
796
  			__be64 *msi_address, __be32 *message_data);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
797
798
799
800
801
802
803
804
805
806
  int64_t opal_start_cpu(uint64_t thread_number, uint64_t start_address);
  int64_t opal_query_cpu_status(uint64_t thread_number, uint8_t *thread_status);
  int64_t opal_write_oppanel(oppanel_line_t *lines, uint64_t num_lines);
  int64_t opal_pci_map_pe_dma_window(uint64_t phb_id, uint16_t pe_number, uint16_t window_id,
  				   uint16_t tce_levels, uint64_t tce_table_addr,
  				   uint64_t tce_table_size, uint64_t tce_page_size);
  int64_t opal_pci_map_pe_dma_window_real(uint64_t phb_id, uint16_t pe_number,
  					uint16_t dma_window_number, uint64_t pci_start_addr,
  					uint64_t pci_mem_size);
  int64_t opal_pci_reset(uint64_t phb_id, uint8_t reset_scope, uint8_t assert_state);
23773230c   Gavin Shan   powerpc/eeh: Sync...
807
808
809
810
811
812
  int64_t opal_pci_get_hub_diag_data(uint64_t hub_id, void *diag_buffer,
  				   uint64_t diag_buffer_len);
  int64_t opal_pci_get_phb_diag_data(uint64_t phb_id, void *diag_buffer,
  				   uint64_t diag_buffer_len);
  int64_t opal_pci_get_phb_diag_data2(uint64_t phb_id, void *diag_buffer,
  				    uint64_t diag_buffer_len);
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
813
  int64_t opal_pci_fence_phb(uint64_t phb_id);
9be3becc2   Gavin Shan   powerpc/eeh: Call...
814
  int64_t opal_pci_reinit(uint64_t phb_id, uint64_t reinit_scope, uint64_t data);
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
815
816
  int64_t opal_pci_mask_pe_error(uint64_t phb_id, uint16_t pe_number, uint8_t error_type, uint8_t mask_action);
  int64_t opal_set_slot_led_status(uint64_t phb_id, uint64_t slot_id, uint8_t led_type, uint8_t led_action);
5e4da530a   Anton Blanchard   powerpc/powernv: ...
817
  int64_t opal_get_epow_status(__be64 *status);
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
818
  int64_t opal_set_system_attention_led(uint8_t led_action);
23773230c   Gavin Shan   powerpc/eeh: Sync...
819
820
821
  int64_t opal_pci_next_error(uint64_t phb_id, uint64_t *first_frozen_pe,
  			    uint16_t *pci_error_type, uint16_t *severity);
  int64_t opal_pci_poll(uint64_t phb_id);
13906db67   Benjamin Herrenschmidt   powerpc/powernv: ...
822
  int64_t opal_return_cpu(void);
f11fe5524   Benjamin Herrenschmidt   powerpc/powernv: ...
823

2f3f38e4d   Benjamin Herrenschmidt   powerpc/powernv: ...
824
825
  int64_t opal_xscom_read(uint32_t gcid, uint64_t pcb_addr, __be64 *val);
  int64_t opal_xscom_write(uint32_t gcid, uint64_t pcb_addr, uint64_t val);
cc0efb57e   Benjamin Herrenschmidt   powerpc/powernv: ...
826
827
828
829
  
  int64_t opal_lpc_write(uint32_t chip_id, enum OpalLPCAddressType addr_type,
  		       uint32_t addr, uint32_t data, uint32_t sz);
  int64_t opal_lpc_read(uint32_t chip_id, enum OpalLPCAddressType addr_type,
803c2d2f8   Benjamin Herrenschmidt   powerpc/powernv: ...
830
  		      uint32_t addr, __be32 *data, uint32_t sz);
774fea1a3   Stewart Smith   powerpc/powernv: ...
831

2bad74238   Anton Blanchard   powerpc/powernv: ...
832
  int64_t opal_read_elog(uint64_t buffer, uint64_t size, uint64_t log_id);
14ad0c58d   Anton Blanchard   powerpc/powernv: ...
833
  int64_t opal_get_elog_size(__be64 *log_id, __be64 *size, __be64 *elog_type);
774fea1a3   Stewart Smith   powerpc/powernv: ...
834
835
836
  int64_t opal_write_elog(uint64_t buffer, uint64_t size, uint64_t offset);
  int64_t opal_send_ack_elog(uint64_t log_id);
  void opal_resend_pending_logs(void);
50bd6153d   Vasant Hegde   powerpc/powernv: ...
837
838
839
  int64_t opal_validate_flash(uint64_t buffer, uint32_t *size, uint32_t *result);
  int64_t opal_manage_flash(uint8_t op);
  int64_t opal_update_flash(uint64_t blk_list);
c7e64b9ce   Stewart Smith   powerpc/powernv P...
840
  int64_t opal_dump_init(uint8_t dump_type);
2d6b63bbd   Anton Blanchard   powerpc/powernv: ...
841
842
  int64_t opal_dump_info(__be32 *dump_id, __be32 *dump_size);
  int64_t opal_dump_info2(__be32 *dump_id, __be32 *dump_size, __be32 *dump_type);
c7e64b9ce   Stewart Smith   powerpc/powernv P...
843
844
845
  int64_t opal_dump_read(uint32_t dump_id, uint64_t buffer);
  int64_t opal_dump_ack(uint32_t dump_id);
  int64_t opal_dump_resend_notification(void);
cc0efb57e   Benjamin Herrenschmidt   powerpc/powernv: ...
846

2bad74238   Anton Blanchard   powerpc/powernv: ...
847
848
  int64_t opal_get_msg(uint64_t buffer, uint64_t size);
  int64_t opal_check_completion(uint64_t buffer, uint64_t size, uint64_t token);
f7d98d18a   Vasant Hegde   powerpc/powernv: ...
849
  int64_t opal_sync_host_reboot(void);
4029cd665   Neelesh Gupta   powerpc/powernv: ...
850
  int64_t opal_get_param(uint64_t token, uint32_t param_id, uint64_t buffer,
2bad74238   Anton Blanchard   powerpc/powernv: ...
851
  		uint64_t length);
4029cd665   Neelesh Gupta   powerpc/powernv: ...
852
  int64_t opal_set_param(uint64_t token, uint32_t param_id, uint64_t buffer,
2bad74238   Anton Blanchard   powerpc/powernv: ...
853
  		uint64_t length);
9000c17dc   Anton Blanchard   powerpc/powernv: ...
854
  int64_t opal_sensor_read(uint32_t sensor_hndl, int token, __be32 *sensor_data);
243663600   Mahesh Salgaonkar   powerpc/powernv: ...
855

14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
856
  /* Internal functions */
e2c8b93e6   Anton Blanchard   powerpc/powernv: ...
857
858
  extern int early_init_dt_scan_opal(unsigned long node, const char *uname,
  				   int depth, void *data);
55672ecfa   Mahesh Salgaonkar   powerpc/book3s: R...
859
860
  extern int early_init_dt_scan_recoverable_ranges(unsigned long node,
  				 const char *uname, int depth, void *data);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
861
862
863
864
865
  
  extern int opal_get_chars(uint32_t vtermno, char *buf, int count);
  extern int opal_put_chars(uint32_t vtermno, const char *buf, int total_len);
  
  extern void hvc_opal_init_early(void);
1bc98de26   Gavin Shan   powernv/opal: Not...
866
  extern int opal_notifier_register(struct notifier_block *nb);
798af00c4   Benjamin Herrenschmidt   powerpc/powernv: ...
867
  extern int opal_notifier_unregister(struct notifier_block *nb);
243663600   Mahesh Salgaonkar   powerpc/powernv: ...
868
869
  extern int opal_message_notifier_register(enum OpalMessageType msg_type,
  						struct notifier_block *nb);
1bc98de26   Gavin Shan   powernv/opal: Not...
870
871
872
  extern void opal_notifier_enable(void);
  extern void opal_notifier_disable(void);
  extern void opal_notifier_update_evt(uint64_t evt_mask, uint64_t evt_val);
8d7248232   Neelesh Gupta   powerpc/powernv: ...
873
874
875
876
877
  extern int __opal_async_get_token(void);
  extern int opal_async_get_token_interruptible(void);
  extern int __opal_async_release_token(int token);
  extern int opal_async_release_token(int token);
  extern int opal_async_wait_response(uint64_t token, struct opal_msg *msg);
7224adbbb   Neelesh Gupta   powerpc/powernv: ...
878
  extern int opal_get_sensor_data(u32 sensor_hndl, u32 *sensor_data);
8d7248232   Neelesh Gupta   powerpc/powernv: ...
879

628daa8d5   Benjamin Herrenschmidt   powerpc/powernv: ...
880
881
882
883
884
  struct rtc_time;
  extern int opal_set_rtc_time(struct rtc_time *tm);
  extern void opal_get_rtc_time(struct rtc_time *tm);
  extern unsigned long opal_get_boot_time(void);
  extern void opal_nvram_init(void);
50bd6153d   Vasant Hegde   powerpc/powernv: ...
885
  extern void opal_flash_init(void);
774fea1a3   Stewart Smith   powerpc/powernv: ...
886
  extern int opal_elog_init(void);
c7e64b9ce   Stewart Smith   powerpc/powernv P...
887
  extern void opal_platform_dump_init(void);
4029cd665   Neelesh Gupta   powerpc/powernv: ...
888
  extern void opal_sys_param_init(void);
bfc36894a   Joel Stanley   powerpc/powernv: ...
889
  extern void opal_msglog_init(void);
628daa8d5   Benjamin Herrenschmidt   powerpc/powernv: ...
890

ed79ba9e1   Benjamin Herrenschmidt   powerpc/powernv: ...
891
  extern int opal_machine_check(struct pt_regs *regs);
55672ecfa   Mahesh Salgaonkar   powerpc/book3s: R...
892
  extern bool opal_mce_check_early_recovery(struct pt_regs *regs);
ed79ba9e1   Benjamin Herrenschmidt   powerpc/powernv: ...
893

73ed148ae   Benjamin Herrenschmidt   powerpc/powernv: ...
894
  extern void opal_shutdown(void);
97eb001f0   Vaidyanathan Srinivasan   powerpc/powernv: ...
895
  extern int opal_resync_timebase(void);
73ed148ae   Benjamin Herrenschmidt   powerpc/powernv: ...
896

3fafe9c20   Benjamin Herrenschmidt   powerpc/powernv: ...
897
  extern void opal_lpc_init(void);
3441f04b4   Anton Blanchard   powerpc/powernv: ...
898
899
900
  struct opal_sg_list *opal_vmalloc_to_sg_list(void *vmalloc_addr,
  					     unsigned long vmalloc_size);
  void opal_free_sg_list(struct opal_sg_list *sg);
14a43e69e   Benjamin Herrenschmidt   powerpc/powernv: ...
901
  #endif /* __ASSEMBLY__ */
27f448887   Benjamin Herrenschmidt   powerpc/powernv: ...
902
903
  
  #endif /* __OPAL_H */