Revision 9f25f11f target-mips/op_helper_mem.c
b/target-mips/op_helper_mem.c | ||
---|---|---|
1 |
#ifdef TARGET_WORDS_BIGENDIAN |
|
2 |
#define GET_LMASK(v) ((v) & 3) |
|
3 |
#else |
|
4 |
#define GET_LMASK(v) (((v) & 3) ^ 3) |
|
5 |
#endif |
|
6 |
|
|
1 | 7 |
void glue(do_lwl, MEMSUFFIX) (uint32_t tmp) |
2 | 8 |
{ |
3 | 9 |
#if defined (DEBUG_OP) |
... | ... | |
7 | 13 |
/* XXX: this is valid only in big-endian mode |
8 | 14 |
* should be reverted for little-endian... |
9 | 15 |
*/ |
10 |
switch (T0 & 3) {
|
|
16 |
switch (GET_LMASK(T0)) {
|
|
11 | 17 |
case 0: |
12 | 18 |
T0 = tmp; |
13 | 19 |
break; |
... | ... | |
39 | 45 |
/* XXX: this is valid only in big-endian mode |
40 | 46 |
* should be reverted for little-endian... |
41 | 47 |
*/ |
42 |
switch (T0 & 3) {
|
|
48 |
switch (GET_LMASK(T0)) {
|
|
43 | 49 |
case 0: |
44 | 50 |
T0 = (tmp >> 24) | (T1 & 0xFFFFFF00); |
45 | 51 |
break; |
... | ... | |
74 | 80 |
/* XXX: this is valid only in big-endian mode |
75 | 81 |
* should be reverted for little-endian... |
76 | 82 |
*/ |
77 |
switch (T0 & 3) {
|
|
83 |
switch (GET_LMASK(T0)) {
|
|
78 | 84 |
case 0: |
79 | 85 |
tmp = T1; |
80 | 86 |
break; |
... | ... | |
110 | 116 |
/* XXX: this is valid only in big-endian mode |
111 | 117 |
* should be reverted for little-endian... |
112 | 118 |
*/ |
113 |
switch (T0 & 3) {
|
|
119 |
switch (GET_LMASK(T0)) {
|
|
114 | 120 |
case 0: |
115 | 121 |
tmp = (tmp & 0x00FFFFFF) | (T1 << 24); |
116 | 122 |
break; |
Also available in: Unified diff