| 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 */ |