A first small step to convert the CRIS translator to TCG.
[qemu/malc.git] / target-sparc / op_mem.h
bloba95c733ed09253851410f0b1e9b5a4c4ff251a47
1 #ifdef TARGET_ABI32
2 #define ADDR(x) ((x) & 0xffffffff)
3 #else
4 #define ADDR(x) (x)
5 #endif
7 #ifdef __i386__
8 /*** Integer store ***/
9 void OPPROTO glue(op_std, MEMSUFFIX)(void)
11 uint64_t tmp = ((uint64_t)T1 << 32) | (uint64_t)(T2 & 0xffffffff);
13 glue(stq, MEMSUFFIX)(ADDR(T0), tmp);
16 #endif /* __i386__ */
17 /*** Floating-point store ***/
18 void OPPROTO glue(op_stf, MEMSUFFIX) (void)
20 glue(stfl, MEMSUFFIX)(ADDR(T0), FT0);
23 void OPPROTO glue(op_stdf, MEMSUFFIX) (void)
25 glue(stfq, MEMSUFFIX)(ADDR(T0), DT0);
28 /*** Floating-point load ***/
29 void OPPROTO glue(op_ldf, MEMSUFFIX) (void)
31 FT0 = glue(ldfl, MEMSUFFIX)(ADDR(T0));
34 void OPPROTO glue(op_lddf, MEMSUFFIX) (void)
36 DT0 = glue(ldfq, MEMSUFFIX)(ADDR(T0));
39 #if defined(CONFIG_USER_ONLY)
40 void OPPROTO glue(op_ldqf, MEMSUFFIX) (void)
42 // XXX add 128 bit load
43 CPU_QuadU u;
45 u.ll.upper = glue(ldq, MEMSUFFIX)(ADDR(T0));
46 u.ll.lower = glue(ldq, MEMSUFFIX)(ADDR(T0 + 8));
47 QT0 = u.q;
50 void OPPROTO glue(op_stqf, MEMSUFFIX) (void)
52 // XXX add 128 bit store
53 CPU_QuadU u;
55 u.q = QT0;
56 glue(stq, MEMSUFFIX)(ADDR(T0), u.ll.upper);
57 glue(stq, MEMSUFFIX)(ADDR(T0 + 8), u.ll.lower);
59 #endif
61 #undef MEMSUFFIX