Loading...
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef _M68K_SEGMENT_H
3#define _M68K_SEGMENT_H
4
5/* define constants */
6/* Address spaces (FC0-FC2) */
7#define USER_DATA (1)
8#ifndef __USER_DS
9#define __USER_DS (USER_DATA)
10#endif
11#define USER_PROGRAM (2)
12#define SUPER_DATA (5)
13#ifndef __KERNEL_DS
14#define __KERNEL_DS (SUPER_DATA)
15#endif
16#define SUPER_PROGRAM (6)
17#define CPU_SPACE (7)
18
19#ifndef __ASSEMBLY__
20
21typedef struct {
22 unsigned long seg;
23} mm_segment_t;
24
25#define MAKE_MM_SEG(s) ((mm_segment_t) { (s) })
26
27#ifdef CONFIG_CPU_HAS_ADDRESS_SPACES
28/*
29 * Get/set the SFC/DFC registers for MOVES instructions
30 */
31#define USER_DS MAKE_MM_SEG(__USER_DS)
32#define KERNEL_DS MAKE_MM_SEG(__KERNEL_DS)
33
34static inline mm_segment_t get_fs(void)
35{
36 mm_segment_t _v;
37 __asm__ ("movec %/dfc,%0":"=r" (_v.seg):);
38 return _v;
39}
40
41static inline void set_fs(mm_segment_t val)
42{
43 __asm__ __volatile__ ("movec %0,%/sfc\n\t"
44 "movec %0,%/dfc\n\t"
45 : /* no outputs */ : "r" (val.seg) : "memory");
46}
47
48#else
49#define USER_DS MAKE_MM_SEG(TASK_SIZE)
50#define KERNEL_DS MAKE_MM_SEG(0xFFFFFFFF)
51#define get_fs() (current_thread_info()->addr_limit)
52#define set_fs(x) (current_thread_info()->addr_limit = (x))
53#endif
54
55#define uaccess_kernel() (get_fs().seg == KERNEL_DS.seg)
56
57#endif /* __ASSEMBLY__ */
58
59#endif /* _M68K_SEGMENT_H */
1#ifndef _M68K_SEGMENT_H
2#define _M68K_SEGMENT_H
3
4/* define constants */
5/* Address spaces (FC0-FC2) */
6#define USER_DATA (1)
7#ifndef __USER_DS
8#define __USER_DS (USER_DATA)
9#endif
10#define USER_PROGRAM (2)
11#define SUPER_DATA (5)
12#ifndef __KERNEL_DS
13#define __KERNEL_DS (SUPER_DATA)
14#endif
15#define SUPER_PROGRAM (6)
16#define CPU_SPACE (7)
17
18#ifndef __ASSEMBLY__
19
20typedef struct {
21 unsigned long seg;
22} mm_segment_t;
23
24#define MAKE_MM_SEG(s) ((mm_segment_t) { (s) })
25#define USER_DS MAKE_MM_SEG(__USER_DS)
26#define KERNEL_DS MAKE_MM_SEG(__KERNEL_DS)
27
28/*
29 * Get/set the SFC/DFC registers for MOVES instructions
30 */
31
32static inline mm_segment_t get_fs(void)
33{
34#ifdef CONFIG_MMU
35 mm_segment_t _v;
36 __asm__ ("movec %/dfc,%0":"=r" (_v.seg):);
37
38 return _v;
39#else
40 return USER_DS;
41#endif
42}
43
44static inline mm_segment_t get_ds(void)
45{
46 /* return the supervisor data space code */
47 return KERNEL_DS;
48}
49
50static inline void set_fs(mm_segment_t val)
51{
52#ifdef CONFIG_MMU
53 __asm__ __volatile__ ("movec %0,%/sfc\n\t"
54 "movec %0,%/dfc\n\t"
55 : /* no outputs */ : "r" (val.seg) : "memory");
56#endif
57}
58
59#define segment_eq(a,b) ((a).seg == (b).seg)
60
61#endif /* __ASSEMBLY__ */
62
63#endif /* _M68K_SEGMENT_H */