753713fffe2104ec89d7d719f3391f9261253c8c
[mes.git] / lib / linux / gnu.c
1 /* -*-comment-start: "//";comment-end:""-*-
2  * GNU Mes --- Maxwell Equations of Software
3  * Copyright © 2018 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
4  *
5  * This file is part of GNU Mes.
6  *
7  * GNU Mes is free software; you can redistribute it and/or modify it
8  * under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 3 of the License, or (at
10  * your option) any later version.
11  *
12  * GNU Mes is distributed in the hope that it will be useful, but
13  * WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with GNU Mes.  If not, see <http://www.gnu.org/licenses/>.
19  */
20
21 #include <sys/resource.h>
22 #include <time.h>
23
24 int
25 link (char const *old_name, char const *new_name)
26 {
27   return _sys_call2 (SYS_link, (long)old_name, (long)new_name);
28 }
29
30 pid_t
31 getpid ()
32 {
33   return _sys_call (SYS_getpid);
34 }
35
36 uid_t
37 getuid ()
38 {
39   return _sys_call (SYS_getuid);
40 }
41
42 int
43 kill (pid_t pid, int signum)
44 {
45   return _sys_call2 (SYS_kill, (long)pid, (long)signum);
46 }
47
48 int
49 rename (char const *old_name, char const *new_name)
50 {
51   return _sys_call2 (SYS_rename, (long)old_name, (long)new_name);
52 }
53
54 int
55 mkdir (char const *file_name, mode_t mode)
56 {
57   return _sys_call2 (SYS_mkdir, (long)file_name, (long)mode);
58 }
59
60 int
61 dup (int old)
62 {
63   return _sys_call1 (SYS_dup, (int)old);
64 }
65
66 gid_t
67 getgid ()
68 {
69   return _sys_call (SYS_getgid);
70 }
71
72 // long _sys_call (long sys_call);
73 // long _sys_call4 (long sys_call, long one, long two, long three, long four);
74
75 #define SA_SIGINFO 4
76 #define SA_RESTORER 0x04000000
77
78 #define SYS_rt_sigreturn 15
79
80 void
81 _restorer (void)
82 {
83   _sys_call (SYS_rt_sigreturn);
84 }
85
86 # define __sigmask(sig) \
87   (((unsigned long int) 1) << (((sig) - 1) % (8 * sizeof (unsigned long int))))
88
89 sighandler_t
90 signal (int signum, sighandler_t action)
91 {
92 #if __i386__
93   return _sys_call2 (SYS_signal, signum, action);
94 #else
95   static struct sigaction setup_action = {-1};
96   static struct sigaction old = {0};
97
98   setup_action.sa_handler = action;
99   setup_action.sa_restorer = _restorer;
100   setup_action.sa_mask = __sigmask (signum);
101   old.sa_handler = SIG_DFL;
102   setup_action.sa_flags = SA_RESTORER | SA_RESTART;
103   int r = _sys_call4 (SYS_rt_sigaction, signum, &setup_action, &old, sizeof (sigset_t));
104   if (r)
105     return 0;
106   return old.sa_handler;
107 #endif
108 }
109
110 int
111 fcntl (int filedes, int command, ...)
112 {
113   va_list ap;
114   va_start (ap, command);
115   int data = va_arg (ap, int);
116   int r = _sys_call3 (SYS_fcntl, (int)filedes, (int)command, (int)data);
117   va_end (ap);
118   return r;
119 }
120
121 int
122 pipe (int filedes[2])
123 {
124   return _sys_call1 (SYS_pipe, (long)filedes);
125 }
126
127 int
128 dup2 (int old, int new)
129 {
130   return _sys_call2 (SYS_dup2, (int)old, (int)new);
131 }
132
133 int
134 getrusage (int processes, struct rusage *rusage)
135 {
136   return _sys_call2 (SYS_getrusage, (int)processes, (long)rusage);
137 }
138
139 int
140 lstat (char const *file_name, struct stat *statbuf)
141 {
142   return _sys_call2 (SYS_lstat, (long)file_name, (long)statbuf);
143 }
144
145 int
146 nanosleep (const struct timespec *requested_time,
147            struct timespec *remaining)
148 {
149   return _sys_call2 (SYS_nanosleep, (long)requested_time, (long)remaining);
150 }
151
152 int
153 setitimer (int which, struct itimerval const *new,
154           struct itimerval *old)
155 {
156   return _sys_call3 (SYS_setitimer, (long)which, (long)new, (long)old);
157 }
158
159 int
160 fstat (int filedes, struct stat *statbuf)
161 {
162   return _sys_call2 (SYS_fstat, (int)filedes, (long)statbuf);
163 }
164
165 int
166 getdents (int filedes, char *buffer, size_t nbytes)
167 {
168   return _sys_call3 (SYS_getdents, (int)filedes, (long)buffer, (long)nbytes);
169 }
170
171 int
172 chdir (char const *file_name)
173 {
174   return _sys_call1 (SYS_chdir, (long)file_name);
175 }
176
177 // bash
178 uid_t
179 geteuid ()
180 {
181   return _sys_call (SYS_geteuid);
182 }
183
184 gid_t
185 getegid ()
186 {
187   return _sys_call (SYS_getegid);
188 }
189
190 int
191 setuid (uid_t newuid)
192 {
193   return _sys_call1 (SYS_setuid, (long)newuid);
194 }
195
196 int
197 setgid (gid_t newgid)
198 {
199   return _sys_call1 (SYS_setgid, (long)newgid);
200 }
201
202 // make+POSIX
203 int
204 sigprocmask (int how, sigset_t const *set, sigset_t *oldset)
205 {
206 #if __i386__
207   return _sys_call3 (SYS_sigprocmask, (long)how, (long)set, (long)oldset);
208 #else
209   return _sys_call3 (SYS_rt_sigprocmask, (long)how, (long)set, (long)oldset);
210 #endif
211 }