Blame view

arch/s390/kernel/sys_s390.c 2.57 KB
b24413180   Greg Kroah-Hartman   License cleanup: ...
1
  // SPDX-License-Identifier: GPL-2.0
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2
  /*
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
3
   *  S390 version
a53c8fab3   Heiko Carstens   s390/comments: un...
4
   *    Copyright IBM Corp. 1999, 2000
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
5
6
7
8
9
10
11
12
13
14
15
16
17
   *    Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com),
   *               Thomas Spatzier (tspat@de.ibm.com)
   *
   *  Derived from "arch/i386/kernel/sys_i386.c"
   *
   *  This file contains various random system calls that
   *  have a non-standard calling sequence on the Linux/s390
   *  platform.
   */
  
  #include <linux/errno.h>
  #include <linux/sched.h>
  #include <linux/mm.h>
4e950f6f0   Alexey Dobriyan   Remove fs.h from ...
18
  #include <linux/fs.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
19
  #include <linux/smp.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
20
21
22
23
24
25
26
27
  #include <linux/sem.h>
  #include <linux/msg.h>
  #include <linux/shm.h>
  #include <linux/stat.h>
  #include <linux/syscalls.h>
  #include <linux/mman.h>
  #include <linux/file.h>
  #include <linux/utsname.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
28
  #include <linux/personality.h>
fe74290d5   Arnd Bergmann   [PATCH] provide k...
29
  #include <linux/unistd.h>
cba4fbbff   Adrian Bunk   remove include/as...
30
  #include <linux/ipc.h>
7c0f6ba68   Linus Torvalds   Replace <asm/uacc...
31
  #include <linux/uaccess.h>
a806170e2   Heiko Carstens   [S390] Fix a lot ...
32
  #include "entry.h"
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
33

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
34
  /*
a4679373c   Christoph Hellwig   Add generic sys_o...
35
36
37
   * Perform the mmap() system call. Linux for S/390 isn't able to handle more
   * than 5 system call parameters, so this system call uses a memory block
   * for parameter passing.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
38
   */
a4679373c   Christoph Hellwig   Add generic sys_o...
39
  struct s390_mmap_arg_struct {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
40
41
42
43
44
45
46
  	unsigned long addr;
  	unsigned long len;
  	unsigned long prot;
  	unsigned long flags;
  	unsigned long fd;
  	unsigned long offset;
  };
a4679373c   Christoph Hellwig   Add generic sys_o...
47
  SYSCALL_DEFINE1(mmap2, struct s390_mmap_arg_struct __user *, arg)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
48
  {
a4679373c   Christoph Hellwig   Add generic sys_o...
49
  	struct s390_mmap_arg_struct a;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
50
51
52
53
  	int error = -EFAULT;
  
  	if (copy_from_user(&a, arg, sizeof(a)))
  		goto out;
a90f590a1   Dominik Brodowski   mm: add ksys_mmap...
54
  	error = ksys_mmap_pgoff(a.addr, a.len, a.prot, a.flags, a.fd, a.offset);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
55
56
57
  out:
  	return error;
  }
58fa4a410   Arnd Bergmann   ipc: introduce ks...
58
  #ifdef CONFIG_SYSVIPC
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
59
  /*
3a3954cea   Heiko Carstens   [S390] ipc: call ...
60
   * sys_ipc() is the de-multiplexer for the SysV IPC calls.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
61
   */
baed7fc9b   Christoph Hellwig   Add generic sys_i...
62
  SYSCALL_DEFINE5(s390_ipc, uint, call, int, first, unsigned long, second,
26689452f   Heiko Carstens   [CVE-2009-0029] s...
63
  		unsigned long, third, void __user *, ptr)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
64
  {
3a3954cea   Heiko Carstens   [S390] ipc: call ...
65
66
67
68
69
70
71
72
73
74
  	if (call >> 16)
  		return -EINVAL;
  	/* The s390 sys_ipc variant has only five parameters instead of six
  	 * like the generic variant. The only difference is the handling of
  	 * the SEMTIMEDOP subcall where on s390 the third parameter is used
  	 * as a pointer to a struct timespec where the generic variant uses
  	 * the fifth parameter.
  	 * Therefore we can call the generic variant by simply passing the
  	 * third parameter also as fifth parameter.
  	 */
58fa4a410   Arnd Bergmann   ipc: introduce ks...
75
  	return ksys_ipc(call, first, second, third, ptr, third);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
76
  }
58fa4a410   Arnd Bergmann   ipc: introduce ks...
77
  #endif /* CONFIG_SYSVIPC */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
78

3a1103703   Heiko Carstens   [S390] sys_person...
79
  SYSCALL_DEFINE1(s390_personality, unsigned int, personality)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
80
  {
1ecff5ef0   Arnd Bergmann   s390: open-code s...
81
  	unsigned int ret = current->personality;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
82

5ab37e1b2   Jiri Kosina   s390: do not clob...
83
84
85
  	if (personality(current->personality) == PER_LINUX32 &&
  	    personality(personality) == PER_LINUX)
  		personality |= PER_LINUX32;
1ecff5ef0   Arnd Bergmann   s390: open-code s...
86
87
88
  
  	if (personality != 0xffffffff)
  		set_personality(personality);
5ab37e1b2   Jiri Kosina   s390: do not clob...
89
90
  	if (personality(ret) == PER_LINUX32)
  		ret &= ~PER_LINUX32;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
91
92
93
  
  	return ret;
  }
aa0d6e70d   Arnd Bergmann   s390: autogenerat...
94
95
96
97
98
  
  SYSCALL_DEFINE0(ni_syscall)
  {
  	return -ENOSYS;
  }