libqtest: Inline g_assert_no_errno()
[qemu/armbru.git] / tests / tcg / mips / mips32-dspr2 / dps_w_ph.c
blobf51f9b9d13d711ce6f78e0f9d8043aad7c3bf640
1 #include<stdio.h>
2 #include<assert.h>
4 int main()
6 int rs, rt;
7 int ach = 5, acl = 5;
8 int resulth, resultl;
10 rs = 0x00FF00FF;
11 rt = 0x00010002;
12 resulth = 0x04;
13 resultl = 0xFFFFFD08;
14 __asm
15 ("mthi %0, $ac1\n\t"
16 "mtlo %1, $ac1\n\t"
17 "dps.w.ph $ac1, %2, %3\n\t"
18 "mfhi %0, $ac1\n\t"
19 "mflo %1, $ac1\n\t"
20 : "+r"(ach), "+r"(acl)
21 : "r"(rs), "r"(rt)
23 assert(ach == resulth);
24 assert(acl == resultl);
26 ach = 6, acl = 7;
27 rs = 0xFFFF00FF;
28 rt = 0xFFFF0002;
29 resulth = 0x05;
30 resultl = 0xFFFFFE08;
31 __asm
32 ("mthi %0, $ac1\n\t"
33 "mtlo %1, $ac1\n\t"
34 "dps.w.ph $ac1, %2, %3\n\t"
35 "mfhi %0, $ac1\n\t"
36 "mflo %1, $ac1\n\t"
37 : "+r"(ach), "+r"(acl)
38 : "r"(rs), "r"(rt)
40 assert(ach == resulth);
41 assert(acl == resultl);
43 return 0;