From: Linus Torvalds Date: Sun, 16 Aug 2020 01:50:32 +0000 (-0700) Subject: Merge tag 'sh-for-5.9' of git://git.libc.org/linux-sh X-Git-Tag: baikal/mips/sdk5.9~12876 X-Git-Url: https://git.baikalelectronics.ru/?a=commitdiff_plain;h=24ef68b20f16cacf8ce89d9716c8613e0d4be897;p=kernel.git Merge tag 'sh-for-5.9' of git://git.libc.org/linux-sh Pull arch/sh updates from Rich Felker: "Cleanup, SECCOMP_FILTER support, message printing fixes, and other changes to arch/sh" * tag 'sh-for-5.9' of git://git.libc.org/linux-sh: (34 commits) sh: landisk: Add missing initialization of sh_io_port_base sh: bring syscall_set_return_value in line with other architectures sh: Add SECCOMP_FILTER sh: Rearrange blocks in entry-common.S sh: switch to copy_thread_tls() sh: use the generic dma coherent remap allocator sh: don't allow non-coherent DMA for NOMMU dma-mapping: consolidate the NO_DMA definition in kernel/dma/Kconfig sh: unexport register_trapped_io and match_trapped_io_handler sh: don't include in sh: move the ioremap implementation out of line sh: move ioremap_fixed details out of sh: remove __KERNEL__ ifdefs from non-UAPI headers sh: sort the selects for SUPERH alphabetically sh: remove -Werror from Makefiles sh: Replace HTTP links with HTTPS ones arch/sh/configs: remove obsolete CONFIG_SOC_CAMERA* sh: stacktrace: Remove stacktrace_ops.stack() sh: machvec: Modernize printing of kernel messages sh: pci: Modernize printing of kernel messages ... --- 24ef68b20f16cacf8ce89d9716c8613e0d4be897 diff --cc arch/m68k/Kconfig index 6663f1741798e,8e488369a7e55..6f2f38d05772a --- a/arch/m68k/Kconfig +++ b/arch/m68k/Kconfig @@@ -14,8 -14,10 +14,9 @@@ config M68 select HAVE_AOUT if MMU select HAVE_ASM_MODVERSIONS select HAVE_DEBUG_BUGVERBOSE - select HAVE_COPY_THREAD_TLS select GENERIC_IRQ_SHOW select GENERIC_ATOMIC64 + select NO_DMA if !MMU && !COLDFIRE select HAVE_UID16 select VIRT_TO_BUS select ARCH_HAVE_NMI_SAFE_CMPXCHG if RMW_INSNS diff --cc arch/sh/include/asm/sparsemem.h index 084706bb8cca4,ed287c4980bca..4703cbe238448 --- a/arch/sh/include/asm/sparsemem.h +++ b/arch/sh/include/asm/sparsemem.h @@@ -2,14 -2,13 +2,11 @@@ #ifndef __ASM_SH_SPARSEMEM_H #define __ASM_SH_SPARSEMEM_H - #ifdef __KERNEL__ /* * SECTION_SIZE_BITS 2^N: how big each section will be - * MAX_PHYSADDR_BITS 2^N: how much physical address space we have - * MAX_PHYSMEM_BITS 2^N: how much memory we can have in that space + * MAX_PHYSMEM_BITS 2^N: how much physical address space we have */ #define SECTION_SIZE_BITS 26 -#define MAX_PHYSADDR_BITS 32 #define MAX_PHYSMEM_BITS 32 - #endif - #endif /* __ASM_SH_SPARSEMEM_H */ diff --cc arch/sh/mm/init.c index cd1379360f08f,da7ea48f9439e..4735176ab811f --- a/arch/sh/mm/init.c +++ b/arch/sh/mm/init.c @@@ -27,8 -27,8 +27,9 @@@ #include #include #include +#include #include + #include "ioremap.h" pgd_t swapper_pg_dir[PTRS_PER_PGD]; diff --cc arch/um/Kconfig index ef69be17ff703,32c1d1945033e..eb51fec759484 --- a/arch/um/Kconfig +++ b/arch/um/Kconfig @@@ -14,6 -14,8 +14,7 @@@ config UM select HAVE_FUTEX_CMPXCHG if FUTEX select HAVE_DEBUG_KMEMLEAK select HAVE_DEBUG_BUGVERBOSE - select HAVE_COPY_THREAD_TLS + select NO_DMA select GENERIC_IRQ_SHOW select GENERIC_CPU_DEVICES select GENERIC_CLOCKEVENTS diff --cc tools/testing/selftests/seccomp/seccomp_bpf.c index 535720b2592ae,6eb21685c88f2..7a6d40286a421 --- a/tools/testing/selftests/seccomp/seccomp_bpf.c +++ b/tools/testing/selftests/seccomp/seccomp_bpf.c @@@ -131,8 -122,8 +131,10 @@@ struct seccomp_data # define __NR_seccomp 358 # elif defined(__s390__) # define __NR_seccomp 348 +# elif defined(__xtensa__) +# define __NR_seccomp 337 + # elif defined(__sh__) + # define __NR_seccomp 372 # else # warning "seccomp syscall number unknown for this architecture" # define __NR_seccomp 0xffff @@@ -1711,14 -1624,10 +1713,18 @@@ TEST_F(TRACE_poke, getpid_runs_normally # define SYSCALL_SYSCALL_NUM regs[4] # define SYSCALL_RET regs[2] # define SYSCALL_NUM_RET_SHARE_REG +#elif defined(__xtensa__) +# define ARCH_REGS struct user_pt_regs +# define SYSCALL_NUM syscall +/* + * On xtensa syscall return value is in the register + * a2 of the current window which is not fixed. + */ +#define SYSCALL_RET(reg) a[(reg).windowbase * 4 + 2] + #elif defined(__sh__) + # define ARCH_REGS struct pt_regs + # define SYSCALL_NUM gpr[3] + # define SYSCALL_RET gpr[0] #else # error "Do not know how to find your architecture's registers and syscalls" #endif @@@ -1790,8 -1699,7 +1796,8 @@@ void change_syscall(struct __test_metad EXPECT_EQ(0, ret) {} #if defined(__x86_64__) || defined(__i386__) || defined(__powerpc__) || \ - defined(__s390__) || defined(__hppa__) || defined(__riscv) || defined(__sh__) + defined(__s390__) || defined(__hppa__) || defined(__riscv) || \ - defined(__xtensa__) || defined(__csky__) ++ defined(__xtensa__) || defined(__csky__) || defined(__sh__) { regs.SYSCALL_NUM = syscall; }