replay: interrupts and exceptions
[qemu/ar7.git] / include / exec / cpu_ldst_useronly_template.h
blob040b147437510d25b31174345465ae1cb6fd881a
1 /*
2 * User-only accessor function support
4 * Generate inline load/store functions for one data size.
6 * Generate a store function as well as signed and unsigned loads.
8 * Not used directly but included from cpu_ldst.h.
10 * Copyright (c) 2015 Linaro Limited
12 * This library is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU Lesser General Public
14 * License as published by the Free Software Foundation; either
15 * version 2 of the License, or (at your option) any later version.
17 * This library is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 * Lesser General Public License for more details.
22 * You should have received a copy of the GNU Lesser General Public
23 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
25 #if DATA_SIZE == 8
26 #define SUFFIX q
27 #define USUFFIX q
28 #define DATA_TYPE uint64_t
29 #elif DATA_SIZE == 4
30 #define SUFFIX l
31 #define USUFFIX l
32 #define DATA_TYPE uint32_t
33 #elif DATA_SIZE == 2
34 #define SUFFIX w
35 #define USUFFIX uw
36 #define DATA_TYPE uint16_t
37 #define DATA_STYPE int16_t
38 #elif DATA_SIZE == 1
39 #define SUFFIX b
40 #define USUFFIX ub
41 #define DATA_TYPE uint8_t
42 #define DATA_STYPE int8_t
43 #else
44 #error unsupported data size
45 #endif
47 #if DATA_SIZE == 8
48 #define RES_TYPE uint64_t
49 #else
50 #define RES_TYPE uint32_t
51 #endif
53 static inline RES_TYPE
54 glue(glue(cpu_ld, USUFFIX), MEMSUFFIX)(CPUArchState *env, target_ulong ptr)
56 return glue(glue(ld, USUFFIX), _p)(g2h(ptr));
59 static inline RES_TYPE
60 glue(glue(glue(cpu_ld, USUFFIX), MEMSUFFIX), _ra)(CPUArchState *env,
61 target_ulong ptr,
62 uintptr_t retaddr)
64 return glue(glue(cpu_ld, USUFFIX), MEMSUFFIX)(env, ptr);
67 #if DATA_SIZE <= 2
68 static inline int
69 glue(glue(cpu_lds, SUFFIX), MEMSUFFIX)(CPUArchState *env, target_ulong ptr)
71 return glue(glue(lds, SUFFIX), _p)(g2h(ptr));
74 static inline int
75 glue(glue(glue(cpu_lds, SUFFIX), MEMSUFFIX), _ra)(CPUArchState *env,
76 target_ulong ptr,
77 uintptr_t retaddr)
79 return glue(glue(cpu_lds, SUFFIX), MEMSUFFIX)(env, ptr);
81 #endif
83 #ifndef CODE_ACCESS
84 static inline void
85 glue(glue(cpu_st, SUFFIX), MEMSUFFIX)(CPUArchState *env, target_ulong ptr,
86 RES_TYPE v)
88 glue(glue(st, SUFFIX), _p)(g2h(ptr), v);
91 static inline void
92 glue(glue(glue(cpu_st, SUFFIX), MEMSUFFIX), _ra)(CPUArchState *env,
93 target_ulong ptr,
94 RES_TYPE v,
95 uintptr_t retaddr)
97 glue(glue(cpu_st, SUFFIX), MEMSUFFIX)(env, ptr, v);
99 #endif
101 #undef RES_TYPE
102 #undef DATA_TYPE
103 #undef DATA_STYPE
104 #undef SUFFIX
105 #undef USUFFIX
106 #undef DATA_SIZE