| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #include <linux/kernel.h> | 
 | 2 | #include <linux/spinlock.h> | 
 | 3 | #include <linux/list.h> | 
 | 4 | #include <linux/syscalls.h> | 
 | 5 | #include <linux/time.h> | 
 | 6 | #include <linux/sem.h> | 
 | 7 | #include <linux/msg.h> | 
 | 8 | #include <linux/shm.h> | 
 | 9 | #include <linux/ipc.h> | 
 | 10 | #include <linux/compat.h> | 
 | 11 |  | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 12 | asmlinkage long sys32_ipc(u32 call, int first, int second, int third, | 
 | 13 | 			  compat_uptr_t ptr, u32 fifth) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | { | 
 | 15 | 	int version; | 
 | 16 |  | 
 | 17 | 	version = call >> 16; /* hack for backward compatibility */ | 
 | 18 | 	call &= 0xffff; | 
 | 19 |  | 
 | 20 | 	switch (call) { | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 21 | 	case SEMOP: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 22 | 		/* struct sembuf is the same on 32 and 64bit :)) */ | 
 | 23 | 		return sys_semtimedop(first, compat_ptr(ptr), second, NULL); | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 24 | 	case SEMTIMEDOP: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 25 | 		return compat_sys_semtimedop(first, compat_ptr(ptr), second, | 
 | 26 | 						compat_ptr(fifth)); | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 27 | 	case SEMGET: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 28 | 		return sys_semget(first, second, third); | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 29 | 	case SEMCTL: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 30 | 		return compat_sys_semctl(first, second, third, compat_ptr(ptr)); | 
 | 31 |  | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 32 | 	case MSGSND: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 33 | 		return compat_sys_msgsnd(first, second, third, compat_ptr(ptr)); | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 34 | 	case MSGRCV: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 35 | 		return compat_sys_msgrcv(first, second, fifth, third, | 
 | 36 | 					 version, compat_ptr(ptr)); | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 37 | 	case MSGGET: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 38 | 		return sys_msgget((key_t) first, second); | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 39 | 	case MSGCTL: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 40 | 		return compat_sys_msgctl(first, second, compat_ptr(ptr)); | 
 | 41 |  | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 42 | 	case SHMAT: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 43 | 		return compat_sys_shmat(first, second, third, version, | 
 | 44 | 					compat_ptr(ptr)); | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 45 | 	case SHMDT: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 46 | 		return sys_shmdt(compat_ptr(ptr)); | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 47 | 	case SHMGET: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 48 | 		return sys_shmget(first, (unsigned)second, third); | 
| Thomas Gleixner | 2da06b4 | 2008-01-30 13:30:08 +0100 | [diff] [blame] | 49 | 	case SHMCTL: | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 50 | 		return compat_sys_shmctl(first, second, compat_ptr(ptr)); | 
 | 51 | 	} | 
 | 52 | 	return -ENOSYS; | 
 | 53 | } |