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