+#ifdef TARGET_WORDS_BIGENDIAN
+#define GET_LMASK(v) ((v) & 3)
+#else
+#define GET_LMASK(v) (((v) & 3) ^ 3)
+#endif
+
void glue(do_lwl, MEMSUFFIX) (uint32_t tmp)
{
#if defined (DEBUG_OP)
/* XXX: this is valid only in big-endian mode
* should be reverted for little-endian...
*/
- switch (T0 & 3) {
+ switch (GET_LMASK(T0)) {
case 0:
T0 = tmp;
break;
/* XXX: this is valid only in big-endian mode
* should be reverted for little-endian...
*/
- switch (T0 & 3) {
+ switch (GET_LMASK(T0)) {
case 0:
T0 = (tmp >> 24) | (T1 & 0xFFFFFF00);
break;
/* XXX: this is valid only in big-endian mode
* should be reverted for little-endian...
*/
- switch (T0 & 3) {
+ switch (GET_LMASK(T0)) {
case 0:
tmp = T1;
break;
/* XXX: this is valid only in big-endian mode
* should be reverted for little-endian...
*/
- switch (T0 & 3) {
+ switch (GET_LMASK(T0)) {
case 0:
tmp = (tmp & 0x00FFFFFF) | (T1 << 24);
break;