uaccess.h (4b4193256c8d3bc3a5397b5cd9494c2ad386317d) uaccess.h (66fc6a6254c7a138aef7806bd933c218e1aefcfc)
1/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Copyright (C) 2008-2009 Michal Simek <monstr@monstr.eu>
4 * Copyright (C) 2008-2009 PetaLogix
5 * Copyright (C) 2006 Atmark Techno, Inc.
6 */
7
8#ifndef _ASM_MICROBLAZE_UACCESS_H

--- 16 unchanged lines hidden (view full) ---

25 * get_fs() == KERNEL_DS, checking is bypassed.
26 *
27 * For historical reasons, these macros are grossly misnamed.
28 *
29 * For non-MMU arch like Microblaze, KERNEL_DS and USER_DS is equal.
30 */
31# define MAKE_MM_SEG(s) ((mm_segment_t) { (s) })
32
1/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Copyright (C) 2008-2009 Michal Simek <monstr@monstr.eu>
4 * Copyright (C) 2008-2009 PetaLogix
5 * Copyright (C) 2006 Atmark Techno, Inc.
6 */
7
8#ifndef _ASM_MICROBLAZE_UACCESS_H

--- 16 unchanged lines hidden (view full) ---

25 * get_fs() == KERNEL_DS, checking is bypassed.
26 *
27 * For historical reasons, these macros are grossly misnamed.
28 *
29 * For non-MMU arch like Microblaze, KERNEL_DS and USER_DS is equal.
30 */
31# define MAKE_MM_SEG(s) ((mm_segment_t) { (s) })
32
33# ifndef CONFIG_MMU
34# define KERNEL_DS MAKE_MM_SEG(0)
35# define USER_DS KERNEL_DS
36# else
37# define KERNEL_DS MAKE_MM_SEG(0xFFFFFFFF)
38# define USER_DS MAKE_MM_SEG(TASK_SIZE - 1)
33# define KERNEL_DS MAKE_MM_SEG(0xFFFFFFFF)
34# define USER_DS MAKE_MM_SEG(TASK_SIZE - 1)
39# endif
40
41# define get_fs() (current_thread_info()->addr_limit)
42# define set_fs(val) (current_thread_info()->addr_limit = (val))
43
44# define uaccess_kernel() (get_fs().seg == KERNEL_DS.seg)
45
35
36# define get_fs() (current_thread_info()->addr_limit)
37# define set_fs(val) (current_thread_info()->addr_limit = (val))
38
39# define uaccess_kernel() (get_fs().seg == KERNEL_DS.seg)
40
46#ifndef CONFIG_MMU
47
48/* Check against bounds of physical memory */
49static inline int ___range_ok(unsigned long addr, unsigned long size)
50{
51 return ((addr < memory_start) ||
52 ((addr + size - 1) > (memory_start + memory_size - 1)));
53}
54
55#define __range_ok(addr, size) \
56 ___range_ok((unsigned long)(addr), (unsigned long)(size))
57
58#define access_ok(addr, size) (__range_ok((addr), (size)) == 0)
59
60#else
61
62static inline int access_ok(const void __user *addr, unsigned long size)
63{
64 if (!size)
65 goto ok;
66
67 if ((get_fs().seg < ((unsigned long)addr)) ||
68 (get_fs().seg < ((unsigned long)addr + size - 1))) {
69 pr_devel("ACCESS fail at 0x%08x (size 0x%x), seg 0x%08x\n",
70 (__force u32)addr, (u32)size,
71 (u32)get_fs().seg);
72 return 0;
73 }
74ok:
75 pr_devel("ACCESS OK at 0x%08x (size 0x%x), seg 0x%08x\n",
76 (__force u32)addr, (u32)size,
77 (u32)get_fs().seg);
78 return 1;
79}
41static inline int access_ok(const void __user *addr, unsigned long size)
42{
43 if (!size)
44 goto ok;
45
46 if ((get_fs().seg < ((unsigned long)addr)) ||
47 (get_fs().seg < ((unsigned long)addr + size - 1))) {
48 pr_devel("ACCESS fail at 0x%08x (size 0x%x), seg 0x%08x\n",
49 (__force u32)addr, (u32)size,
50 (u32)get_fs().seg);
51 return 0;
52 }
53ok:
54 pr_devel("ACCESS OK at 0x%08x (size 0x%x), seg 0x%08x\n",
55 (__force u32)addr, (u32)size,
56 (u32)get_fs().seg);
57 return 1;
58}
80#endif
81
59
82#ifdef CONFIG_MMU
83# define __FIXUP_SECTION ".section .fixup,\"ax\"\n"
84# define __EX_TABLE_SECTION ".section __ex_table,\"a\"\n"
60# define __FIXUP_SECTION ".section .fixup,\"ax\"\n"
61# define __EX_TABLE_SECTION ".section __ex_table,\"a\"\n"
85#else
86# define __FIXUP_SECTION ".section .discard,\"ax\"\n"
87# define __EX_TABLE_SECTION ".section .discard,\"ax\"\n"
88#endif
89
90extern unsigned long __copy_tofrom_user(void __user *to,
91 const void __user *from, unsigned long size);
92
93/* Return: number of not copied bytes, i.e. 0 if OK or non-zero if fail. */
94static inline unsigned long __must_check __clear_user(void __user *to,
95 unsigned long n)
96{

--- 254 unchanged lines hidden ---
62
63extern unsigned long __copy_tofrom_user(void __user *to,
64 const void __user *from, unsigned long size);
65
66/* Return: number of not copied bytes, i.e. 0 if OK or non-zero if fail. */
67static inline unsigned long __must_check __clear_user(void __user *to,
68 unsigned long n)
69{

--- 254 unchanged lines hidden ---