]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
riscv: remove address space overrides using set_fs()
authorChristoph Hellwig <hch@lst.de>
Mon, 7 Sep 2020 05:58:25 +0000 (07:58 +0200)
committerPalmer Dabbelt <palmerdabbelt@google.com>
Sun, 4 Oct 2020 17:27:10 +0000 (10:27 -0700)
Stop providing the possibility to override the address space using
set_fs() now that there is no need for that any more.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Palmer Dabbelt <palmerdabbelt@google.com>
arch/riscv/Kconfig
arch/riscv/include/asm/thread_info.h
arch/riscv/include/asm/uaccess.h
arch/riscv/kernel/process.c

index 1046ee7c0ccf5386f745f56228e196a273784a97..12642bab4700fd9d1137c3c17015ebf52c29369c 100644 (file)
@@ -87,7 +87,6 @@ config RISCV
        select SPARSE_IRQ
        select SYSCTL_EXCEPTION_TRACE
        select THREAD_INFO_IN_TASK
-       select SET_FS
        select UACCESS_MEMCPY if !MMU
 
 config ARCH_MMAP_RND_BITS_MIN
index 464a2bbc97ea334db9ac64c09b65f8ca1f54550c..a390711129de6471524141120419213e228a47e2 100644 (file)
 #include <asm/processor.h>
 #include <asm/csr.h>
 
-typedef struct {
-       unsigned long seg;
-} mm_segment_t;
-
 /*
  * low level task data that entry.S needs immediate access to
  * - this struct should fit entirely inside of one cache line
@@ -39,7 +35,6 @@ typedef struct {
 struct thread_info {
        unsigned long           flags;          /* low level flags */
        int                     preempt_count;  /* 0=>preemptible, <0=>BUG */
-       mm_segment_t            addr_limit;
        /*
         * These stack pointers are overwritten on every system call or
         * exception.  SP is also saved to the stack it can be recovered when
@@ -59,7 +54,6 @@ struct thread_info {
 {                                              \
        .flags          = 0,                    \
        .preempt_count  = INIT_PREEMPT_COUNT,   \
-       .addr_limit     = KERNEL_DS,            \
 }
 
 #endif /* !__ASSEMBLY__ */
index 264e52fb62b143ac65f020802edc82a2ccc25d65..c47e6b35c551f4a8500d3bd3200528b46ce3a034 100644 (file)
 #define __disable_user_access()                                                        \
        __asm__ __volatile__ ("csrc sstatus, %0" : : "r" (SR_SUM) : "memory")
 
-/*
- * The fs value determines whether argument validity checking should be
- * performed or not.  If get_fs() == USER_DS, checking is performed, with
- * get_fs() == KERNEL_DS, checking is bypassed.
- *
- * For historical reasons, these macros are grossly misnamed.
- */
-
-#define MAKE_MM_SEG(s) ((mm_segment_t) { (s) })
-
-#define KERNEL_DS      MAKE_MM_SEG(~0UL)
-#define USER_DS                MAKE_MM_SEG(TASK_SIZE)
-
-#define get_fs()       (current_thread_info()->addr_limit)
-
-static inline void set_fs(mm_segment_t fs)
-{
-       current_thread_info()->addr_limit = fs;
-}
-
-#define uaccess_kernel() (get_fs().seg == KERNEL_DS.seg)
-#define user_addr_max()        (get_fs().seg)
-
 /**
  * access_ok: - Checks if a user space pointer is valid
  * @addr: User space pointer to start of block to check
@@ -76,9 +53,7 @@ static inline void set_fs(mm_segment_t fs)
  */
 static inline int __access_ok(unsigned long addr, unsigned long size)
 {
-       const mm_segment_t fs = get_fs();
-
-       return size <= fs.seg && addr <= fs.seg - size;
+       return size <= TASK_SIZE && addr <= TASK_SIZE - size;
 }
 
 /*
index 2b97c493427c9e6b2210990d687d72f0e4abb21d..19225ec65db62f608f14493009410711a99b2783 100644 (file)
@@ -84,7 +84,6 @@ void start_thread(struct pt_regs *regs, unsigned long pc,
        }
        regs->epc = pc;
        regs->sp = sp;
-       set_fs(USER_DS);
 }
 
 void flush_thread(void)