Revision d79f0809

b/target-ppc/helper.h
143 143
DEF_HELPER_3(vsrb, void, avr, avr, avr)
144 144
DEF_HELPER_3(vsrh, void, avr, avr, avr)
145 145
DEF_HELPER_3(vsrw, void, avr, avr, avr)
146
DEF_HELPER_3(vslb, void, avr, avr, avr)
147
DEF_HELPER_3(vslh, void, avr, avr, avr)
148
DEF_HELPER_3(vslw, void, avr, avr, avr)
146 149

  
147 150
DEF_HELPER_1(efscfsi, i32, i32)
148 151
DEF_HELPER_1(efscfui, i32, i32)
b/target-ppc/op_helper.c
2088 2088
#undef VMUL_DO
2089 2089
#undef VMUL
2090 2090

  
2091
#define VSL(suffix, element)                                            \
2092
    void helper_vsl##suffix (ppc_avr_t *r, ppc_avr_t *a, ppc_avr_t *b)  \
2093
    {                                                                   \
2094
        int i;                                                          \
2095
        for (i = 0; i < ARRAY_SIZE(r->element); i++) {                  \
2096
            unsigned int mask = ((1 << (3 + (sizeof (a->element[0]) >> 1))) - 1); \
2097
            unsigned int shift = b->element[i] & mask;                  \
2098
            r->element[i] = a->element[i] << shift;                     \
2099
        }                                                               \
2100
    }
2101
VSL(b, u8)
2102
VSL(h, u16)
2103
VSL(w, u32)
2104
#undef VSL
2105

  
2091 2106
#define VSR(suffix, element)                                            \
2092 2107
    void helper_vsr##suffix (ppc_avr_t *r, ppc_avr_t *a, ppc_avr_t *b)  \
2093 2108
    {                                                                   \
b/target-ppc/translate.c
6219 6219
GEN_VXFORM(vmuleuh, 4, 9);
6220 6220
GEN_VXFORM(vmulesb, 4, 12);
6221 6221
GEN_VXFORM(vmulesh, 4, 13);
6222
GEN_VXFORM(vslb, 2, 4);
6223
GEN_VXFORM(vslh, 2, 5);
6224
GEN_VXFORM(vslw, 2, 6);
6222 6225
GEN_VXFORM(vsrb, 2, 8);
6223 6226
GEN_VXFORM(vsrh, 2, 9);
6224 6227
GEN_VXFORM(vsrw, 2, 10);

Also available in: Unified diff