Revision 3475187d target-sparc/op_mem.h
b/target-sparc/op_mem.h | ||
---|---|---|
2 | 2 |
#define SPARC_LD_OP(name, qp) \ |
3 | 3 |
void OPPROTO glue(glue(op_, name), MEMSUFFIX)(void) \ |
4 | 4 |
{ \ |
5 |
T1 = glue(qp, MEMSUFFIX)(T0); \
|
|
5 |
T1 = (target_ulong)glue(qp, MEMSUFFIX)(T0); \
|
|
6 | 6 |
} |
7 | 7 |
|
8 |
#define SPARC_LD_OP_S(name, qp) \ |
|
9 |
void OPPROTO glue(glue(op_, name), MEMSUFFIX)(void) \ |
|
10 |
{ \ |
|
11 |
T1 = (target_long)glue(qp, MEMSUFFIX)(T0); \ |
|
12 |
} |
|
13 |
|
|
8 | 14 |
#define SPARC_ST_OP(name, op) \ |
9 | 15 |
void OPPROTO glue(glue(op_, name), MEMSUFFIX)(void) \ |
10 | 16 |
{ \ |
... | ... | |
14 | 20 |
SPARC_LD_OP(ld, ldl); |
15 | 21 |
SPARC_LD_OP(ldub, ldub); |
16 | 22 |
SPARC_LD_OP(lduh, lduw); |
17 |
SPARC_LD_OP(ldsb, ldsb); |
|
18 |
SPARC_LD_OP(ldsh, ldsw); |
|
23 |
SPARC_LD_OP_S(ldsb, ldsb);
|
|
24 |
SPARC_LD_OP_S(ldsh, ldsw);
|
|
19 | 25 |
|
20 | 26 |
/*** Integer store ***/ |
21 | 27 |
SPARC_ST_OP(st, stl); |
... | ... | |
68 | 74 |
{ |
69 | 75 |
DT0 = glue(ldfq, MEMSUFFIX)(T0); |
70 | 76 |
} |
77 |
|
|
78 |
#ifdef TARGET_SPARC64 |
|
79 |
/* XXX: Should be Atomically */ |
|
80 |
/* XXX: There are no cas[x] instructions, only cas[x]a */ |
|
81 |
void OPPROTO glue(op_cas, MEMSUFFIX)(void) |
|
82 |
{ |
|
83 |
uint32_t tmp; |
|
84 |
|
|
85 |
tmp = glue(ldl, MEMSUFFIX)(T0); |
|
86 |
T2 &= 0xffffffffULL; |
|
87 |
if (tmp == (T1 & 0xffffffffULL)) { |
|
88 |
glue(stl, MEMSUFFIX)(T0, T2); |
|
89 |
} |
|
90 |
T2 = tmp; |
|
91 |
} |
|
92 |
|
|
93 |
void OPPROTO glue(op_casx, MEMSUFFIX)(void) |
|
94 |
{ |
|
95 |
uint64_t tmp; |
|
96 |
|
|
97 |
// XXX |
|
98 |
tmp = (uint64_t)glue(ldl, MEMSUFFIX)(T0) << 32; |
|
99 |
tmp |= glue(ldl, MEMSUFFIX)(T0); |
|
100 |
if (tmp == T1) { |
|
101 |
glue(stq, MEMSUFFIX)(T0, T2); |
|
102 |
} |
|
103 |
T2 = tmp; |
|
104 |
} |
|
105 |
|
|
106 |
void OPPROTO glue(op_ldsw, MEMSUFFIX)(void) |
|
107 |
{ |
|
108 |
T1 = (int64_t)glue(ldl, MEMSUFFIX)(T0); |
|
109 |
} |
|
110 |
|
|
111 |
void OPPROTO glue(op_ldx, MEMSUFFIX)(void) |
|
112 |
{ |
|
113 |
// XXX |
|
114 |
T1 = (uint64_t)glue(ldl, MEMSUFFIX)(T0) << 32; |
|
115 |
T1 |= glue(ldl, MEMSUFFIX)(T0); |
|
116 |
} |
|
117 |
|
|
118 |
void OPPROTO glue(op_stx, MEMSUFFIX)(void) |
|
119 |
{ |
|
120 |
glue(stl, MEMSUFFIX)(T0, T1 >> 32); |
|
121 |
glue(stl, MEMSUFFIX)(T0, T1 & 0xffffffff); |
|
122 |
} |
|
123 |
#endif |
|
71 | 124 |
#undef MEMSUFFIX |
Also available in: Unified diff