aboutsummaryrefslogtreecommitdiff
path: root/tests/tcg/mips/mips32-dsp/insv.c
blob: 7e3b0476064dc6f93e659b7c11d3be2ba15dfd2f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include<stdio.h>
#include<assert.h>

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

    /* msb = 10, lsb = 5 */
    dsp    = 0x305;
    rt     = 0x12345678;
    rs     = 0x87654321;
    result = 0x12345338;
    __asm
        ("wrdsp %2, 0x03\n\t"
         "insv  %0, %1\n\t"
         : "+r"(rt)
         : "r"(rs), "r"(dsp)
        );
    assert(rt == result);

    return 0;
}