xref: /qemu/tests/tcg/mips/user/ase/dsp/test_dsp_r1_msubu.c (revision 073d9f2ce051d7a4bad9aa7bfdacf97394c57c05)
1*d70080c4SJia Liu #include<stdio.h>
2*d70080c4SJia Liu #include<assert.h>
3*d70080c4SJia Liu 
main()4*d70080c4SJia Liu int main()
5*d70080c4SJia Liu {
6*d70080c4SJia Liu     int achi, acli, rs, rt;
7*d70080c4SJia Liu     int acho, aclo;
8*d70080c4SJia Liu     int resulth, resultl;
9*d70080c4SJia Liu 
10*d70080c4SJia Liu     rs      = 0x00BBAACC;
11*d70080c4SJia Liu     rt      = 0x0B1C3D2F;
12*d70080c4SJia Liu     achi    = 0x00004433;
13*d70080c4SJia Liu     acli    = 0xFFCC0011;
14*d70080c4SJia Liu     resulth = 0xFFF81F29;
15*d70080c4SJia Liu     resultl = 0xB355089D;
16*d70080c4SJia Liu 
17*d70080c4SJia Liu     __asm
18*d70080c4SJia Liu         ("mthi %2, $ac1\n\t"
19*d70080c4SJia Liu          "mtlo %3, $ac1\n\t"
20*d70080c4SJia Liu          "msubu $ac1, %4, %5\n\t"
21*d70080c4SJia Liu          "mfhi %0, $ac1\n\t"
22*d70080c4SJia Liu          "mflo %1, $ac1\n\t"
23*d70080c4SJia Liu          : "=r"(acho), "=r"(aclo)
24*d70080c4SJia Liu          : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
25*d70080c4SJia Liu         );
26*d70080c4SJia Liu     assert(acho == resulth);
27*d70080c4SJia Liu     assert(aclo == resultl);
28*d70080c4SJia Liu 
29*d70080c4SJia Liu     return 0;
30*d70080c4SJia Liu }
31