#include <stdio.h>
#define branch(mask,_v1,_v2) \
({ \
unsigned char taken; \
unsigned b1 = _v1; \
unsigned b2 = _v2; \
asm volatile( " alr %[b1],%[b2]\n\t" \
" brc " #mask " ,1f\n\t" \
" mvi %[taken],0\n\t" \
" j 0f\n\t" \
"1: mvi %[taken],1\n\t" \
"0: bcr 0,0 /* nop */\n\t" \
: [taken] "=Q" (taken), [b1] "+d"(b1) \
: [b2] "d"(b2) \
: "cc"); \
taken; \
})
void
alr_cc_0(void)
{
unsigned v1, v2;
int wrong, ok;
printf("Test #1 cc == 0\n");
v1 = v2 = 0;
wrong = ok = 0;
if (branch(0, v1, v2)) ++wrong; else ++ok;
if (branch(1, v1, v2)) ++wrong; else ++ok;
if (branch(2, v1, v2)) ++wrong; else ++ok;
if (branch(3, v1, v2)) ++wrong; else ++ok;
if (branch(4, v1, v2)) ++wrong; else ++ok;
if (branch(5, v1, v2)) ++wrong; else ++ok;
if (branch(6, v1, v2)) ++wrong; else ++ok;
if (branch(7, v1, v2)) ++wrong; else ++ok;
if (branch(8, v1, v2)) ++ok; else ++wrong;
if (branch(9, v1, v2)) ++ok; else ++wrong;
if (branch(10, v1, v2)) ++ok; else ++wrong;
if (branch(11, v1, v2)) ++ok; else ++wrong;
if (branch(12, v1, v2)) ++ok; else ++wrong;
if (branch(13, v1, v2)) ++ok; else ++wrong;
if (branch(14, v1, v2)) ++ok; else ++wrong;
if (branch(15, v1, v2)) ++ok; else ++wrong;
if (wrong != 0 || ok != 16)
printf("FAILED\n");
else
printf("OK\n");
}
void
alr_cc_1(void)
{
unsigned v1, v2;
int wrong, ok;
printf("Test #2 cc == 1\n");
v1 = v2 = 42;
wrong = ok = 0;
if (branch(0, v1, v2)) ++wrong; else ++ok;
if (branch(1, v1, v2)) ++wrong; else ++ok;
if (branch(2, v1, v2)) ++wrong; else ++ok;
if (branch(3, v1, v2)) ++wrong; else ++ok;
if (branch(4, v1, v2)) ++ok; else ++wrong;
if (branch(5, v1, v2)) ++ok; else ++wrong;
if (branch(6, v1, v2)) ++ok; else ++wrong;
if (branch(7, v1, v2)) ++ok; else ++wrong;
if (branch(8, v1, v2)) ++wrong; else ++ok;
if (branch(9, v1, v2)) ++wrong; else ++ok;
if (branch(10, v1, v2)) ++wrong; else ++ok;
if (branch(11, v1, v2)) ++wrong; else ++ok;
if (branch(12, v1, v2)) ++ok; else ++wrong;
if (branch(13, v1, v2)) ++ok; else ++wrong;
if (branch(14, v1, v2)) ++ok; else ++wrong;
if (branch(15, v1, v2)) ++ok; else ++wrong;
if (wrong != 0 || ok != 16)
printf("FAILED\n");
else
printf("OK\n");
}
void
alr_cc_2(void)
{
unsigned v1, v2;
int wrong, ok;
printf("Test #3 cc == 2\n");
v1 = 0xFFFFFFFF;
v2 = 1;
wrong = ok = 0;
if (branch(0, v1, v2)) ++wrong; else ++ok;
if (branch(1, v1, v2)) ++wrong; else ++ok;
if (branch(2, v1, v2)) ++ok; else ++wrong;
if (branch(3, v1, v2)) ++ok; else ++wrong;
if (branch(4, v1, v2)) ++wrong; else ++ok;
if (branch(5, v1, v2)) ++wrong; else ++ok;
if (branch(6, v1, v2)) ++ok; else ++wrong;
if (branch(7, v1, v2)) ++ok; else ++wrong;
if (branch(8, v1, v2)) ++wrong; else ++ok;
if (branch(9, v1, v2)) ++wrong; else ++ok;
if (branch(10, v1, v2)) ++ok; else ++wrong;
if (branch(11, v1, v2)) ++ok; else ++wrong;
if (branch(12, v1, v2)) ++wrong; else ++ok;
if (branch(13, v1, v2)) ++wrong; else ++ok;
if (branch(14, v1, v2)) ++ok; else ++wrong;
if (branch(15, v1, v2)) ++ok; else ++wrong;
if (wrong != 0 /* || ok != 16 */)
printf("FAILED\n");
else
printf("OK\n");
}
void
alr_cc_3(void)
{
unsigned v1, v2;
int wrong, ok;
printf("Test #4 cc == 3\n");
v1 = 0xFFFFFFFF;
v2 = 100;
wrong = ok = 0;
if (branch(0, v1, v2)) ++wrong; else ++ok;
if (branch(1, v1, v2)) ++ok; else ++wrong;
if (branch(2, v1, v2)) ++wrong; else ++ok;
if (branch(3, v1, v2)) ++ok; else ++wrong;
if (branch(4, v1, v2)) ++wrong; else ++ok;
if (branch(5, v1, v2)) ++ok; else ++wrong;
if (branch(6, v1, v2)) ++wrong; else ++ok;
if (branch(7, v1, v2)) ++ok; else ++wrong;
if (branch(8, v1, v2)) ++wrong; else ++ok;
if (branch(9, v1, v2)) ++ok; else ++wrong;
if (branch(10, v1, v2)) ++wrong; else ++ok;
if (branch(11, v1, v2)) ++ok; else ++wrong;
if (branch(12, v1, v2)) ++wrong; else ++ok;
if (branch(13, v1, v2)) ++ok; else ++wrong;
if (branch(14, v1, v2)) ++wrong; else ++ok;
if (branch(15, v1, v2)) ++ok; else ++wrong;
if (wrong != 0 || ok != 16)
printf("FAILED\n");
else
printf("OK\n");
}
int main()
{
alr_cc_0();
alr_cc_1();
alr_cc_2();
alr_cc_3();
return 0;
}