blob: 28d1d53d61e29e9ff628db5e763c53511f75157c [file] [log] [blame]
bellarda9049a02005-10-30 18:16:26 +00001/* Common softmmu definitions and inline routines. */
2
j_mayer6ebbf392007-10-14 07:07:08 +00003/* XXX: find something cleaner.
4 * Furthermore, this is false for 64 bits targets
5 */
6#define ldul_user ldl_user
7#define ldul_kernel ldl_kernel
8#define ldul_hypv ldl_hypv
9#define ldul_executive ldl_executive
10#define ldul_supervisor ldl_supervisor
bellarda9049a02005-10-30 18:16:26 +000011
blueswir179383c92008-08-30 09:51:20 +000012#include "softmmu_defs.h"
13
bellarda9049a02005-10-30 18:16:26 +000014#define ACCESS_TYPE 0
j_mayer6ebbf392007-10-14 07:07:08 +000015#define MEMSUFFIX MMU_MODE0_SUFFIX
bellarda9049a02005-10-30 18:16:26 +000016#define DATA_SIZE 1
17#include "softmmu_header.h"
18
19#define DATA_SIZE 2
20#include "softmmu_header.h"
21
22#define DATA_SIZE 4
23#include "softmmu_header.h"
24
25#define DATA_SIZE 8
26#include "softmmu_header.h"
27#undef ACCESS_TYPE
28#undef MEMSUFFIX
29
30#define ACCESS_TYPE 1
j_mayer6ebbf392007-10-14 07:07:08 +000031#define MEMSUFFIX MMU_MODE1_SUFFIX
bellarda9049a02005-10-30 18:16:26 +000032#define DATA_SIZE 1
33#include "softmmu_header.h"
34
35#define DATA_SIZE 2
36#include "softmmu_header.h"
37
38#define DATA_SIZE 4
39#include "softmmu_header.h"
40
41#define DATA_SIZE 8
42#include "softmmu_header.h"
43#undef ACCESS_TYPE
44#undef MEMSUFFIX
45
j_mayer6ebbf392007-10-14 07:07:08 +000046#if (NB_MMU_MODES >= 3)
47
bellarda9049a02005-10-30 18:16:26 +000048#define ACCESS_TYPE 2
j_mayer6ebbf392007-10-14 07:07:08 +000049#define MEMSUFFIX MMU_MODE2_SUFFIX
50#define DATA_SIZE 1
51#include "softmmu_header.h"
52
53#define DATA_SIZE 2
54#include "softmmu_header.h"
55
56#define DATA_SIZE 4
57#include "softmmu_header.h"
58
59#define DATA_SIZE 8
60#include "softmmu_header.h"
61#undef ACCESS_TYPE
62#undef MEMSUFFIX
aurel32e37e6ee2009-04-07 21:47:27 +000063#endif /* (NB_MMU_MODES >= 3) */
j_mayer6ebbf392007-10-14 07:07:08 +000064
65#if (NB_MMU_MODES >= 4)
66
67#define ACCESS_TYPE 3
68#define MEMSUFFIX MMU_MODE3_SUFFIX
69#define DATA_SIZE 1
70#include "softmmu_header.h"
71
72#define DATA_SIZE 2
73#include "softmmu_header.h"
74
75#define DATA_SIZE 4
76#include "softmmu_header.h"
77
78#define DATA_SIZE 8
79#include "softmmu_header.h"
80#undef ACCESS_TYPE
81#undef MEMSUFFIX
aurel32e37e6ee2009-04-07 21:47:27 +000082#endif /* (NB_MMU_MODES >= 4) */
j_mayer6ebbf392007-10-14 07:07:08 +000083
aurel32e37e6ee2009-04-07 21:47:27 +000084#if (NB_MMU_MODES >= 5)
85
86#define ACCESS_TYPE 4
87#define MEMSUFFIX MMU_MODE4_SUFFIX
88#define DATA_SIZE 1
89#include "softmmu_header.h"
90
91#define DATA_SIZE 2
92#include "softmmu_header.h"
93
94#define DATA_SIZE 4
95#include "softmmu_header.h"
96
97#define DATA_SIZE 8
98#include "softmmu_header.h"
99#undef ACCESS_TYPE
100#undef MEMSUFFIX
101#endif /* (NB_MMU_MODES >= 5) */
102
Igor V. Kovalenko20650612010-05-03 11:29:44 +0400103#if (NB_MMU_MODES >= 6)
104
105#define ACCESS_TYPE 5
106#define MEMSUFFIX MMU_MODE5_SUFFIX
107#define DATA_SIZE 1
108#include "softmmu_header.h"
109
110#define DATA_SIZE 2
111#include "softmmu_header.h"
112
113#define DATA_SIZE 4
114#include "softmmu_header.h"
115
116#define DATA_SIZE 8
117#include "softmmu_header.h"
118#undef ACCESS_TYPE
119#undef MEMSUFFIX
120#endif /* (NB_MMU_MODES >= 6) */
121
122#if (NB_MMU_MODES > 6)
123#error "NB_MMU_MODES > 6 is not supported for now"
124#endif /* (NB_MMU_MODES > 6) */
j_mayer6ebbf392007-10-14 07:07:08 +0000125
126/* these access are slower, they must be as rare as possible */
127#define ACCESS_TYPE (NB_MMU_MODES)
bellarda9049a02005-10-30 18:16:26 +0000128#define MEMSUFFIX _data
129#define DATA_SIZE 1
130#include "softmmu_header.h"
131
132#define DATA_SIZE 2
133#include "softmmu_header.h"
134
135#define DATA_SIZE 4
136#include "softmmu_header.h"
137
138#define DATA_SIZE 8
139#include "softmmu_header.h"
140#undef ACCESS_TYPE
141#undef MEMSUFFIX
142
143#define ldub(p) ldub_data(p)
144#define ldsb(p) ldsb_data(p)
145#define lduw(p) lduw_data(p)
146#define ldsw(p) ldsw_data(p)
147#define ldl(p) ldl_data(p)
148#define ldq(p) ldq_data(p)
149
150#define stb(p, v) stb_data(p, v)
151#define stw(p, v) stw_data(p, v)
152#define stl(p, v) stl_data(p, v)
153#define stq(p, v) stq_data(p, v)