32 lines
544 B
C
32 lines
544 B
C
#include <unistd.h>
|
|
|
|
static long test_subqv (long a, long b)
|
|
{
|
|
long res;
|
|
|
|
asm ("subq/v %1,%2,%0"
|
|
: "=r" (res) : "r" (a), "r" (b));
|
|
return res;
|
|
}
|
|
static struct {
|
|
long (*func)(long, long);
|
|
long a;
|
|
long b;
|
|
long r;
|
|
} vectors[] =
|
|
{
|
|
{test_subqv, 0, 0x7d54000, 0xfffffffff82ac000L}
|
|
};
|
|
|
|
int main (void)
|
|
{
|
|
int i;
|
|
|
|
for (i = 0; i < sizeof (vectors)/sizeof(vectors[0]); i++)
|
|
if ((*vectors[i].func)(vectors[i].a, vectors[i].b) != vectors[i].r) {
|
|
write(1, "Failed\n", 7);
|
|
}
|
|
write(1, "OK\n", 3);
|
|
return 0;
|
|
}
|