xref: /openbmc/qemu/bsd-user/i386/target_arch_sysarch.h (revision ec11dc41eec5142b4776db1296972c6323ba5847)
1ea1ab4cfSStacey Son /*
2ea1ab4cfSStacey Son  *  i386 sysarch system call emulation
3ea1ab4cfSStacey Son  *
4ea1ab4cfSStacey Son  *  Copyright (c) 2013 Stacey D. Son
5ea1ab4cfSStacey Son  *
6ea1ab4cfSStacey Son  *  This program is free software; you can redistribute it and/or modify
7ea1ab4cfSStacey Son  *  it under the terms of the GNU General Public License as published by
8ea1ab4cfSStacey Son  *  the Free Software Foundation; either version 2 of the License, or
9ea1ab4cfSStacey Son  *  (at your option) any later version.
10ea1ab4cfSStacey Son  *
11ea1ab4cfSStacey Son  *  This program is distributed in the hope that it will be useful,
12ea1ab4cfSStacey Son  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13ea1ab4cfSStacey Son  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14ea1ab4cfSStacey Son  *  GNU General Public License for more details.
15ea1ab4cfSStacey Son  *
16ea1ab4cfSStacey Son  *  You should have received a copy of the GNU General Public License
17ea1ab4cfSStacey Son  *  along with this program; if not, see <http://www.gnu.org/licenses/>.
18ea1ab4cfSStacey Son  */
19ea1ab4cfSStacey Son 
20*52581c71SMarkus Armbruster #ifndef TARGET_ARCH_SYSARCH_H
21*52581c71SMarkus Armbruster #define TARGET_ARCH_SYSARCH_H
22ea1ab4cfSStacey Son 
23ea1ab4cfSStacey Son #include "target_syscall.h"
24ea1ab4cfSStacey Son 
do_freebsd_arch_sysarch(CPUX86State * env,int op,abi_ulong parms)25ea1ab4cfSStacey Son static inline abi_long do_freebsd_arch_sysarch(CPUX86State *env, int op,
26ea1ab4cfSStacey Son         abi_ulong parms)
27ea1ab4cfSStacey Son {
28ea1ab4cfSStacey Son     abi_long ret = 0;
29ea1ab4cfSStacey Son     abi_ulong val;
30ea1ab4cfSStacey Son     int idx;
31ea1ab4cfSStacey Son 
32ea1ab4cfSStacey Son     switch (op) {
33ea1ab4cfSStacey Son     case TARGET_FREEBSD_I386_SET_GSBASE:
34ea1ab4cfSStacey Son     case TARGET_FREEBSD_I386_SET_FSBASE:
35ea1ab4cfSStacey Son         if (op == TARGET_FREEBSD_I386_SET_GSBASE) {
36ea1ab4cfSStacey Son             idx = R_GS;
37ea1ab4cfSStacey Son         } else {
38ea1ab4cfSStacey Son             idx = R_FS;
39ea1ab4cfSStacey Son         }
40ea1ab4cfSStacey Son         if (get_user(val, parms, abi_ulong)) {
41ea1ab4cfSStacey Son             return -TARGET_EFAULT;
42ea1ab4cfSStacey Son         }
43ea1ab4cfSStacey Son         cpu_x86_load_seg(env, idx, 0);
44ea1ab4cfSStacey Son         env->segs[idx].base = val;
45ea1ab4cfSStacey Son         break;
46ea1ab4cfSStacey Son 
47ea1ab4cfSStacey Son     case TARGET_FREEBSD_I386_GET_GSBASE:
48ea1ab4cfSStacey Son     case TARGET_FREEBSD_I386_GET_FSBASE:
49ea1ab4cfSStacey Son         if (op == TARGET_FREEBSD_I386_GET_GSBASE) {
50ea1ab4cfSStacey Son             idx = R_GS;
51ea1ab4cfSStacey Son         } else {
52ea1ab4cfSStacey Son             idx = R_FS;
53ea1ab4cfSStacey Son         }
54ea1ab4cfSStacey Son         val = env->segs[idx].base;
55ea1ab4cfSStacey Son         if (put_user(val, parms, abi_ulong)) {
56ea1ab4cfSStacey Son             return -TARGET_EFAULT;
57ea1ab4cfSStacey Son         }
58ea1ab4cfSStacey Son         break;
59ea1ab4cfSStacey Son 
60ea1ab4cfSStacey Son     /* XXX handle the others... */
61ea1ab4cfSStacey Son     default:
62ea1ab4cfSStacey Son         ret = -TARGET_EINVAL;
63ea1ab4cfSStacey Son         break;
64ea1ab4cfSStacey Son     }
65ea1ab4cfSStacey Son     return ret;
66ea1ab4cfSStacey Son }
67ea1ab4cfSStacey Son 
do_freebsd_arch_print_sysarch(const struct syscallname * name,abi_long arg1,abi_long arg2,abi_long arg3,abi_long arg4,abi_long arg5,abi_long arg6)68ea1ab4cfSStacey Son static inline void do_freebsd_arch_print_sysarch(
69ea1ab4cfSStacey Son         const struct syscallname *name, abi_long arg1, abi_long arg2,
70ea1ab4cfSStacey Son         abi_long arg3, abi_long arg4, abi_long arg5, abi_long arg6)
71ea1ab4cfSStacey Son {
72ea1ab4cfSStacey Son 
73ea1ab4cfSStacey Son     gemu_log("%s(%d, " TARGET_ABI_FMT_lx ", " TARGET_ABI_FMT_lx ", "
74ea1ab4cfSStacey Son         TARGET_ABI_FMT_lx ")", name->name, (int)arg1, arg2, arg3, arg4);
75ea1ab4cfSStacey Son }
76ea1ab4cfSStacey Son 
77*52581c71SMarkus Armbruster #endif /* TARGET_ARCH_SYSARCH_H */
78