qemu-e2k/tests/tcg/cris/libc/check_bound.c
Alex Bennée d4f6e58fcb tests/tcg: split cris tests into bare and libc directories
Bare tests are standalone assembly tests that don't require linking to
any libc and hence can be built with kernel only compilers. The libc
tests need a compiler capable of building properly linked userspace
binaries. As we don't have such a cross compiler at the moment we
won't be building those tests.

Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
2019-03-12 17:05:21 +00:00

143 lines
2.4 KiB
C

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include "sys.h"
#include "crisutils.h"
static always_inline int cris_bound_b(int v, int b)
{
int r = v;
asm ("bound.b\t%1, %0\n" : "+r" (r) : "ri" (b));
return r;
}
static always_inline int cris_bound_w(int v, int b)
{
int r = v;
asm ("bound.w\t%1, %0\n" : "+r" (r) : "ri" (b));
return r;
}
static always_inline int cris_bound_d(int v, int b)
{
int r = v;
asm ("bound.d\t%1, %0\n" : "+r" (r) : "ri" (b));
return r;
}
int main(void)
{
int r;
cris_tst_cc_init();
r = cris_bound_d(-1, 2);
cris_tst_cc(0, 0, 0, 0);
if (r != 2)
err();
cris_tst_cc_init();
r = cris_bound_d(2, 0xffffffff);
cris_tst_cc(0, 0, 0, 0);
if (r != 2)
err();
cris_tst_cc_init();
r = cris_bound_d(0xffff, 0xffff);
cris_tst_cc(0, 0, 0, 0);
if (r != 0xffff)
err();
cris_tst_cc_init();
r = cris_bound_d(-1, 0xffffffff);
cris_tst_cc(1, 0, 0, 0);
if (r != 0xffffffff)
err();
cris_tst_cc_init();
r = cris_bound_d(0x78134452, 0x5432f789);
cris_tst_cc(0, 0, 0, 0);
if (r != 0x5432f789)
err();
cris_tst_cc_init();
r = cris_bound_w(-1, 2);
cris_tst_cc(0, 0, 0, 0);
if (r != 2)
err();
cris_tst_cc_init();
r = cris_bound_w(-1, 0xffff);
cris_tst_cc(0, 0, 0, 0);
if (r != 0xffff)
err();
cris_tst_cc_init();
r = cris_bound_w(2, 0xffff);
cris_tst_cc(0, 0, 0, 0);
if (r != 2)
err();
cris_tst_cc_init();
r = cris_bound_w(0xfedaffff, 0xffff);
cris_tst_cc(0, 0, 0, 0);
if (r != 0xffff)
err();
cris_tst_cc_init();
r = cris_bound_w(0x78134452, 0xf789);
cris_tst_cc(0, 0, 0, 0);
if (r != 0xf789)
err();
cris_tst_cc_init();
r = cris_bound_b(-1, 2);
cris_tst_cc(0, 0, 0, 0);
if (r != 2)
err();
cris_tst_cc_init();
r = cris_bound_b(2, 0xff);
cris_tst_cc(0, 0, 0, 0);
if (r != 2)
err();
cris_tst_cc_init();
r = cris_bound_b(-1, 0xff);
cris_tst_cc(0, 0, 0, 0);
if (r != 0xff)
err();
cris_tst_cc_init();
r = cris_bound_b(0xff, 0xff);
cris_tst_cc(0, 0, 0, 0);
if (r != 0xff)
err();
cris_tst_cc_init();
r = cris_bound_b(0xfeda49ff, 0xff);
cris_tst_cc(0, 0, 0, 0);
if (r != 0xff)
err();
cris_tst_cc_init();
r = cris_bound_b(0x78134452, 0x89);
cris_tst_cc(0, 0, 0, 0);
if (r != 0x89)
err();
cris_tst_cc_init();
r = cris_bound_w(0x78134452, 0);
cris_tst_cc(0, 1, 0, 0);
if (r != 0)
err();
cris_tst_cc_init();
r = cris_bound_b(0xffff, -1);
cris_tst_cc(0, 0, 0, 0);
if (r != 0xff)
err();
pass();
return 0;
}