aboutsummaryrefslogtreecommitdiff
path: root/tests/tcg/s390x/mie3-mvcrl.c
blob: 57b08e48d00403f3e4110f43a89dffec84fa112b (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
#include <stdint.h>
#include <string.h>

static inline void mvcrl_8(const char *dst, const char *src)
{
    asm volatile (
    "llill %%r0, 8\n"
    ".insn sse, 0xE50A00000000, 0(%[dst]), 0(%[src])"
    : : [dst] "d" (dst), [src] "d" (src)
    : "memory");
}

int main(int argc, char *argv[])
{
    const char *alpha = "abcdefghijklmnop";

    /* array missing 'i' */
    char tstr[17] = "abcdefghjklmnop\0" ;

    /* mvcrl reference use: 'open a hole in an array' */
    mvcrl_8(tstr + 9, tstr + 8);

    /* place missing 'i' */
    tstr[8] = 'i';

    return strncmp(alpha, tstr, 16ul);
}