aboutsummaryrefslogtreecommitdiff
path: root/tests/tcg/s390x/lae.c
blob: 59712b5e3715ee965e22f849c5ad82432b342a0b (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
/*
 * Test the LOAD ADDRESS EXTENDED instruction.
 *
 * SPDX-License-Identifier: GPL-2.0-or-later
 */
#include <assert.h>
#include <stdlib.h>

int main(void)
{
    unsigned long long ar = -1, b2 = 100000, r, x2 = 500;
    /*
     * Hardcode the register number, since clang does not allow using %rN in
     * place of %aN.
     */
    register unsigned long long r2 __asm__("2");
    int tmp;

    asm("ear %[tmp],%%a2\n"
        "lae %%r2,42(%[x2],%[b2])\n"
        "ear %[ar],%%a2\n"
        "sar %%a2,%[tmp]"
        : [tmp] "=&r" (tmp), "=&r" (r2), [ar] "+r" (ar)
        : [b2] "r" (b2), [x2] "r" (x2)
        : "memory");
    r = r2;
    assert(ar == 0xffffffff00000000ULL);
    assert(r == 100542);

    return EXIT_SUCCESS;
}