[DTrace-devel] [PATCH 2/4] bpf: add check for -masm=normal BPFC option

Elena Zannoni elena.zannoni at oracle.com
Sat May 25 00:59:30 UTC 2024


Reviewed-by: Elena Zannoni <elena.zannoni at oracle.com>

On 5/24/24 17:57, Kris Van Hees wrote:
> Newer BPF gcc cross compilers expect assembler instructions in pseudoc
> syntax rather than normal syntax by default.  Those versions support
> the -masm=normal option, so we test for that and use that option when
> mneeded.
> 
> Signed-off-by: Kris Van Hees <kris.van.hees at oracle.com>
> ---
>  GNUmakefile | 2 +-
>  Makeconfig  | 1 +
>  configure   | 1 +
>  3 files changed, 3 insertions(+), 1 deletion(-)
> 
> diff --git a/GNUmakefile b/GNUmakefile
> index 7d1af564..360058c6 100644
> --- a/GNUmakefile
> +++ b/GNUmakefile
> @@ -124,7 +124,7 @@ PREPROCESS = $(CC) -E
>  export BPFC ?= bpf-unknown-none-gcc
>  
>  BPFCPPFLAGS += -D$(subst sparc64,__sparc,$(subst aarch64,__aarch64__,$(subst x86_64,__amd64,$(ARCH))))
> -BPFCFLAGS ?= -O2 -Wall -Wno-unknown-pragmas $(if $(HAVE_BPFV3),-mcpu=v3)
> +BPFCFLAGS ?= -O2 -Wall -Wno-unknown-pragmas $(if $(HAVE_BPFV3),-mcpu=v3) $(if $(HAVE_BPFMASM),-masm=normal)
>  export BPFLD ?= bpf-unknown-none-ld
>  
>  all::
> diff --git a/Makeconfig b/Makeconfig
> index 87a601c8..f3d47c08 100644
> --- a/Makeconfig
> +++ b/Makeconfig
> @@ -231,6 +231,7 @@ $(eval $(call check-header-rule,DIS4,disassembler(0,0,0,NULL),disasm))
>  $(eval $(call check-header-rule,INITDISINFO3,init_disassemble_info(NULL,NULL,NULL),disasm))
>  $(eval $(call check-header-rule,INITDISINFO4,init_disassemble_info(NULL,NULL,NULL,NULL),disasm))
>  $(eval $(call check-bpfc-option-rule,BPFV3,-mcpu=v3))
> +$(eval $(call check-bpfc-option-rule,BPFMASM,-masm=normal))
>  
>  help-overrides::
>  	printf "\n" >&2
> diff --git a/configure b/configure
> index 40b870f8..c423bc82 100755
> --- a/configure
> +++ b/configure
> @@ -163,6 +163,7 @@ for option in "$@"; do
>          HAVE_CLOSE_RANGE=*) write_config_var CLOSE_RANGE "$option";;
>          HAVE_GETTID=*) write_config_var GETTID "$option";;
>          HAVE_BPFV3=*) write_config_var BPFV3 "$option";;
> +        HAVE_BPFMASM=*) write_config_var BPFMASM "$option";;
>  	*) echo "Unknown option $option" >&2
>             exit 1;;
>      esac




More information about the DTrace-devel mailing list