POWER9 Changes to OPAL API¶
This document is a summary of POWER9 changes to the OPAL API over what it was for POWER7 and POWER8. As the POWER series of processors (at least up to POWER9) require changes in the hypervisor to work on a new processor generation, this gives us an opportunity with POWER9 to clean up several parts of the OPAL API.
Eventually, when the kernel drops support for POWER8 and before, we can then remove the associated kernel code too.
OPAL_REINIT_CPUS¶
Can now be extended beyond HILE BE/LE bits. If invalid flags are set on POWER9, OPAL_UNSUPPORTED will be returned.
Device Tree¶
/ibm,opal/compatible property now just listsibm,opal-v3and no longeribm,opal-v2(power9 and above only)Use only
stdout-pathproperty from POWER9 and above as usage oflinux,stdout-pathis deprecatedRename
fsp-ipl-sideassp-ipl-sidein/ipl-paramsAdd interrupt-parent property for
/ibm,opal/ipminode on POWER9 and above to make use of OPAL irqchip rather than event interface in linux.
TODO¶
Things we still have to do for POWER9:
PCI to use async API rather than returning delays
deprecate/remove v1 APIs where there’s a V2
Fix this FWTS warning:
FAILED [MEDIUM] DeviceTreeBaseDTCWarnings: Test 3, dtc reports warnings from device tree: Warning (reg_format): "reg" property in /ibm,opal/flash@0 has invalid length (8 bytes) (#address-cells == 0, #size-cells == 0)
Remove mi-version / ml-version from
/ibm,opal/firmwareand replace with something better and more portable