Skip to content

Commit

Permalink
[CR][AArch64] Define MRS and MSR macros since kernel 4.9
Browse files Browse the repository at this point in the history
  • Loading branch information
cyring committed Feb 4, 2024
1 parent e56a53d commit af70a9d
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 16 deletions.
34 changes: 18 additions & 16 deletions aarch64/corefreqk.c
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,9 @@
#ifdef CONFIG_XEN
#include <xen/xen.h>
#endif /* CONFIG_XEN */
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 17, 0)
#include <asm/sysreg.h>
#endif
#ifdef CONFIG_ACPI
#include <linux/acpi.h>
#include <acpi/processor.h>
Expand Down Expand Up @@ -564,7 +566,7 @@ static void Query_Features(void *pArg)
:
: "memory"
);
mmfr2.value = read_sysreg_s(ID_AA64MMFR2_EL1);
mmfr2.value = MOV_SR_GPR(ID_AA64MMFR2_EL1);

iArg->Features->Info.Signature.Stepping = midr.Revision
| (midr.Variant << 4);
Expand Down Expand Up @@ -1118,7 +1120,7 @@ static void Query_Features(void *pArg)
}
if (iArg->Features->SVE | iArg->Features->SME)
{
volatile AA64ZFR0 zfr0 = {.value = read_sysreg_s(ID_AA64ZFR0_EL1)};
volatile AA64ZFR0 zfr0 = {.value = MOV_SR_GPR(ID_AA64ZFR0_EL1)};

switch (zfr0.SVE_F64MM) {
case 0b0001:
Expand Down Expand Up @@ -1209,7 +1211,7 @@ static void Query_Features(void *pArg)
}
}
if (iArg->Features->SME) {
volatile AA64SMFR0 smfr0 = {.value = read_sysreg_s(ID_AA64SMFR0_EL1)};
volatile AA64SMFR0 smfr0 = {.value = MOV_SR_GPR(ID_AA64SMFR0_EL1)};

switch (smfr0.SMEver) {
case 0b0010:
Expand Down Expand Up @@ -1274,7 +1276,7 @@ static void Query_Features(void *pArg)
}
if (Experimental && (iArg->HypervisorID == HYPERV_NONE)) {
/* Query the Cluster Configuration */
volatile CLUSTERCFR clustercfg = {.value=read_sysreg_s(CLUSTERCFR_EL1)};
volatile CLUSTERCFR clustercfg = {.value = MOV_SR_GPR(CLUSTERCFR_EL1)};
if (clustercfg.NUMCORE) {
iArg->SMT_Count = iArg->SMT_Count + clustercfg.NUMCORE;
}
Expand Down Expand Up @@ -1989,7 +1991,7 @@ void SystemRegisters(CORE_RO *Core)
volatile AA64MMFR1 mmfr1;
volatile AA64PFR0 pfr0;

isar2.value = read_sysreg_s(ID_AA64ISAR2_EL1);
isar2.value = MOV_SR_GPR(ID_AA64ISAR2_EL1);

__asm__ __volatile__(
"mrs %[cpacr], cpacr_el1" "\n\t"
Expand Down Expand Up @@ -2023,14 +2025,14 @@ void SystemRegisters(CORE_RO *Core)
}
Core->Query.SCTLRX = 0;
if (Experimental) {
volatile AA64MMFR3 mmfr3 = {.value = read_sysreg_s(ID_AA64MMFR3_EL1)};
volatile AA64MMFR3 mmfr3 = {.value = MOV_SR_GPR(ID_AA64MMFR3_EL1)};
if ((Core->Query.SCTLRX = mmfr3.SCTLRX) == 0b0001) {
Core->SystemRegister.SCTLR2 = read_sysreg_s(SCTLR2_EL1);
Core->SystemRegister.SCTLR2 = MOV_SR_GPR(SCTLR2_EL1);
}
}
if (PUBLIC(RO(Proc))->Features.DIT) {
Core->SystemRegister.FLAGS |= (
read_sysreg_s(MRS_DIT) & (1LLU << FLAG_DIT)
MOV_SR_GPR(MRS_DIT) & (1LLU << FLAG_DIT)
);
}
if (isar2.CLRBHB == 0b0001) {
Expand Down Expand Up @@ -2066,7 +2068,7 @@ void SystemRegisters(CORE_RO *Core)
}
if (PUBLIC(RO(Proc))->Features.SSBS == 0b0010)
{
SSBS2 mrs_ssbs = {.value = read_sysreg_s(MRS_SSBS2)};
SSBS2 mrs_ssbs = {.value = MOV_SR_GPR(MRS_SSBS2)};

if (mrs_ssbs.SSBS) {
BITSET_CC(LOCKLESS, PUBLIC(RW(Proc))->SSBS, Core->Bind);
Expand All @@ -2077,31 +2079,31 @@ void SystemRegisters(CORE_RO *Core)
}
if (PUBLIC(RO(Proc))->Features.PAN) {
Core->SystemRegister.FLAGS |= (
read_sysreg_s(MRS_PAN) & (1LLU << FLAG_PAN)
MOV_SR_GPR(MRS_PAN) & (1LLU << FLAG_PAN)
);
}
if (PUBLIC(RO(Proc))->Features.UAO) {
Core->SystemRegister.FLAGS |= (
read_sysreg_s(MRS_UAO) & (1LLU << FLAG_UAO)
MOV_SR_GPR(MRS_UAO) & (1LLU << FLAG_UAO)
);
}
if (PUBLIC(RO(Proc))->Features.MTE) {
Core->SystemRegister.FLAGS |= (
read_sysreg_s(MRS_TCO) & (1LLU << FLAG_TCO)
MOV_SR_GPR(MRS_TCO) & (1LLU << FLAG_TCO)
);
}
if (PUBLIC(RO(Proc))->Features.NMI) {
Core->SystemRegister.FLAGS |= (
read_sysreg_s(MRS_ALLINT) & (1LLU << FLAG_NMI)
MOV_SR_GPR(MRS_ALLINT) & (1LLU << FLAG_NMI)
);
}
if (PUBLIC(RO(Proc))->Features.EBEP) {
Core->SystemRegister.FLAGS |= (
read_sysreg_s(MRS_PM) & (1LLU << FLAG_PM)
MOV_SR_GPR(MRS_PM) & (1LLU << FLAG_PM)
);
}
if (PUBLIC(RO(Proc))->Features.SME) {
Core->SystemRegister.SVCR = read_sysreg_s(MRS_SVCR);
Core->SystemRegister.SVCR = MOV_SR_GPR(MRS_SVCR);
}
BITSET_CC(LOCKLESS, PUBLIC(RO(Proc))->CR_Mask, Core->Bind);
}
Expand Down Expand Up @@ -2154,7 +2156,7 @@ static void PerCore_GenericMachine(void *arg)
Core->Boost[BOOST(MIN)] = 8;

if (Experimental && (PUBLIC(RO(Proc))->HypervisorID == HYPERV_NONE)) {
cpupwrctl.value = read_sysreg_s(CPUPWRCTLR_EL1);
cpupwrctl.value = MOV_SR_GPR(CPUPWRCTLR_EL1);
Core->Query.CStateBaseAddr = cpupwrctl.WFI_RET_CTRL;
}
Core->Query.Revision = revid.Revision;
Expand Down
24 changes: 24 additions & 0 deletions aarch64/corefreqk.h
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,30 @@

#define KDIV(_opl, _opr) DIV_ROUND_CLOSEST((_opl), (_opr))

#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 17, 0)
#define sys_reg(op0, op1, crn, crm, op2) ({ \
UNUSED(op0); \
UNUSED(op1); \
UNUSED(crn); \
UNUSED(crm); \
UNUSED(op2); \
})
#endif

#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 9, 0)
#define MOV_SR_GPR(_reg) read_sysreg_s(_reg)
#define MOV_GPR_SR(_val, _reg) write_sysreg_s(_val, _reg)
#else
#define MOV_SR_GPR(_reg) ({ \
UNUSED(_reg); \
0; \
})
#define MOV_GPR_SR(_val, _reg) ({ \
UNUSED(_val); \
UNUSED(_reg); \
})
#endif

#define Atomic_Read_VPMC(_lock, _dest, _src) \
{ \
/* __asm__ volatile \
Expand Down

0 comments on commit af70a9d

Please sign in to comment.