41 lines
1.2 KiB
ArmAsm
41 lines
1.2 KiB
ArmAsm
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
/*
|
||
|
* PowerPC ELF notes.
|
||
|
*
|
||
|
* Copyright 2019, IBM Corporation
|
||
|
*/
|
||
|
|
||
|
#include <linux/elfnote.h>
|
||
|
#include <asm/elfnote.h>
|
||
|
|
||
|
/*
|
||
|
* Ultravisor-capable bit (PowerNV only).
|
||
|
*
|
||
|
* Bit 0 indicates that the powerpc kernel binary knows how to run in an
|
||
|
* ultravisor-enabled system.
|
||
|
*
|
||
|
* In an ultravisor-enabled system, some machine resources are now controlled
|
||
|
* by the ultravisor. If the kernel is not ultravisor-capable, but it ends up
|
||
|
* being run on a machine with ultravisor, the kernel will probably crash
|
||
|
* trying to access ultravisor resources. For instance, it may crash in early
|
||
|
* boot trying to set the partition table entry 0.
|
||
|
*
|
||
|
* In an ultravisor-enabled system, a bootloader could warn the user or prevent
|
||
|
* the kernel from being run if the PowerPC ultravisor capability doesn't exist
|
||
|
* or the Ultravisor-capable bit is not set.
|
||
|
*/
|
||
|
#ifdef CONFIG_PPC_POWERNV
|
||
|
#define PPCCAP_ULTRAVISOR_BIT (1 << 0)
|
||
|
#else
|
||
|
#define PPCCAP_ULTRAVISOR_BIT 0
|
||
|
#endif
|
||
|
|
||
|
/*
|
||
|
* Add the PowerPC Capabilities in the binary ELF note. It is a bitmap that
|
||
|
* can be used to advertise kernel capabilities to userland.
|
||
|
*/
|
||
|
#define PPC_CAPABILITIES_BITMAP (PPCCAP_ULTRAVISOR_BIT)
|
||
|
|
||
|
ELFNOTE(PowerPC, PPC_ELFNOTE_CAPABILITIES,
|
||
|
.long PPC_CAPABILITIES_BITMAP)
|