1ea1ab4cfSStacey Son /*
2ea1ab4cfSStacey Son  *  arm 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*9c092804SMarkus Armbruster #ifndef TARGET_ARCH_SYSARCH_H
21*9c092804SMarkus Armbruster #define TARGET_ARCH_SYSARCH_H
22ea1ab4cfSStacey Son 
23ea1ab4cfSStacey Son #include "target_syscall.h"
24ea1ab4cfSStacey Son #include "target_arch.h"
25ea1ab4cfSStacey Son 
do_freebsd_arch_sysarch(CPUARMState * env,int op,abi_ulong parms)26ea1ab4cfSStacey Son static inline abi_long do_freebsd_arch_sysarch(CPUARMState *env, int op,
27ea1ab4cfSStacey Son         abi_ulong parms)
28ea1ab4cfSStacey Son {
29ea1ab4cfSStacey Son     int ret = 0;
30ea1ab4cfSStacey Son 
31ea1ab4cfSStacey Son     switch (op) {
32ea1ab4cfSStacey Son     case TARGET_FREEBSD_ARM_SYNC_ICACHE:
33ea1ab4cfSStacey Son     case TARGET_FREEBSD_ARM_DRAIN_WRITEBUF:
34ea1ab4cfSStacey Son         break;
35ea1ab4cfSStacey Son 
36ea1ab4cfSStacey Son     case TARGET_FREEBSD_ARM_SET_TP:
37ea1ab4cfSStacey Son         target_cpu_set_tls(env, parms);
38ea1ab4cfSStacey Son         break;
39ea1ab4cfSStacey Son 
40ea1ab4cfSStacey Son     case TARGET_FREEBSD_ARM_GET_TP:
41ea1ab4cfSStacey Son         ret = target_cpu_get_tls(env);
42ea1ab4cfSStacey Son         break;
43ea1ab4cfSStacey Son 
44ea1ab4cfSStacey Son     default:
45ea1ab4cfSStacey Son         ret = -TARGET_EINVAL;
46ea1ab4cfSStacey Son         break;
47ea1ab4cfSStacey Son     }
48ea1ab4cfSStacey Son     return ret;
49ea1ab4cfSStacey Son }
50ea1ab4cfSStacey 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)51ea1ab4cfSStacey Son static inline void do_freebsd_arch_print_sysarch(
52ea1ab4cfSStacey Son         const struct syscallname *name, abi_long arg1, abi_long arg2,
53ea1ab4cfSStacey Son         abi_long arg3, abi_long arg4, abi_long arg5, abi_long arg6)
54ea1ab4cfSStacey Son {
55ea1ab4cfSStacey Son 
56ea1ab4cfSStacey Son     switch (arg1) {
57ea1ab4cfSStacey Son     case TARGET_FREEBSD_ARM_SYNC_ICACHE:
58ea1ab4cfSStacey Son         gemu_log("%s(ARM_SYNC_ICACHE, ...)", name->name);
59ea1ab4cfSStacey Son         break;
60ea1ab4cfSStacey Son 
61ea1ab4cfSStacey Son     case TARGET_FREEBSD_ARM_DRAIN_WRITEBUF:
62ea1ab4cfSStacey Son         gemu_log("%s(ARM_DRAIN_WRITEBUF, ...)", name->name);
63ea1ab4cfSStacey Son         break;
64ea1ab4cfSStacey Son 
65ea1ab4cfSStacey Son     case TARGET_FREEBSD_ARM_SET_TP:
66ea1ab4cfSStacey Son         gemu_log("%s(ARM_SET_TP, 0x" TARGET_ABI_FMT_lx ")", name->name, arg2);
67ea1ab4cfSStacey Son         break;
68ea1ab4cfSStacey Son 
69ea1ab4cfSStacey Son     case TARGET_FREEBSD_ARM_GET_TP:
70ea1ab4cfSStacey Son         gemu_log("%s(ARM_GET_TP, 0x" TARGET_ABI_FMT_lx ")", name->name, arg2);
71ea1ab4cfSStacey Son         break;
72ea1ab4cfSStacey Son 
73ea1ab4cfSStacey Son     default:
74ea1ab4cfSStacey Son         gemu_log("UNKNOWN OP: %d, " TARGET_ABI_FMT_lx ")", (int)arg1, arg2);
75ea1ab4cfSStacey Son     }
76ea1ab4cfSStacey Son }
77ea1ab4cfSStacey Son 
78*9c092804SMarkus Armbruster #endif /* TARGET_ARCH_SYSARCH_H */
79