]> rtime.felk.cvut.cz Git - mcf548x/linux.git/blob - arch/m68k/include/asm/segment.h
Current (FEC from 2.6.31 port, no CAN, no I2C, no PCI)
[mcf548x/linux.git] / arch / m68k / include / asm / 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
20 typedef 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
32 #ifndef CONFIG_COLDFIRE 
33
34 static inline mm_segment_t get_fs(void)
35 {
36 #ifdef CONFIG_MMU
37         mm_segment_t _v;
38         __asm__ ("movec %/dfc,%0":"=r" (_v.seg):);
39
40         return _v;
41 #else
42         return USER_DS;
43 #endif
44 }
45
46 static inline mm_segment_t get_ds(void)
47 {
48     /* return the supervisor data space code */
49     return KERNEL_DS;
50 }
51
52 static inline void set_fs(mm_segment_t val)
53 {
54 #ifdef CONFIG_MMU
55         __asm__ __volatile__ ("movec %0,%/sfc\n\t"
56                               "movec %0,%/dfc\n\t"
57                               : /* no outputs */ : "r" (val.seg) : "memory");
58 #endif
59 }
60
61 #else /* CONFIG_COLDFIRE */
62
63 #include <asm/current.h>
64 #define get_fs()        (current->thread.fs)
65 #define set_fs(val)     (current->thread.fs = (val))
66 #define get_ds()        (KERNEL_DS)
67
68 #endif /* CONFIG_COLDFIRE */
69
70 #define segment_eq(a,b) ((a).seg == (b).seg)
71
72 #endif /* __ASSEMBLY__ */
73
74 #endif /* _M68K_SEGMENT_H */