aboutsummaryrefslogtreecommitdiffstats
path: root/tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c
blob: 5c9baab03d0098d58cca7162876788b01b612eeb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#include<stdio.h>
#include<assert.h>

int main()
{
    int rs, rt;
    int result;

    rs = 0x12345678;
    rt = 0x87654321;
    result = 0x43215678;

    __asm
        ("precr_sra.ph.w %0, %1, 0x00\n\t"
         : "+r"(rt)
         : "r"(rs)
        );
    assert(result == rt);

    rs = 0x12345678;
    rt = 0x87654321;
    result = 0xFFFF0000;

    __asm
        ("precr_sra.ph.w %0, %1, 0x1F\n\t"
         : "+r"(rt)
         : "r"(rs)
        );
    assert(result == rt);

    return 0;
}