Statistics
| Branch: | Revision:

root / target-ppc / op_helper_mem.h @ 71be0fc3

History | View | Annotate | Download (2.2 kB)

1 9a64fbe4 bellard
void glue(do_lsw, MEMSUFFIX) (int dst)
2 9a64fbe4 bellard
{
3 9a64fbe4 bellard
    uint32_t tmp;
4 9a64fbe4 bellard
    int sh;
5 9a64fbe4 bellard
6 71be0fc3 bellard
#if 0
7 71be0fc3 bellard
    fprintf(logfile, "%s: addr=0x%08x count=%d reg=%d\n",
8 71be0fc3 bellard
            __func__, T0, T1, dst);
9 71be0fc3 bellard
#endif
10 9a64fbe4 bellard
    for (; T1 > 3; T1 -= 4, T0 += 4) {
11 0fa85d43 bellard
        ugpr(dst++) = glue(ldl, MEMSUFFIX)(T0);
12 9a64fbe4 bellard
        if (dst == 32)
13 9a64fbe4 bellard
            dst = 0;
14 9a64fbe4 bellard
    }
15 9a64fbe4 bellard
    if (T1 > 0) {
16 9a64fbe4 bellard
        tmp = 0;
17 9a64fbe4 bellard
        for (sh = 24; T1 > 0; T1--, T0++, sh -= 8) {
18 0fa85d43 bellard
            tmp |= glue(ldub, MEMSUFFIX)(T0) << sh;
19 9a64fbe4 bellard
        }
20 9a64fbe4 bellard
        ugpr(dst) = tmp;
21 9a64fbe4 bellard
    }
22 9a64fbe4 bellard
}
23 9a64fbe4 bellard
24 9a64fbe4 bellard
void glue(do_stsw, MEMSUFFIX) (int src)
25 9a64fbe4 bellard
{
26 9a64fbe4 bellard
    int sh;
27 9a64fbe4 bellard
28 71be0fc3 bellard
#if 0
29 71be0fc3 bellard
    fprintf(logfile, "%s: addr=0x%08x count=%d reg=%d\n",
30 71be0fc3 bellard
            __func__, T0, T1, src);
31 71be0fc3 bellard
#endif
32 9a64fbe4 bellard
    for (; T1 > 3; T1 -= 4, T0 += 4) {
33 0fa85d43 bellard
        glue(stl, MEMSUFFIX)(T0, ugpr(src++));
34 9a64fbe4 bellard
        if (src == 32)
35 9a64fbe4 bellard
            src = 0;
36 9a64fbe4 bellard
    }
37 9a64fbe4 bellard
    if (T1 > 0) {
38 9a64fbe4 bellard
        for (sh = 24; T1 > 0; T1--, T0++, sh -= 8)
39 0fa85d43 bellard
            glue(stb, MEMSUFFIX)(T0, (ugpr(src) >> sh) & 0xFF);
40 9a64fbe4 bellard
    }
41 9a64fbe4 bellard
}
42 9a64fbe4 bellard
43 111bfab3 bellard
void glue(do_lsw_le, MEMSUFFIX) (int dst)
44 111bfab3 bellard
{
45 111bfab3 bellard
    uint32_t tmp;
46 111bfab3 bellard
    int sh;
47 111bfab3 bellard
48 71be0fc3 bellard
#if 0
49 111bfab3 bellard
        fprintf(logfile, "%s: addr=0x%08x count=%d reg=%d\n",
50 111bfab3 bellard
                __func__, T0, T1, dst);
51 71be0fc3 bellard
#endif
52 111bfab3 bellard
    for (; T1 > 3; T1 -= 4, T0 += 4) {
53 111bfab3 bellard
        tmp = glue(ldl, MEMSUFFIX)(T0);
54 111bfab3 bellard
        ugpr(dst++) = ((tmp & 0xFF000000) >> 24) | ((tmp & 0x00FF0000) >> 8) |
55 111bfab3 bellard
            ((tmp & 0x0000FF00) << 8) | ((tmp & 0x000000FF) << 24);
56 111bfab3 bellard
        if (dst == 32)
57 111bfab3 bellard
            dst = 0;
58 111bfab3 bellard
    }
59 111bfab3 bellard
    if (T1 > 0) {
60 111bfab3 bellard
        tmp = 0;
61 111bfab3 bellard
        for (sh = 0; T1 > 0; T1--, T0++, sh += 8) {
62 111bfab3 bellard
            tmp |= glue(ldub, MEMSUFFIX)(T0) << sh;
63 111bfab3 bellard
        }
64 111bfab3 bellard
        ugpr(dst) = tmp;
65 111bfab3 bellard
    }
66 111bfab3 bellard
}
67 111bfab3 bellard
68 111bfab3 bellard
void glue(do_stsw_le, MEMSUFFIX) (int src)
69 111bfab3 bellard
{
70 111bfab3 bellard
    uint32_t tmp;
71 111bfab3 bellard
    int sh;
72 111bfab3 bellard
73 71be0fc3 bellard
#if 0
74 111bfab3 bellard
        fprintf(logfile, "%s: addr=0x%08x count=%d reg=%d\n",
75 111bfab3 bellard
                __func__, T0, T1, src);
76 71be0fc3 bellard
#endif
77 111bfab3 bellard
    for (; T1 > 3; T1 -= 4, T0 += 4) {
78 111bfab3 bellard
        tmp = ((ugpr(src++) & 0xFF000000) >> 24);
79 111bfab3 bellard
        tmp |= ((ugpr(src++) & 0x00FF0000) >> 8);
80 111bfab3 bellard
        tmp |= ((ugpr(src++) & 0x0000FF00) << 8);
81 111bfab3 bellard
        tmp |= ((ugpr(src++) & 0x000000FF) << 24);
82 111bfab3 bellard
        glue(stl, MEMSUFFIX)(T0, tmp);
83 111bfab3 bellard
        if (src == 32)
84 111bfab3 bellard
            src = 0;
85 111bfab3 bellard
    }
86 111bfab3 bellard
    if (T1 > 0) {
87 111bfab3 bellard
        for (sh = 0; T1 > 0; T1--, T0++, sh += 8)
88 111bfab3 bellard
            glue(stb, MEMSUFFIX)(T0, (ugpr(src) >> sh) & 0xFF);
89 111bfab3 bellard
    }
90 111bfab3 bellard
}
91 111bfab3 bellard
92 9a64fbe4 bellard
#undef MEMSUFFIX