| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef _M68K_SHM_H | 
|  | 2 | #define _M68K_SHM_H | 
|  | 3 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 4 |  | 
|  | 5 | /* format of page table entries that correspond to shared memory pages | 
|  | 6 | currently out in swap space (see also mm/swap.c): | 
|  | 7 | bits 0-1 (PAGE_PRESENT) is  = 0 | 
|  | 8 | bits 8..2 (SWP_TYPE) are = SHM_SWP_TYPE | 
|  | 9 | bits 31..9 are used like this: | 
|  | 10 | bits 15..9 (SHM_ID) the id of the shared memory segment | 
|  | 11 | bits 30..16 (SHM_IDX) the index of the page within the shared memory segment | 
|  | 12 | (actually only bits 25..16 get used since SHMMAX is so low) | 
|  | 13 | bit 31 (SHM_READ_ONLY) flag whether the page belongs to a read-only attach | 
|  | 14 | */ | 
|  | 15 | /* on the m68k both bits 0 and 1 must be zero */ | 
|  | 16 | /* format on the sun3 is similar, but bits 30, 31 are set to zero and all | 
|  | 17 | others are reduced by 2. --m */ | 
|  | 18 |  | 
|  | 19 | #ifndef CONFIG_SUN3 | 
|  | 20 | #define SHM_ID_SHIFT	9 | 
|  | 21 | #else | 
|  | 22 | #define SHM_ID_SHIFT	7 | 
|  | 23 | #endif | 
|  | 24 | #define _SHM_ID_BITS	7 | 
|  | 25 | #define SHM_ID_MASK	((1<<_SHM_ID_BITS)-1) | 
|  | 26 |  | 
|  | 27 | #define SHM_IDX_SHIFT	(SHM_ID_SHIFT+_SHM_ID_BITS) | 
|  | 28 | #define _SHM_IDX_BITS	15 | 
|  | 29 | #define SHM_IDX_MASK	((1<<_SHM_IDX_BITS)-1) | 
|  | 30 |  | 
|  | 31 | #endif /* _M68K_SHM_H */ |