| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef __ASM_SH_SEGMENT_H | 
 | 2 | #define __ASM_SH_SEGMENT_H | 
 | 3 |  | 
| Paul Mundt | 02f7e62 | 2008-06-03 18:48:54 +0900 | [diff] [blame] | 4 | #ifndef __ASSEMBLY__ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 5 |  | 
| Paul Mundt | 02f7e62 | 2008-06-03 18:48:54 +0900 | [diff] [blame] | 6 | typedef struct { | 
 | 7 | 	unsigned long seg; | 
 | 8 | } mm_segment_t; | 
 | 9 |  | 
 | 10 | #define MAKE_MM_SEG(s)	((mm_segment_t) { (s) }) | 
 | 11 |  | 
 | 12 | /* | 
 | 13 |  * The fs value determines whether argument validity checking should be | 
 | 14 |  * performed or not.  If get_fs() == USER_DS, checking is performed, with | 
 | 15 |  * get_fs() == KERNEL_DS, checking is bypassed. | 
 | 16 |  * | 
 | 17 |  * For historical reasons, these macros are grossly misnamed. | 
 | 18 |  */ | 
 | 19 | #define KERNEL_DS	MAKE_MM_SEG(0xFFFFFFFFUL) | 
 | 20 | #ifdef CONFIG_MMU | 
 | 21 | #define USER_DS		MAKE_MM_SEG(PAGE_OFFSET) | 
 | 22 | #else | 
 | 23 | #define USER_DS		KERNEL_DS | 
 | 24 | #endif | 
 | 25 |  | 
 | 26 | #define segment_eq(a,b)	((a).seg == (b).seg) | 
 | 27 |  | 
 | 28 | #define get_ds()	(KERNEL_DS) | 
 | 29 |  | 
 | 30 | #define get_fs()	(current_thread_info()->addr_limit) | 
 | 31 | #define set_fs(x)	(current_thread_info()->addr_limit = (x)) | 
 | 32 |  | 
 | 33 | #endif /* __ASSEMBLY__ */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 34 | #endif /* __ASM_SH_SEGMENT_H */ |