chao an 2023-03-06 21:33:34 +08:00 committed by Petro Karashchenko
parent 3c3dea5d7a
commit 815f40c8f1
2 changed files with 46 additions and 10 deletions

View File

@ -1049,6 +1049,12 @@ config ARM_HAVE_MVE
---help--- ---help---
Decide whether support MVE instruction Decide whether support MVE instruction
config ARM_HAVE_PACBTI
bool
default n
---help---
Decide whether support PACBTI(Pointer Authentication and Branch Target Identification) Extension
config ARM_FPU_ABI_SOFT config ARM_FPU_ABI_SOFT
bool "Soft Float ABI" bool "Soft Float ABI"
default n default n
@ -1073,6 +1079,13 @@ config ARM_DSP
---help--- ---help---
Enables DSP Extension Enables DSP Extension
config ARM_PACBTI
bool "Advanced PACBTI Extension"
default y
depends on ARM_HAVE_PACBTI
---help---
Enables PACBTI(Pointer Authentication and Branch Target Identification) Extension
config ARM_HAVE_MPU_UNIFIED config ARM_HAVE_MPU_UNIFIED
bool bool
default n default n

View File

@ -24,6 +24,37 @@ ifeq ($(CONFIG_ARM_DSP),y)
EXTCPUFLAGS = +dsp EXTCPUFLAGS = +dsp
endif endif
ifeq ($(CONFIG_ARM_PACBTI),y)
EXTCPUFLAGS := $(EXTCPUFLAGS)+pacbti
# Protects branches using pointer authentication and Branch Target Identification.
#
# The default is -mbranch-protection=none.
#
# -mbranch-protection=standard:
# Enables all types of branch protection to their standard values.
# The standard protection is equivalent to -mbranch-protection=bti+pac-ret.
#
# -mbranch-protection=bti:
# Enables branch protection using Branch Target Identification.
#
# -mbranch-protection=pac-ret:
# Enables branch protection using pointer authentication using key A.
#
# +leaf:
# Enables pointer authentication on all leaf functions, including the leaf
# functions that do not save the LR on the stack.
#
# +b-key:
# Enables pointer authentication with Key B, rather than Key A.
ARCHOPTIMIZATION += -mbranch-protection=standard
endif
ifeq ($(CONFIG_ARM_HAVE_MVE),y)
EXTCPUFLAGS := $(EXTCPUFLAGS)+mve.fp+fp.dp
endif
ifeq ($(CONFIG_ARCH_CORTEXM23),y) ifeq ($(CONFIG_ARCH_CORTEXM23),y)
TOOLCHAIN_MTUNE := -mtune=cortex-m23 TOOLCHAIN_MTUNE := -mtune=cortex-m23
TOOLCHAIN_MARCH := -march=armv8-m.main TOOLCHAIN_MARCH := -march=armv8-m.main
@ -45,22 +76,14 @@ else ifeq ($(CONFIG_ARCH_CORTEXM35P),y)
ZARCHCPUFLAGS := -mcpu=cortex_m35p ZARCHCPUFLAGS := -mcpu=cortex_m35p
else ifeq ($(CONFIG_ARCH_CORTEXM55),y) else ifeq ($(CONFIG_ARCH_CORTEXM55),y)
TOOLCHAIN_MTUNE := -mtune=cortex-m55 TOOLCHAIN_MTUNE := -mtune=cortex-m55
ifeq ($(CONFIG_ARM_HAVE_MVE),y)
TOOLCHAIN_MARCH := -march=armv8.1-m.main+mve.fp+fp.dp
else
TOOLCHAIN_MARCH := -march=armv8.1-m.main$(EXTCPUFLAGS) TOOLCHAIN_MARCH := -march=armv8.1-m.main$(EXTCPUFLAGS)
endif
ifeq ($(CONFIG_ARCH_FPU),y) ifeq ($(CONFIG_ARCH_FPU),y)
TOOLCHAIN_MFLOAT := -mfpu=fpv5-d16 TOOLCHAIN_MFLOAT := -mfpu=fpv5-d16
endif endif
ZARCHCPUFLAGS := -mcpu=cortex_m55 ZARCHCPUFLAGS := -mcpu=cortex_m55
else ifeq ($(CONFIG_ARCH_CORTEXM85),y) else ifeq ($(CONFIG_ARCH_CORTEXM85),y)
TOOLCHAIN_MTUNE := -mtune=cortex-m85 TOOLCHAIN_MTUNE := -mtune=cortex-m85
ifeq ($(CONFIG_ARM_HAVE_MVE),y)
TOOLCHAIN_MARCH := -march=armv8.1-m.main+mve.fp+fp.dp
else
TOOLCHAIN_MARCH := -march=armv8.1-m.main$(EXTCPUFLAGS) TOOLCHAIN_MARCH := -march=armv8.1-m.main$(EXTCPUFLAGS)
endif
ifeq ($(CONFIG_ARCH_FPU),y) ifeq ($(CONFIG_ARCH_FPU),y)
TOOLCHAIN_MFLOAT := -mfpu=fpv5-d16 TOOLCHAIN_MFLOAT := -mfpu=fpv5-d16
endif endif