2025-02-07 15:48:56 +01:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
/*
|
|
|
|
* Copyright IBM Corp. 2024
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __ASM_S390_MACHINE_H
|
|
|
|
#define __ASM_S390_MACHINE_H
|
|
|
|
|
2025-02-07 15:48:57 +01:00
|
|
|
#include <linux/const.h>
|
|
|
|
|
|
|
|
#define MFEATURE_LOWCORE 0
|
2025-02-07 15:48:58 +01:00
|
|
|
#define MFEATURE_PCI_MIO 1
|
2025-02-07 15:48:59 +01:00
|
|
|
#define MFEATURE_SCC 2
|
2025-02-07 15:49:00 +01:00
|
|
|
#define MFEATURE_TLB_GUEST 3
|
2025-02-07 15:49:01 +01:00
|
|
|
#define MFEATURE_TX 4
|
2025-02-07 15:49:02 +01:00
|
|
|
#define MFEATURE_ESOP 5
|
2025-02-07 15:49:03 +01:00
|
|
|
#define MFEATURE_DIAG9C 6
|
2025-02-07 15:49:07 +01:00
|
|
|
#define MFEATURE_VM 7
|
|
|
|
#define MFEATURE_KVM 8
|
|
|
|
#define MFEATURE_LPAR 9
|
2025-04-10 11:50:36 +02:00
|
|
|
#define MFEATURE_DIAG288 10
|
2025-02-07 15:48:57 +01:00
|
|
|
|
2025-06-11 16:00:46 +02:00
|
|
|
#ifndef __ASSEMBLER__
|
2025-02-07 15:48:56 +01:00
|
|
|
|
|
|
|
#include <linux/bitops.h>
|
|
|
|
#include <asm/alternative.h>
|
|
|
|
|
|
|
|
extern unsigned long machine_features[1];
|
|
|
|
|
|
|
|
#define MAX_MFEATURE_BIT (sizeof(machine_features) * BITS_PER_BYTE)
|
|
|
|
|
|
|
|
static inline void __set_machine_feature(unsigned int nr, unsigned long *mfeatures)
|
|
|
|
{
|
|
|
|
if (nr >= MAX_MFEATURE_BIT)
|
|
|
|
return;
|
|
|
|
__set_bit(nr, mfeatures);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void set_machine_feature(unsigned int nr)
|
|
|
|
{
|
|
|
|
__set_machine_feature(nr, machine_features);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void __clear_machine_feature(unsigned int nr, unsigned long *mfeatures)
|
|
|
|
{
|
|
|
|
if (nr >= MAX_MFEATURE_BIT)
|
|
|
|
return;
|
|
|
|
__clear_bit(nr, mfeatures);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void clear_machine_feature(unsigned int nr)
|
|
|
|
{
|
|
|
|
__clear_machine_feature(nr, machine_features);
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool __test_machine_feature(unsigned int nr, unsigned long *mfeatures)
|
|
|
|
{
|
|
|
|
if (nr >= MAX_MFEATURE_BIT)
|
|
|
|
return false;
|
|
|
|
return test_bit(nr, mfeatures);
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool test_machine_feature(unsigned int nr)
|
|
|
|
{
|
|
|
|
return __test_machine_feature(nr, machine_features);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __always_inline bool __test_machine_feature_constant(unsigned int nr)
|
|
|
|
{
|
|
|
|
asm goto(
|
|
|
|
ALTERNATIVE("brcl 15,%l[l_no]", "brcl 0,0", ALT_FEATURE(%[nr]))
|
|
|
|
:
|
|
|
|
: [nr] "i" (nr)
|
|
|
|
:
|
|
|
|
: l_no);
|
|
|
|
return true;
|
|
|
|
l_no:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
#define DEFINE_MACHINE_HAS_FEATURE(name, feature) \
|
|
|
|
static __always_inline bool machine_has_##name(void) \
|
|
|
|
{ \
|
|
|
|
if (!__is_defined(__DECOMPRESSOR) && __builtin_constant_p(feature)) \
|
|
|
|
return __test_machine_feature_constant(feature); \
|
|
|
|
return test_machine_feature(feature); \
|
|
|
|
}
|
|
|
|
|
2025-02-07 15:48:57 +01:00
|
|
|
DEFINE_MACHINE_HAS_FEATURE(relocated_lowcore, MFEATURE_LOWCORE)
|
2025-02-07 15:48:59 +01:00
|
|
|
DEFINE_MACHINE_HAS_FEATURE(scc, MFEATURE_SCC)
|
2025-02-07 15:49:00 +01:00
|
|
|
DEFINE_MACHINE_HAS_FEATURE(tlb_guest, MFEATURE_TLB_GUEST)
|
2025-02-07 15:49:01 +01:00
|
|
|
DEFINE_MACHINE_HAS_FEATURE(tx, MFEATURE_TX)
|
2025-02-07 15:49:02 +01:00
|
|
|
DEFINE_MACHINE_HAS_FEATURE(esop, MFEATURE_ESOP)
|
2025-02-07 15:49:03 +01:00
|
|
|
DEFINE_MACHINE_HAS_FEATURE(diag9c, MFEATURE_DIAG9C)
|
2025-02-07 15:49:07 +01:00
|
|
|
DEFINE_MACHINE_HAS_FEATURE(vm, MFEATURE_VM)
|
|
|
|
DEFINE_MACHINE_HAS_FEATURE(kvm, MFEATURE_KVM)
|
|
|
|
DEFINE_MACHINE_HAS_FEATURE(lpar, MFEATURE_LPAR)
|
|
|
|
|
|
|
|
#define machine_is_vm machine_has_vm
|
|
|
|
#define machine_is_kvm machine_has_kvm
|
|
|
|
#define machine_is_lpar machine_has_lpar
|
2025-02-07 15:48:57 +01:00
|
|
|
|
2025-06-11 16:00:46 +02:00
|
|
|
#endif /* __ASSEMBLER__ */
|
2025-02-07 15:48:56 +01:00
|
|
|
#endif /* __ASM_S390_MACHINE_H */
|