1 | /* |
2 | * Physical memory access templates |
3 | * |
4 | * Copyright (c) 2003 Fabrice Bellard |
5 | * Copyright (c) 2015 Linaro, Inc. |
6 | * Copyright (c) 2016 Red Hat, Inc. |
7 | * |
8 | * This library is free software; you can redistribute it and/or |
9 | * modify it under the terms of the GNU Lesser General Public |
10 | * License as published by the Free Software Foundation; either |
11 | * version 2 of the License, or (at your option) any later version. |
12 | * |
13 | * This library is distributed in the hope that it will be useful, |
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
16 | * Lesser General Public License for more details. |
17 | * |
18 | * You should have received a copy of the GNU Lesser General Public |
19 | * License along with this library; if not, see <http://www.gnu.org/licenses/>. |
20 | */ |
21 | |
22 | #ifdef TARGET_ENDIANNESS |
23 | static inline uint32_t glue(ldl_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
24 | { |
25 | return glue(address_space_ldl, SUFFIX)(ARG1, addr, |
26 | MEMTXATTRS_UNSPECIFIED, NULL); |
27 | } |
28 | |
29 | static inline uint64_t glue(ldq_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
30 | { |
31 | return glue(address_space_ldq, SUFFIX)(ARG1, addr, |
32 | MEMTXATTRS_UNSPECIFIED, NULL); |
33 | } |
34 | |
35 | static inline uint32_t glue(lduw_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
36 | { |
37 | return glue(address_space_lduw, SUFFIX)(ARG1, addr, |
38 | MEMTXATTRS_UNSPECIFIED, NULL); |
39 | } |
40 | |
41 | static inline void glue(stl_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint32_t val) |
42 | { |
43 | glue(address_space_stl, SUFFIX)(ARG1, addr, val, |
44 | MEMTXATTRS_UNSPECIFIED, NULL); |
45 | } |
46 | |
47 | static inline void glue(stw_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint32_t val) |
48 | { |
49 | glue(address_space_stw, SUFFIX)(ARG1, addr, val, |
50 | MEMTXATTRS_UNSPECIFIED, NULL); |
51 | } |
52 | |
53 | static inline void glue(stq_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint64_t val) |
54 | { |
55 | glue(address_space_stq, SUFFIX)(ARG1, addr, val, |
56 | MEMTXATTRS_UNSPECIFIED, NULL); |
57 | } |
58 | #else |
59 | static inline uint32_t glue(ldl_le_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
60 | { |
61 | return glue(address_space_ldl_le, SUFFIX)(ARG1, addr, |
62 | MEMTXATTRS_UNSPECIFIED, NULL); |
63 | } |
64 | |
65 | static inline uint32_t glue(ldl_be_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
66 | { |
67 | return glue(address_space_ldl_be, SUFFIX)(ARG1, addr, |
68 | MEMTXATTRS_UNSPECIFIED, NULL); |
69 | } |
70 | |
71 | static inline uint64_t glue(ldq_le_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
72 | { |
73 | return glue(address_space_ldq_le, SUFFIX)(ARG1, addr, |
74 | MEMTXATTRS_UNSPECIFIED, NULL); |
75 | } |
76 | |
77 | static inline uint64_t glue(ldq_be_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
78 | { |
79 | return glue(address_space_ldq_be, SUFFIX)(ARG1, addr, |
80 | MEMTXATTRS_UNSPECIFIED, NULL); |
81 | } |
82 | |
83 | static inline uint32_t glue(ldub_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
84 | { |
85 | return glue(address_space_ldub, SUFFIX)(ARG1, addr, |
86 | MEMTXATTRS_UNSPECIFIED, NULL); |
87 | } |
88 | |
89 | static inline uint32_t glue(lduw_le_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
90 | { |
91 | return glue(address_space_lduw_le, SUFFIX)(ARG1, addr, |
92 | MEMTXATTRS_UNSPECIFIED, NULL); |
93 | } |
94 | |
95 | static inline uint32_t glue(lduw_be_phys, SUFFIX)(ARG1_DECL, hwaddr addr) |
96 | { |
97 | return glue(address_space_lduw_be, SUFFIX)(ARG1, addr, |
98 | MEMTXATTRS_UNSPECIFIED, NULL); |
99 | } |
100 | |
101 | static inline void glue(stl_le_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint32_t val) |
102 | { |
103 | glue(address_space_stl_le, SUFFIX)(ARG1, addr, val, |
104 | MEMTXATTRS_UNSPECIFIED, NULL); |
105 | } |
106 | |
107 | static inline void glue(stl_be_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint32_t val) |
108 | { |
109 | glue(address_space_stl_be, SUFFIX)(ARG1, addr, val, |
110 | MEMTXATTRS_UNSPECIFIED, NULL); |
111 | } |
112 | |
113 | static inline void glue(stb_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint32_t val) |
114 | { |
115 | glue(address_space_stb, SUFFIX)(ARG1, addr, val, |
116 | MEMTXATTRS_UNSPECIFIED, NULL); |
117 | } |
118 | |
119 | static inline void glue(stw_le_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint32_t val) |
120 | { |
121 | glue(address_space_stw_le, SUFFIX)(ARG1, addr, val, |
122 | MEMTXATTRS_UNSPECIFIED, NULL); |
123 | } |
124 | |
125 | static inline void glue(stw_be_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint32_t val) |
126 | { |
127 | glue(address_space_stw_be, SUFFIX)(ARG1, addr, val, |
128 | MEMTXATTRS_UNSPECIFIED, NULL); |
129 | } |
130 | |
131 | static inline void glue(stq_le_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint64_t val) |
132 | { |
133 | glue(address_space_stq_le, SUFFIX)(ARG1, addr, val, |
134 | MEMTXATTRS_UNSPECIFIED, NULL); |
135 | } |
136 | |
137 | static inline void glue(stq_be_phys, SUFFIX)(ARG1_DECL, hwaddr addr, uint64_t val) |
138 | { |
139 | glue(address_space_stq_be, SUFFIX)(ARG1, addr, val, |
140 | MEMTXATTRS_UNSPECIFIED, NULL); |
141 | } |
142 | #endif |
143 | |
144 | #undef ARG1_DECL |
145 | #undef ARG1 |
146 | #undef SUFFIX |
147 | #undef TARGET_ENDIANNESS |
148 | |