dpaqx_sa_w_ph.c 1.3 KB
Newer Older
J
Jia Liu 已提交
1 2 3 4 5 6
#include<stdio.h>
#include<assert.h>

int main()
{
    int rs, rt, dsp;
7
    int ach, acl;
J
Jia Liu 已提交
8 9
    int resulth, resultl, resultdsp;

10 11
    ach = 0x00000005;
    acl = 0x00000005;
J
Jia Liu 已提交
12 13 14 15 16
    rs     = 0x00FF00FF;
    rt     = 0x00010002;
    resulth = 0x00;
    resultl = 0x7FFFFFFF;
    resultdsp = 0x01;
17
    dsp = 0;
J
Jia Liu 已提交
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
    __asm
        ("wrdsp %2\n\t"
         "mthi  %0, $ac1\n\t"
         "mtlo  %1, $ac1\n\t"
         "dpaqx_sa.w.ph $ac1, %3, %4\n\t"
         "mfhi  %0, $ac1\n\t"
         "mflo  %1, $ac1\n\t"
         "rddsp %2\n\t"
         : "+r"(ach), "+r"(acl), "+r"(dsp)
         : "r"(rs), "r"(rt)
        );
    assert(dsp >> (16 + 1) == resultdsp);
    assert(ach == resulth);
    assert(acl == resultl);

33 34
    ach = 0x00000009;
    acl = 0x0000000B;
J
Jia Liu 已提交
35 36 37
    rs     = 0x800000FF;
    rt     = 0x00018000;
    resulth = 0x00;
38
    resultl = 0x7FFFFFFF;
J
Jia Liu 已提交
39
    resultdsp = 0x01;
40
    dsp = 0;
J
Jia Liu 已提交
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
    __asm
        ("wrdsp %2\n\t"
         "mthi  %0, $ac1\n\t"
         "mtlo  %1, $ac1\n\t"
         "dpaqx_sa.w.ph $ac1, %3, %4\n\t"
         "mfhi  %0, $ac1\n\t"
         "mflo  %1, $ac1\n\t"
         "rddsp %2\n\t"
         : "+r"(ach), "+r"(acl), "+r"(dsp)
         : "r"(rs), "r"(rt)
        );
    assert(dsp >> (16 + 1) == resultdsp);
    assert(ach == resulth);
    assert(acl == resultl);

    return 0;
}