2011-09-19 17:44:57 +00:00
|
|
|
/*
|
|
|
|
* PowerNV OPAL API wrappers
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2015-04-09 03:51:32 +00:00
|
|
|
#include <linux/jump_label.h>
|
2011-09-19 17:44:57 +00:00
|
|
|
#include <asm/ppc_asm.h>
|
|
|
|
#include <asm/hvcall.h>
|
|
|
|
#include <asm/asm-offsets.h>
|
|
|
|
#include <asm/opal.h>
|
2018-07-05 16:24:57 +00:00
|
|
|
#include <asm/asm-compat.h>
|
2014-07-03 07:20:50 +00:00
|
|
|
|
|
|
|
.section ".text"
|
|
|
|
|
|
|
|
#ifdef CONFIG_TRACEPOINTS
|
2014-10-30 04:43:43 +00:00
|
|
|
#ifdef HAVE_JUMP_LABEL
|
2014-07-03 07:20:50 +00:00
|
|
|
#define OPAL_BRANCH(LABEL) \
|
|
|
|
ARCH_STATIC_BRANCH(LABEL, opal_tracepoint_key)
|
|
|
|
#else
|
|
|
|
|
|
|
|
.section ".toc","aw"
|
|
|
|
|
|
|
|
.globl opal_tracepoint_refcount
|
|
|
|
opal_tracepoint_refcount:
|
2017-03-09 05:42:12 +00:00
|
|
|
.8byte 0
|
2014-07-03 07:20:50 +00:00
|
|
|
|
|
|
|
.section ".text"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* We branch around this in early init by using an unconditional cpu
|
|
|
|
* feature.
|
|
|
|
*/
|
|
|
|
#define OPAL_BRANCH(LABEL) \
|
|
|
|
BEGIN_FTR_SECTION; \
|
|
|
|
b 1f; \
|
|
|
|
END_FTR_SECTION(0, 1); \
|
2017-03-02 06:41:24 +00:00
|
|
|
ld r11,opal_tracepoint_refcount@toc(r2); \
|
|
|
|
cmpdi r11,0; \
|
2014-07-03 07:20:50 +00:00
|
|
|
bne- LABEL; \
|
|
|
|
1:
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#else
|
|
|
|
#define OPAL_BRANCH(LABEL)
|
|
|
|
#endif
|
2011-09-19 17:44:57 +00:00
|
|
|
|
2017-03-23 07:54:01 +00:00
|
|
|
/*
|
|
|
|
* DO_OPAL_CALL assumes:
|
|
|
|
* r0 = opal call token
|
|
|
|
* r12 = msr
|
|
|
|
* LR has been saved
|
2011-09-19 17:44:57 +00:00
|
|
|
*/
|
2017-03-23 07:54:01 +00:00
|
|
|
#define DO_OPAL_CALL() \
|
2017-02-07 05:03:17 +00:00
|
|
|
mfcr r11; \
|
|
|
|
stw r11,8(r1); \
|
2014-07-03 07:20:50 +00:00
|
|
|
li r11,0; \
|
|
|
|
ori r11,r11,MSR_EE; \
|
2011-09-19 17:44:57 +00:00
|
|
|
std r12,PACASAVEDMSR(r13); \
|
2014-07-03 07:20:50 +00:00
|
|
|
andc r12,r12,r11; \
|
2011-09-19 17:44:57 +00:00
|
|
|
mtmsrd r12,1; \
|
2014-07-03 07:20:50 +00:00
|
|
|
LOAD_REG_ADDR(r11,opal_return); \
|
|
|
|
mtlr r11; \
|
|
|
|
li r11,MSR_DR|MSR_IR|MSR_LE;\
|
|
|
|
andc r12,r12,r11; \
|
2011-09-19 17:44:57 +00:00
|
|
|
mtspr SPRN_HSRR1,r12; \
|
|
|
|
LOAD_REG_ADDR(r11,opal); \
|
|
|
|
ld r12,8(r11); \
|
|
|
|
ld r2,0(r11); \
|
|
|
|
mtspr SPRN_HSRR0,r12; \
|
|
|
|
hrfid
|
|
|
|
|
2017-03-23 07:54:01 +00:00
|
|
|
#define OPAL_CALL(name, token) \
|
|
|
|
_GLOBAL_TOC(name); \
|
|
|
|
mfmsr r12; \
|
|
|
|
mflr r0; \
|
|
|
|
andi. r11,r12,MSR_IR|MSR_DR; \
|
|
|
|
std r0,PPC_LR_STKOFF(r1); \
|
|
|
|
li r0,token; \
|
|
|
|
beq opal_real_call; \
|
|
|
|
OPAL_BRANCH(opal_tracepoint_entry) \
|
|
|
|
DO_OPAL_CALL()
|
|
|
|
|
|
|
|
|
2014-02-04 05:04:52 +00:00
|
|
|
opal_return:
|
2013-09-23 02:05:03 +00:00
|
|
|
/*
|
|
|
|
* Fixup endian on OPAL return... we should be able to simplify
|
|
|
|
* this by instead converting the below trampoline to a set of
|
|
|
|
* bytes (always BE) since MSR:LE will end up fixed up as a side
|
|
|
|
* effect of the rfid.
|
|
|
|
*/
|
2017-10-23 07:08:15 +00:00
|
|
|
FIXUP_ENDIAN_HV
|
2011-09-19 17:44:57 +00:00
|
|
|
ld r2,PACATOC(r13);
|
2013-10-15 03:36:31 +00:00
|
|
|
lwz r4,8(r1);
|
2016-07-08 06:37:11 +00:00
|
|
|
ld r5,PPC_LR_STKOFF(r1);
|
2011-09-19 17:44:57 +00:00
|
|
|
ld r6,PACASAVEDMSR(r13);
|
|
|
|
mtcr r4;
|
2017-05-01 12:01:10 +00:00
|
|
|
mtspr SPRN_HSRR0,r5;
|
|
|
|
mtspr SPRN_HSRR1,r6;
|
|
|
|
hrfid
|
2011-09-19 17:44:57 +00:00
|
|
|
|
2017-02-07 05:03:17 +00:00
|
|
|
opal_real_call:
|
|
|
|
mfcr r11
|
|
|
|
stw r11,8(r1)
|
|
|
|
/* Set opal return address */
|
|
|
|
LOAD_REG_ADDR(r11, opal_return_realmode)
|
|
|
|
mtlr r11
|
|
|
|
li r11,MSR_LE
|
|
|
|
andc r12,r12,r11
|
|
|
|
mtspr SPRN_HSRR1,r12
|
|
|
|
LOAD_REG_ADDR(r11,opal)
|
|
|
|
ld r12,8(r11)
|
|
|
|
ld r2,0(r11)
|
|
|
|
mtspr SPRN_HSRR0,r12
|
|
|
|
hrfid
|
|
|
|
|
|
|
|
opal_return_realmode:
|
2017-10-23 07:08:15 +00:00
|
|
|
FIXUP_ENDIAN_HV
|
2017-02-07 05:03:17 +00:00
|
|
|
ld r2,PACATOC(r13);
|
|
|
|
lwz r11,8(r1);
|
|
|
|
ld r12,PPC_LR_STKOFF(r1)
|
|
|
|
mtcr r11;
|
|
|
|
mtlr r12
|
|
|
|
blr
|
|
|
|
|
2014-07-03 07:20:50 +00:00
|
|
|
#ifdef CONFIG_TRACEPOINTS
|
|
|
|
opal_tracepoint_entry:
|
|
|
|
stdu r1,-STACKFRAMESIZE(r1)
|
|
|
|
std r0,STK_REG(R23)(r1)
|
|
|
|
std r3,STK_REG(R24)(r1)
|
|
|
|
std r4,STK_REG(R25)(r1)
|
|
|
|
std r5,STK_REG(R26)(r1)
|
|
|
|
std r6,STK_REG(R27)(r1)
|
|
|
|
std r7,STK_REG(R28)(r1)
|
|
|
|
std r8,STK_REG(R29)(r1)
|
|
|
|
std r9,STK_REG(R30)(r1)
|
|
|
|
std r10,STK_REG(R31)(r1)
|
|
|
|
mr r3,r0
|
|
|
|
addi r4,r1,STK_REG(R24)
|
|
|
|
bl __trace_opal_entry
|
|
|
|
ld r0,STK_REG(R23)(r1)
|
|
|
|
ld r3,STK_REG(R24)(r1)
|
|
|
|
ld r4,STK_REG(R25)(r1)
|
|
|
|
ld r5,STK_REG(R26)(r1)
|
|
|
|
ld r6,STK_REG(R27)(r1)
|
|
|
|
ld r7,STK_REG(R28)(r1)
|
|
|
|
ld r8,STK_REG(R29)(r1)
|
|
|
|
ld r9,STK_REG(R30)(r1)
|
|
|
|
ld r10,STK_REG(R31)(r1)
|
2017-03-23 07:54:01 +00:00
|
|
|
|
|
|
|
/* setup LR so we return via tracepoint_return */
|
2014-07-03 07:20:50 +00:00
|
|
|
LOAD_REG_ADDR(r11,opal_tracepoint_return)
|
|
|
|
std r11,16(r1)
|
2017-03-23 07:54:01 +00:00
|
|
|
|
2014-07-03 07:20:50 +00:00
|
|
|
mfmsr r12
|
2017-03-23 07:54:01 +00:00
|
|
|
DO_OPAL_CALL()
|
2014-07-03 07:20:50 +00:00
|
|
|
|
|
|
|
opal_tracepoint_return:
|
|
|
|
std r3,STK_REG(R31)(r1)
|
|
|
|
mr r4,r3
|
2017-02-07 10:01:01 +00:00
|
|
|
ld r3,STK_REG(R23)(r1)
|
2014-07-03 07:20:50 +00:00
|
|
|
bl __trace_opal_exit
|
|
|
|
ld r3,STK_REG(R31)(r1)
|
|
|
|
addi r1,r1,STACKFRAMESIZE
|
|
|
|
ld r0,16(r1)
|
|
|
|
mtlr r0
|
|
|
|
blr
|
|
|
|
#endif
|
|
|
|
|
2016-07-08 06:37:11 +00:00
|
|
|
|
2014-04-01 03:58:20 +00:00
|
|
|
OPAL_CALL(opal_invalid_call, OPAL_INVALID_CALL);
|
2011-09-19 17:44:57 +00:00
|
|
|
OPAL_CALL(opal_console_write, OPAL_CONSOLE_WRITE);
|
|
|
|
OPAL_CALL(opal_console_read, OPAL_CONSOLE_READ);
|
|
|
|
OPAL_CALL(opal_console_write_buffer_space, OPAL_CONSOLE_WRITE_BUFFER_SPACE);
|
|
|
|
OPAL_CALL(opal_rtc_read, OPAL_RTC_READ);
|
|
|
|
OPAL_CALL(opal_rtc_write, OPAL_RTC_WRITE);
|
|
|
|
OPAL_CALL(opal_cec_power_down, OPAL_CEC_POWER_DOWN);
|
|
|
|
OPAL_CALL(opal_cec_reboot, OPAL_CEC_REBOOT);
|
2015-07-31 15:54:38 +00:00
|
|
|
OPAL_CALL(opal_cec_reboot2, OPAL_CEC_REBOOT2);
|
2011-09-19 17:44:57 +00:00
|
|
|
OPAL_CALL(opal_read_nvram, OPAL_READ_NVRAM);
|
|
|
|
OPAL_CALL(opal_write_nvram, OPAL_WRITE_NVRAM);
|
|
|
|
OPAL_CALL(opal_handle_interrupt, OPAL_HANDLE_INTERRUPT);
|
|
|
|
OPAL_CALL(opal_poll_events, OPAL_POLL_EVENTS);
|
|
|
|
OPAL_CALL(opal_pci_set_hub_tce_memory, OPAL_PCI_SET_HUB_TCE_MEMORY);
|
|
|
|
OPAL_CALL(opal_pci_set_phb_tce_memory, OPAL_PCI_SET_PHB_TCE_MEMORY);
|
|
|
|
OPAL_CALL(opal_pci_config_read_byte, OPAL_PCI_CONFIG_READ_BYTE);
|
|
|
|
OPAL_CALL(opal_pci_config_read_half_word, OPAL_PCI_CONFIG_READ_HALF_WORD);
|
|
|
|
OPAL_CALL(opal_pci_config_read_word, OPAL_PCI_CONFIG_READ_WORD);
|
|
|
|
OPAL_CALL(opal_pci_config_write_byte, OPAL_PCI_CONFIG_WRITE_BYTE);
|
|
|
|
OPAL_CALL(opal_pci_config_write_half_word, OPAL_PCI_CONFIG_WRITE_HALF_WORD);
|
|
|
|
OPAL_CALL(opal_pci_config_write_word, OPAL_PCI_CONFIG_WRITE_WORD);
|
|
|
|
OPAL_CALL(opal_set_xive, OPAL_SET_XIVE);
|
|
|
|
OPAL_CALL(opal_get_xive, OPAL_GET_XIVE);
|
|
|
|
OPAL_CALL(opal_register_exception_handler, OPAL_REGISTER_OPAL_EXCEPTION_HANDLER);
|
|
|
|
OPAL_CALL(opal_pci_eeh_freeze_status, OPAL_PCI_EEH_FREEZE_STATUS);
|
|
|
|
OPAL_CALL(opal_pci_eeh_freeze_clear, OPAL_PCI_EEH_FREEZE_CLEAR);
|
2014-07-21 04:42:31 +00:00
|
|
|
OPAL_CALL(opal_pci_eeh_freeze_set, OPAL_PCI_EEH_FREEZE_SET);
|
2014-09-30 02:38:55 +00:00
|
|
|
OPAL_CALL(opal_pci_err_inject, OPAL_PCI_ERR_INJECT);
|
2011-09-19 17:44:57 +00:00
|
|
|
OPAL_CALL(opal_pci_shpc, OPAL_PCI_SHPC);
|
|
|
|
OPAL_CALL(opal_pci_phb_mmio_enable, OPAL_PCI_PHB_MMIO_ENABLE);
|
|
|
|
OPAL_CALL(opal_pci_set_phb_mem_window, OPAL_PCI_SET_PHB_MEM_WINDOW);
|
|
|
|
OPAL_CALL(opal_pci_map_pe_mmio_window, OPAL_PCI_MAP_PE_MMIO_WINDOW);
|
|
|
|
OPAL_CALL(opal_pci_set_phb_table_memory, OPAL_PCI_SET_PHB_TABLE_MEMORY);
|
|
|
|
OPAL_CALL(opal_pci_set_pe, OPAL_PCI_SET_PE);
|
|
|
|
OPAL_CALL(opal_pci_set_peltv, OPAL_PCI_SET_PELTV);
|
|
|
|
OPAL_CALL(opal_pci_set_mve, OPAL_PCI_SET_MVE);
|
|
|
|
OPAL_CALL(opal_pci_set_mve_enable, OPAL_PCI_SET_MVE_ENABLE);
|
|
|
|
OPAL_CALL(opal_pci_get_xive_reissue, OPAL_PCI_GET_XIVE_REISSUE);
|
|
|
|
OPAL_CALL(opal_pci_set_xive_reissue, OPAL_PCI_SET_XIVE_REISSUE);
|
|
|
|
OPAL_CALL(opal_pci_set_xive_pe, OPAL_PCI_SET_XIVE_PE);
|
|
|
|
OPAL_CALL(opal_get_xive_source, OPAL_GET_XIVE_SOURCE);
|
|
|
|
OPAL_CALL(opal_get_msi_32, OPAL_GET_MSI_32);
|
|
|
|
OPAL_CALL(opal_get_msi_64, OPAL_GET_MSI_64);
|
|
|
|
OPAL_CALL(opal_start_cpu, OPAL_START_CPU);
|
|
|
|
OPAL_CALL(opal_query_cpu_status, OPAL_QUERY_CPU_STATUS);
|
|
|
|
OPAL_CALL(opal_write_oppanel, OPAL_WRITE_OPPANEL);
|
|
|
|
OPAL_CALL(opal_pci_map_pe_dma_window, OPAL_PCI_MAP_PE_DMA_WINDOW);
|
|
|
|
OPAL_CALL(opal_pci_map_pe_dma_window_real, OPAL_PCI_MAP_PE_DMA_WINDOW_REAL);
|
|
|
|
OPAL_CALL(opal_pci_reset, OPAL_PCI_RESET);
|
2011-11-29 18:22:50 +00:00
|
|
|
OPAL_CALL(opal_pci_get_hub_diag_data, OPAL_PCI_GET_HUB_DIAG_DATA);
|
|
|
|
OPAL_CALL(opal_pci_get_phb_diag_data, OPAL_PCI_GET_PHB_DIAG_DATA);
|
|
|
|
OPAL_CALL(opal_pci_fence_phb, OPAL_PCI_FENCE_PHB);
|
|
|
|
OPAL_CALL(opal_pci_reinit, OPAL_PCI_REINIT);
|
|
|
|
OPAL_CALL(opal_pci_mask_pe_error, OPAL_PCI_MASK_PE_ERROR);
|
|
|
|
OPAL_CALL(opal_set_slot_led_status, OPAL_SET_SLOT_LED_STATUS);
|
|
|
|
OPAL_CALL(opal_get_epow_status, OPAL_GET_EPOW_STATUS);
|
2015-07-08 11:06:01 +00:00
|
|
|
OPAL_CALL(opal_get_dpo_status, OPAL_GET_DPO_STATUS);
|
2011-11-29 18:22:50 +00:00
|
|
|
OPAL_CALL(opal_set_system_attention_led, OPAL_SET_SYSTEM_ATTENTION_LED);
|
2013-06-20 05:21:05 +00:00
|
|
|
OPAL_CALL(opal_pci_next_error, OPAL_PCI_NEXT_ERROR);
|
|
|
|
OPAL_CALL(opal_pci_poll, OPAL_PCI_POLL);
|
2013-04-25 19:20:59 +00:00
|
|
|
OPAL_CALL(opal_pci_msi_eoi, OPAL_PCI_MSI_EOI);
|
2013-06-20 05:21:05 +00:00
|
|
|
OPAL_CALL(opal_pci_get_phb_diag_data2, OPAL_PCI_GET_PHB_DIAG_DATA2);
|
2013-07-15 03:03:09 +00:00
|
|
|
OPAL_CALL(opal_xscom_read, OPAL_XSCOM_READ);
|
|
|
|
OPAL_CALL(opal_xscom_write, OPAL_XSCOM_WRITE);
|
|
|
|
OPAL_CALL(opal_lpc_read, OPAL_LPC_READ);
|
|
|
|
OPAL_CALL(opal_lpc_write, OPAL_LPC_WRITE);
|
2013-08-21 03:03:20 +00:00
|
|
|
OPAL_CALL(opal_return_cpu, OPAL_RETURN_CPU);
|
2014-05-20 01:01:28 +00:00
|
|
|
OPAL_CALL(opal_reinit_cpus, OPAL_REINIT_CPUS);
|
powerpc/powernv: Read OPAL error log and export it through sysfs
Based on a patch by: Mahesh Salgaonkar <mahesh@linux.vnet.ibm.com>
This patch adds support to read error logs from OPAL and export
them to userspace through a sysfs interface.
We export each log entry as a directory in /sys/firmware/opal/elog/
Currently, OPAL will buffer up to 128 error log records, we don't
need to have any knowledge of this limit on the Linux side as that
is actually largely transparent to us.
Each error log entry has the following files: id, type, acknowledge, raw.
Currently we just export the raw binary error log in the 'raw' attribute.
In a future patch, we may parse more of the error log to make it a bit
easier for userspace (e.g. to be able to display a brief summary in
petitboot without having to have a full parser).
If we have >128 logs from OPAL, we'll only be notified of 128 until
userspace starts acknowledging them. This limitation may be lifted in
the future and with this patch, that should "just work" from the linux side.
A userspace daemon should:
- wait for error log entries using normal mechanisms (we announce creation)
- read error log entry
- save error log entry safely to disk
- acknowledge the error log entry
- rinse, repeat.
On the Linux side, we read the error log when we're notified of it. This
possibly isn't ideal as it would be better to only read them on-demand.
However, this doesn't really work with current OPAL interface, so we
read the error log immediately when notified at the moment.
I've tested this pretty extensively and am rather confident that the
linux side of things works rather well. There is currently an issue with
the service processor side of things for >128 error logs though.
Signed-off-by: Stewart Smith <stewart@linux.vnet.ibm.com>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
2014-02-28 00:58:32 +00:00
|
|
|
OPAL_CALL(opal_read_elog, OPAL_ELOG_READ);
|
|
|
|
OPAL_CALL(opal_send_ack_elog, OPAL_ELOG_ACK);
|
|
|
|
OPAL_CALL(opal_get_elog_size, OPAL_ELOG_SIZE);
|
|
|
|
OPAL_CALL(opal_resend_pending_logs, OPAL_ELOG_RESEND);
|
|
|
|
OPAL_CALL(opal_write_elog, OPAL_ELOG_WRITE);
|
2013-10-24 10:34:58 +00:00
|
|
|
OPAL_CALL(opal_validate_flash, OPAL_FLASH_VALIDATE);
|
|
|
|
OPAL_CALL(opal_manage_flash, OPAL_FLASH_MANAGE);
|
|
|
|
OPAL_CALL(opal_update_flash, OPAL_FLASH_UPDATE);
|
2014-02-26 00:08:43 +00:00
|
|
|
OPAL_CALL(opal_resync_timebase, OPAL_RESYNC_TIMEBASE);
|
2014-08-19 04:47:59 +00:00
|
|
|
OPAL_CALL(opal_check_token, OPAL_CHECK_TOKEN);
|
2014-03-02 23:25:42 +00:00
|
|
|
OPAL_CALL(opal_dump_init, OPAL_DUMP_INIT);
|
|
|
|
OPAL_CALL(opal_dump_info, OPAL_DUMP_INFO);
|
|
|
|
OPAL_CALL(opal_dump_info2, OPAL_DUMP_INFO2);
|
|
|
|
OPAL_CALL(opal_dump_read, OPAL_DUMP_READ);
|
|
|
|
OPAL_CALL(opal_dump_ack, OPAL_DUMP_ACK);
|
2013-11-18 10:05:58 +00:00
|
|
|
OPAL_CALL(opal_get_msg, OPAL_GET_MSG);
|
2016-06-29 03:38:39 +00:00
|
|
|
OPAL_CALL(opal_write_oppanel_async, OPAL_WRITE_OPPANEL_ASYNC);
|
2013-11-18 10:05:58 +00:00
|
|
|
OPAL_CALL(opal_check_completion, OPAL_CHECK_ASYNC_COMPLETION);
|
2014-03-02 23:25:42 +00:00
|
|
|
OPAL_CALL(opal_dump_resend_notification, OPAL_DUMP_RESEND);
|
2014-01-15 06:02:04 +00:00
|
|
|
OPAL_CALL(opal_sync_host_reboot, OPAL_SYNC_HOST_REBOOT);
|
2014-03-07 05:33:27 +00:00
|
|
|
OPAL_CALL(opal_sensor_read, OPAL_SENSOR_READ);
|
2014-03-07 05:32:09 +00:00
|
|
|
OPAL_CALL(opal_get_param, OPAL_GET_PARAM);
|
|
|
|
OPAL_CALL(opal_set_param, OPAL_SET_PARAM);
|
2014-07-29 13:10:07 +00:00
|
|
|
OPAL_CALL(opal_handle_hmi, OPAL_HANDLE_HMI);
|
2015-04-20 05:02:58 +00:00
|
|
|
OPAL_CALL(opal_config_cpu_idle_state, OPAL_CONFIG_CPU_IDLE_STATE);
|
2014-12-09 18:56:53 +00:00
|
|
|
OPAL_CALL(opal_slw_set_reg, OPAL_SLW_SET_REG);
|
2014-08-09 05:45:45 +00:00
|
|
|
OPAL_CALL(opal_register_dump_region, OPAL_REGISTER_DUMP_REGION);
|
|
|
|
OPAL_CALL(opal_unregister_dump_region, OPAL_UNREGISTER_DUMP_REGION);
|
2015-02-17 09:01:54 +00:00
|
|
|
OPAL_CALL(opal_pci_set_phb_cxl_mode, OPAL_PCI_SET_PHB_CAPI_MODE);
|
2014-10-14 08:38:36 +00:00
|
|
|
OPAL_CALL(opal_tpo_write, OPAL_WRITE_TPO);
|
|
|
|
OPAL_CALL(opal_tpo_read, OPAL_READ_TPO);
|
2014-11-06 03:38:27 +00:00
|
|
|
OPAL_CALL(opal_ipmi_send, OPAL_IPMI_SEND);
|
|
|
|
OPAL_CALL(opal_ipmi_recv, OPAL_IPMI_RECV);
|
2014-12-13 18:01:05 +00:00
|
|
|
OPAL_CALL(opal_i2c_request, OPAL_I2C_REQUEST);
|
2015-04-01 06:05:30 +00:00
|
|
|
OPAL_CALL(opal_flash_read, OPAL_FLASH_READ);
|
|
|
|
OPAL_CALL(opal_flash_write, OPAL_FLASH_WRITE);
|
|
|
|
OPAL_CALL(opal_flash_erase, OPAL_FLASH_ERASE);
|
2015-06-04 13:51:47 +00:00
|
|
|
OPAL_CALL(opal_prd_msg, OPAL_PRD_MSG);
|
2015-08-19 16:49:52 +00:00
|
|
|
OPAL_CALL(opal_leds_get_ind, OPAL_LEDS_GET_INDICATOR);
|
|
|
|
OPAL_CALL(opal_leds_set_ind, OPAL_LEDS_SET_INDICATOR);
|
2015-11-27 06:23:07 +00:00
|
|
|
OPAL_CALL(opal_console_flush, OPAL_CONSOLE_FLUSH);
|
2016-05-20 06:41:41 +00:00
|
|
|
OPAL_CALL(opal_get_device_tree, OPAL_GET_DEVICE_TREE);
|
|
|
|
OPAL_CALL(opal_pci_get_presence_state, OPAL_PCI_GET_PRESENCE_STATE);
|
|
|
|
OPAL_CALL(opal_pci_get_power_state, OPAL_PCI_GET_POWER_STATE);
|
|
|
|
OPAL_CALL(opal_pci_set_power_state, OPAL_PCI_SET_POWER_STATE);
|
2016-07-08 06:37:05 +00:00
|
|
|
OPAL_CALL(opal_int_get_xirr, OPAL_INT_GET_XIRR);
|
|
|
|
OPAL_CALL(opal_int_set_cppr, OPAL_INT_SET_CPPR);
|
|
|
|
OPAL_CALL(opal_int_eoi, OPAL_INT_EOI);
|
|
|
|
OPAL_CALL(opal_int_set_mfrr, OPAL_INT_SET_MFRR);
|
2016-07-08 06:37:11 +00:00
|
|
|
OPAL_CALL(opal_pci_tce_kill, OPAL_PCI_TCE_KILL);
|
2016-12-14 02:36:51 +00:00
|
|
|
OPAL_CALL(opal_nmmu_set_ptcr, OPAL_NMMU_SET_PTCR);
|
2017-04-05 23:01:33 +00:00
|
|
|
OPAL_CALL(opal_xive_reset, OPAL_XIVE_RESET);
|
|
|
|
OPAL_CALL(opal_xive_get_irq_info, OPAL_XIVE_GET_IRQ_INFO);
|
|
|
|
OPAL_CALL(opal_xive_get_irq_config, OPAL_XIVE_GET_IRQ_CONFIG);
|
|
|
|
OPAL_CALL(opal_xive_set_irq_config, OPAL_XIVE_SET_IRQ_CONFIG);
|
|
|
|
OPAL_CALL(opal_xive_get_queue_info, OPAL_XIVE_GET_QUEUE_INFO);
|
|
|
|
OPAL_CALL(opal_xive_set_queue_info, OPAL_XIVE_SET_QUEUE_INFO);
|
|
|
|
OPAL_CALL(opal_xive_donate_page, OPAL_XIVE_DONATE_PAGE);
|
|
|
|
OPAL_CALL(opal_xive_alloc_vp_block, OPAL_XIVE_ALLOCATE_VP_BLOCK);
|
|
|
|
OPAL_CALL(opal_xive_free_vp_block, OPAL_XIVE_FREE_VP_BLOCK);
|
|
|
|
OPAL_CALL(opal_xive_allocate_irq, OPAL_XIVE_ALLOCATE_IRQ);
|
|
|
|
OPAL_CALL(opal_xive_free_irq, OPAL_XIVE_FREE_IRQ);
|
|
|
|
OPAL_CALL(opal_xive_get_vp_info, OPAL_XIVE_GET_VP_INFO);
|
|
|
|
OPAL_CALL(opal_xive_set_vp_info, OPAL_XIVE_SET_VP_INFO);
|
|
|
|
OPAL_CALL(opal_xive_sync, OPAL_XIVE_SYNC);
|
|
|
|
OPAL_CALL(opal_xive_dump, OPAL_XIVE_DUMP);
|
2017-09-29 03:29:42 +00:00
|
|
|
OPAL_CALL(opal_signal_system_reset, OPAL_SIGNAL_SYSTEM_RESET);
|
2017-04-03 09:51:44 +00:00
|
|
|
OPAL_CALL(opal_npu_init_context, OPAL_NPU_INIT_CONTEXT);
|
|
|
|
OPAL_CALL(opal_npu_destroy_context, OPAL_NPU_DESTROY_CONTEXT);
|
|
|
|
OPAL_CALL(opal_npu_map_lpar, OPAL_NPU_MAP_LPAR);
|
2017-07-18 21:36:32 +00:00
|
|
|
OPAL_CALL(opal_imc_counters_init, OPAL_IMC_COUNTERS_INIT);
|
|
|
|
OPAL_CALL(opal_imc_counters_start, OPAL_IMC_COUNTERS_START);
|
|
|
|
OPAL_CALL(opal_imc_counters_stop, OPAL_IMC_COUNTERS_STOP);
|
powerpc/powernv: Enable PCI peer-to-peer
P9 has support for PCI peer-to-peer, enabling a device to write in the
MMIO space of another device directly, without interrupting the CPU.
This patch adds support for it on powernv, by adding a new API to be
called by drivers. The pnv_pci_set_p2p(...) call configures an
'initiator', i.e the device which will issue the MMIO operation, and a
'target', i.e. the device on the receiving side.
P9 really only supports MMIO stores for the time being but that's
expected to change in the future, so the API allows to define both
load and store operations.
/* PCI p2p descriptor */
#define OPAL_PCI_P2P_ENABLE 0x1
#define OPAL_PCI_P2P_LOAD 0x2
#define OPAL_PCI_P2P_STORE 0x4
int pnv_pci_set_p2p(struct pci_dev *initiator, struct pci_dev *target,
u64 desc)
It uses a new OPAL call, as the configuration magic is done on the
PHBs by skiboot.
Signed-off-by: Frederic Barrat <fbarrat@linux.vnet.ibm.com>
Reviewed-by: Russell Currey <ruscur@russell.cc>
[mpe: Drop unrelated OPAL calls, s/uint64_t/u64/, minor formatting]
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
2017-08-04 09:55:14 +00:00
|
|
|
OPAL_CALL(opal_pci_set_p2p, OPAL_PCI_SET_P2P);
|
2017-08-10 03:31:18 +00:00
|
|
|
OPAL_CALL(opal_get_powercap, OPAL_GET_POWERCAP);
|
|
|
|
OPAL_CALL(opal_set_powercap, OPAL_SET_POWERCAP);
|
2017-08-10 03:31:19 +00:00
|
|
|
OPAL_CALL(opal_get_power_shift_ratio, OPAL_GET_POWER_SHIFT_RATIO);
|
|
|
|
OPAL_CALL(opal_set_power_shift_ratio, OPAL_SET_POWER_SHIFT_RATIO);
|
2017-08-10 03:31:20 +00:00
|
|
|
OPAL_CALL(opal_sensor_group_clear, OPAL_SENSOR_GROUP_CLEAR);
|
2018-05-10 12:21:48 +00:00
|
|
|
OPAL_CALL(opal_quiesce, OPAL_QUIESCE);
|
2018-01-23 11:31:38 +00:00
|
|
|
OPAL_CALL(opal_npu_spa_setup, OPAL_NPU_SPA_SETUP);
|
|
|
|
OPAL_CALL(opal_npu_spa_clear_cache, OPAL_NPU_SPA_CLEAR_CACHE);
|
|
|
|
OPAL_CALL(opal_npu_tl_set, OPAL_NPU_TL_SET);
|
2018-03-02 09:56:11 +00:00
|
|
|
OPAL_CALL(opal_pci_get_pbcq_tunnel_bar, OPAL_PCI_GET_PBCQ_TUNNEL_BAR);
|
|
|
|
OPAL_CALL(opal_pci_set_pbcq_tunnel_bar, OPAL_PCI_SET_PBCQ_TUNNEL_BAR);
|
2018-05-07 10:25:36 +00:00
|
|
|
OPAL_CALL(opal_sensor_read_u64, OPAL_SENSOR_READ_U64);
|