.. Kenneth Lee 版权所有 2020
:Authors: Kenneth Lee :Version: 1.0
ARM64 Linux Kernel 5.7无法GDB调试问题
Linux主线Kernel刚发布了5.7,同步上去后,我的gdb调试功能异常了,加载内核一堆错误 :::
FD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
BFD: warning: vmlinux: unsupported GNU_PROPERTY_TYPE (5) type: 0xc0000000
强行调试会出各种错误。
从这里(https://github.com/ClangBuiltLinux/linux/issues/844)可以知道,这是新的 ARM8.3a+ PAC和BTI特性(指针和跳转鉴权)引起的,这两个特性需要binutils支持这种新 的段类型,但gdb还没有支持。
查了一下内核的编译参数,在arch/arm64/Makefile中可以看到这个定义:::
ifeq ($(CONFIG_ARM64_PTR_AUTH),y)
branch-prot-flags-$(CONFIG_CC_HAS_SIGN_RETURN_ADDRESS) := -msign-return-address=all
branch-prot-flags-$(CONFIG_CC_HAS_BRANCH_PROT_PAC_RET) := -mbranch-protection=pac-ret+leaf
# -march=armv8.3-a enables the non-nops instructions for PAC, to avoid the
# compiler to generate them and consequently to break the single image contract
# we pass it only to the assembler. This option is utilized only in case of non
# integrated assemblers.
branch-prot-flags-$(CONFIG_AS_HAS_PAC) += -Wa,-march=armv8.3-a
endif
代码是3月份Kristina Martsenko提交的补丁(但合入应该是5.7才正式生效的):::
74afda4016a74 (Kristina Martsenko 2020-03-13 14:35:03 +0530 72) ifeq ($(CONFIG_ARM64_PTR_AUTH),y)
74afda4016a74 (Kristina Martsenko 2020-03-13 14:35:03 +0530 73) branch-prot-flags-$(CONFIG_CC_HAS_SIGN_RETURN_ADDRESS) := -msign-r eturn-address=all
暂时不知道有稳定的支持的gdb可以使用,所以如果各位需要继续正常调试当前ARM的内核 ,请关掉这个配置项:CONFIG_ARM64_PTR_AUTH。