xref: /qemu/os-wasm.c (revision c5f122fdcc280a82e7c5f31de890f985aa7ba773)
1*0f46bf65SKohei Tokunaga /* SPDX-License-Identifier: MIT */
2*0f46bf65SKohei Tokunaga /*
3*0f46bf65SKohei Tokunaga  * os-wasm.c
4*0f46bf65SKohei Tokunaga  * Forked from os-posix.c, removing functions not working on Emscripten
5*0f46bf65SKohei Tokunaga  *
6*0f46bf65SKohei Tokunaga  * Copyright (c) 2003-2008 Fabrice Bellard
7*0f46bf65SKohei Tokunaga  * Copyright (c) 2010 Red Hat, Inc.
8*0f46bf65SKohei Tokunaga  *
9*0f46bf65SKohei Tokunaga  * Permission is hereby granted, free of charge, to any person obtaining a copy
10*0f46bf65SKohei Tokunaga  * of this software and associated documentation files (the "Software"), to deal
11*0f46bf65SKohei Tokunaga  * in the Software without restriction, including without limitation the rights
12*0f46bf65SKohei Tokunaga  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
13*0f46bf65SKohei Tokunaga  * copies of the Software, and to permit persons to whom the Software is
14*0f46bf65SKohei Tokunaga  * furnished to do so, subject to the following conditions:
15*0f46bf65SKohei Tokunaga  *
16*0f46bf65SKohei Tokunaga  * The above copyright notice and this permission notice shall be included in
17*0f46bf65SKohei Tokunaga  * all copies or substantial portions of the Software.
18*0f46bf65SKohei Tokunaga  *
19*0f46bf65SKohei Tokunaga  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20*0f46bf65SKohei Tokunaga  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21*0f46bf65SKohei Tokunaga  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
22*0f46bf65SKohei Tokunaga  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23*0f46bf65SKohei Tokunaga  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24*0f46bf65SKohei Tokunaga  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25*0f46bf65SKohei Tokunaga  * THE SOFTWARE.
26*0f46bf65SKohei Tokunaga  */
27*0f46bf65SKohei Tokunaga 
28*0f46bf65SKohei Tokunaga #include "qemu/osdep.h"
29*0f46bf65SKohei Tokunaga #include <sys/resource.h>
30*0f46bf65SKohei Tokunaga #include <sys/wait.h>
31*0f46bf65SKohei Tokunaga #include <pwd.h>
32*0f46bf65SKohei Tokunaga #include <grp.h>
33*0f46bf65SKohei Tokunaga #include <libgen.h>
34*0f46bf65SKohei Tokunaga 
35*0f46bf65SKohei Tokunaga #include "qemu/error-report.h"
36*0f46bf65SKohei Tokunaga #include "qemu/log.h"
37*0f46bf65SKohei Tokunaga #include "system/runstate.h"
38*0f46bf65SKohei Tokunaga #include "qemu/cutils.h"
39*0f46bf65SKohei Tokunaga 
os_setup_post(void)40*0f46bf65SKohei Tokunaga void os_setup_post(void){}
os_set_line_buffering(void)41*0f46bf65SKohei Tokunaga void os_set_line_buffering(void)
42*0f46bf65SKohei Tokunaga {
43*0f46bf65SKohei Tokunaga     setvbuf(stdout, NULL, _IOLBF, 0);
44*0f46bf65SKohei Tokunaga }
os_setup_early_signal_handling(void)45*0f46bf65SKohei Tokunaga void os_setup_early_signal_handling(void)
46*0f46bf65SKohei Tokunaga {
47*0f46bf65SKohei Tokunaga     struct sigaction act;
48*0f46bf65SKohei Tokunaga     sigfillset(&act.sa_mask);
49*0f46bf65SKohei Tokunaga     act.sa_flags = 0;
50*0f46bf65SKohei Tokunaga     act.sa_handler = SIG_IGN;
51*0f46bf65SKohei Tokunaga     sigaction(SIGPIPE, &act, NULL);
52*0f46bf65SKohei Tokunaga }
os_set_proc_name(const char * s)53*0f46bf65SKohei Tokunaga void os_set_proc_name(const char *s)
54*0f46bf65SKohei Tokunaga {
55*0f46bf65SKohei Tokunaga     error_report("Change of process name not supported by your OS");
56*0f46bf65SKohei Tokunaga     exit(1);
57*0f46bf65SKohei Tokunaga }
termsig_handler(int signal,siginfo_t * info,void * c)58*0f46bf65SKohei Tokunaga static void termsig_handler(int signal, siginfo_t *info, void *c)
59*0f46bf65SKohei Tokunaga {
60*0f46bf65SKohei Tokunaga     qemu_system_killed(info->si_signo, info->si_pid);
61*0f46bf65SKohei Tokunaga }
62*0f46bf65SKohei Tokunaga 
os_setup_signal_handling(void)63*0f46bf65SKohei Tokunaga void os_setup_signal_handling(void)
64*0f46bf65SKohei Tokunaga {
65*0f46bf65SKohei Tokunaga     struct sigaction act;
66*0f46bf65SKohei Tokunaga 
67*0f46bf65SKohei Tokunaga     memset(&act, 0, sizeof(act));
68*0f46bf65SKohei Tokunaga     act.sa_sigaction = termsig_handler;
69*0f46bf65SKohei Tokunaga     act.sa_flags = SA_SIGINFO;
70*0f46bf65SKohei Tokunaga     sigaction(SIGINT,  &act, NULL);
71*0f46bf65SKohei Tokunaga     sigaction(SIGHUP,  &act, NULL);
72*0f46bf65SKohei Tokunaga     sigaction(SIGTERM, &act, NULL);
73*0f46bf65SKohei Tokunaga }
os_setup_limits(void)74*0f46bf65SKohei Tokunaga void os_setup_limits(void)
75*0f46bf65SKohei Tokunaga {
76*0f46bf65SKohei Tokunaga     struct rlimit nofile;
77*0f46bf65SKohei Tokunaga 
78*0f46bf65SKohei Tokunaga     if (getrlimit(RLIMIT_NOFILE, &nofile) < 0) {
79*0f46bf65SKohei Tokunaga         warn_report("unable to query NOFILE limit: %s", strerror(errno));
80*0f46bf65SKohei Tokunaga         return;
81*0f46bf65SKohei Tokunaga     }
82*0f46bf65SKohei Tokunaga 
83*0f46bf65SKohei Tokunaga     if (nofile.rlim_cur == nofile.rlim_max) {
84*0f46bf65SKohei Tokunaga         return;
85*0f46bf65SKohei Tokunaga     }
86*0f46bf65SKohei Tokunaga 
87*0f46bf65SKohei Tokunaga     nofile.rlim_cur = nofile.rlim_max;
88*0f46bf65SKohei Tokunaga 
89*0f46bf65SKohei Tokunaga     if (setrlimit(RLIMIT_NOFILE, &nofile) < 0) {
90*0f46bf65SKohei Tokunaga         warn_report("unable to set NOFILE limit: %s", strerror(errno));
91*0f46bf65SKohei Tokunaga         return;
92*0f46bf65SKohei Tokunaga     }
93*0f46bf65SKohei Tokunaga }
os_mlock(bool on_fault)94*0f46bf65SKohei Tokunaga int os_mlock(bool on_fault)
95*0f46bf65SKohei Tokunaga {
96*0f46bf65SKohei Tokunaga #ifdef HAVE_MLOCKALL
97*0f46bf65SKohei Tokunaga     int ret = 0;
98*0f46bf65SKohei Tokunaga     int flags = MCL_CURRENT | MCL_FUTURE;
99*0f46bf65SKohei Tokunaga 
100*0f46bf65SKohei Tokunaga     if (on_fault) {
101*0f46bf65SKohei Tokunaga #ifdef HAVE_MLOCK_ONFAULT
102*0f46bf65SKohei Tokunaga         flags |= MCL_ONFAULT;
103*0f46bf65SKohei Tokunaga #else
104*0f46bf65SKohei Tokunaga         error_report("mlockall: on_fault not supported");
105*0f46bf65SKohei Tokunaga         return -EINVAL;
106*0f46bf65SKohei Tokunaga #endif
107*0f46bf65SKohei Tokunaga     }
108*0f46bf65SKohei Tokunaga 
109*0f46bf65SKohei Tokunaga     ret = mlockall(flags);
110*0f46bf65SKohei Tokunaga     if (ret < 0) {
111*0f46bf65SKohei Tokunaga         error_report("mlockall: %s", strerror(errno));
112*0f46bf65SKohei Tokunaga     }
113*0f46bf65SKohei Tokunaga 
114*0f46bf65SKohei Tokunaga     return ret;
115*0f46bf65SKohei Tokunaga #else
116*0f46bf65SKohei Tokunaga     (void)on_fault;
117*0f46bf65SKohei Tokunaga     return -ENOSYS;
118*0f46bf65SKohei Tokunaga #endif
119*0f46bf65SKohei Tokunaga }
120