 27c9d80f51
			
		
	
	27c9d80f51
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			62 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From: Johan Almbladh <johan.almbladh@anyfinetworks.com>
 | |
| Date: Tue, 5 Oct 2021 18:54:07 +0200
 | |
| Subject: [PATCH] mips: bpf: Enable eBPF JITs
 | |
| 
 | |
| This patch enables the new eBPF JITs for 32-bit and 64-bit MIPS. It also
 | |
| disables the old cBPF JIT to so cBPF programs are converted to use the
 | |
| new JIT.
 | |
| 
 | |
| Workarounds for R4000 CPU errata are not implemented by the JIT, so the
 | |
| JIT is disabled if any of those workarounds are configured.
 | |
| 
 | |
| Signed-off-by: Johan Almbladh <johan.almbladh@anyfinetworks.com>
 | |
| ---
 | |
| 
 | |
| --- a/MAINTAINERS
 | |
| +++ b/MAINTAINERS
 | |
| @@ -3431,6 +3431,7 @@ S:	Supported
 | |
|  F:	arch/arm64/net/
 | |
|  
 | |
|  BPF JIT for MIPS (32-BIT AND 64-BIT)
 | |
| +M:	Johan Almbladh <johan.almbladh@anyfinetworks.com>
 | |
|  M:	Paul Burton <paulburton@kernel.org>
 | |
|  L:	netdev@vger.kernel.org
 | |
|  L:	bpf@vger.kernel.org
 | |
| --- a/arch/mips/Kconfig
 | |
| +++ b/arch/mips/Kconfig
 | |
| @@ -58,7 +58,6 @@ config MIPS
 | |
|  	select HAVE_ARCH_TRACEHOOK
 | |
|  	select HAVE_ARCH_TRANSPARENT_HUGEPAGE if CPU_SUPPORTS_HUGEPAGES
 | |
|  	select HAVE_ASM_MODVERSIONS
 | |
| -	select HAVE_CBPF_JIT if !64BIT && !CPU_MICROMIPS
 | |
|  	select HAVE_CONTEXT_TRACKING
 | |
|  	select HAVE_TIF_NOHZ
 | |
|  	select HAVE_C_RECORDMCOUNT
 | |
| @@ -66,7 +65,10 @@ config MIPS
 | |
|  	select HAVE_DEBUG_STACKOVERFLOW
 | |
|  	select HAVE_DMA_CONTIGUOUS
 | |
|  	select HAVE_DYNAMIC_FTRACE
 | |
| -	select HAVE_EBPF_JIT if 64BIT && !CPU_MICROMIPS && TARGET_ISA_REV >= 2
 | |
| +	select HAVE_EBPF_JIT if !CPU_MICROMIPS && \
 | |
| +				!CPU_DADDI_WORKAROUNDS && \
 | |
| +				!CPU_R4000_WORKAROUNDS && \
 | |
| +				!CPU_R4400_WORKAROUNDS
 | |
|  	select HAVE_EXIT_THREAD
 | |
|  	select HAVE_FAST_GUP
 | |
|  	select HAVE_FTRACE_MCOUNT_RECORD
 | |
| --- a/arch/mips/net/Makefile
 | |
| +++ b/arch/mips/net/Makefile
 | |
| @@ -2,9 +2,10 @@
 | |
|  # MIPS networking code
 | |
|  
 | |
|  obj-$(CONFIG_MIPS_CBPF_JIT) += bpf_jit.o bpf_jit_asm.o
 | |
| +obj-$(CONFIG_MIPS_EBPF_JIT) += bpf_jit_comp.o
 | |
|  
 | |
|  ifeq ($(CONFIG_32BIT),y)
 | |
| -        obj-$(CONFIG_MIPS_EBPF_JIT) += bpf_jit_comp.o bpf_jit_comp32.o
 | |
| +        obj-$(CONFIG_MIPS_EBPF_JIT) += bpf_jit_comp32.o
 | |
|  else
 | |
| -        obj-$(CONFIG_MIPS_EBPF_JIT) += ebpf_jit.o
 | |
| +        obj-$(CONFIG_MIPS_EBPF_JIT) += bpf_jit_comp64.o
 | |
|  endif
 |