blob: 78d202d3bd703ae34bce2758fb1e4c79d280a228 [file] [log] [blame]
#include <stdio.h>
#define branch(mask,icmm,_v1) \
({ \
unsigned char taken; \
unsigned b1 = _v1; \
asm volatile( " larl 1, 2f\n\t" \
" l 0, 0(1)\n\t" \
" icm 0," #icmm",%[b1]\n\t" \
" brc " #mask " ,1f\n\t" \
" mvi %[taken],0\n\t" \
" j 0f\n\t" \
"1: mvi %[taken],1\n\t" \
" j 0f\n\t" \
"2: .long 0\n\t" \
"0: bcr 0,0 /* nop */\n\t" \
: [taken] "=Q" (taken) \
: [b1] "Q"(b1) \
: "cc", "0","1"); \
taken; \
})
void
icm_mask_0(void)
{
int wrong, ok;
unsigned v1;
printf("Test #1 mask == 0, value == 0xFFFFFFFF --> cc == 0\n");
v1 = 0xFFFFFFFF;
wrong = ok = 0;
if (branch(0, 0, v1)) ++wrong; else ++ok;
if (branch(1, 0, v1)) ++wrong; else ++ok;
if (branch(2, 0, v1)) ++wrong; else ++ok;
if (branch(3, 0, v1)) ++wrong; else ++ok;
if (branch(4, 0, v1)) ++wrong; else ++ok;
if (branch(5, 0, v1)) ++wrong; else ++ok;
if (branch(6, 0, v1)) ++wrong; else ++ok;
if (branch(7, 0, v1)) ++wrong; else ++ok;
if (branch(8, 0, v1)) ++ok; else ++wrong;
if (branch(9, 0, v1)) ++ok; else ++wrong;
if (branch(10, 0, v1)) ++ok; else ++wrong;
if (branch(11, 0, v1)) ++ok; else ++wrong;
if (branch(12, 0, v1)) ++ok; else ++wrong;
if (branch(13, 0, v1)) ++ok; else ++wrong;
if (branch(14, 0, v1)) ++ok; else ++wrong;
if (branch(15, 0, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 16)
printf("FAILED\n");
else
printf("OK\n");
}
void
icm_value_0(void)
{
int wrong, ok;
unsigned v1;
printf("Test #2 mask == 0xF, value == 0 --> cc == 0\n");
v1 = 0;
wrong = ok = 0;
if (branch(0, 15, v1)) ++wrong; else ++ok;
if (branch(1, 15, v1)) ++wrong; else ++ok;
if (branch(2, 15, v1)) ++wrong; else ++ok;
if (branch(3, 15, v1)) ++wrong; else ++ok;
if (branch(4, 15, v1)) ++wrong; else ++ok;
if (branch(5, 15, v1)) ++wrong; else ++ok;
if (branch(6, 15, v1)) ++wrong; else ++ok;
if (branch(7, 15, v1)) ++wrong; else ++ok;
if (branch(8, 15, v1)) ++ok; else ++wrong;
if (branch(9, 15, v1)) ++ok; else ++wrong;
if (branch(10, 15, v1)) ++ok; else ++wrong;
if (branch(11, 15, v1)) ++ok; else ++wrong;
if (branch(12, 15, v1)) ++ok; else ++wrong;
if (branch(13, 15, v1)) ++ok; else ++wrong;
if (branch(14, 15, v1)) ++ok; else ++wrong;
if (branch(15, 15, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 16)
printf("FAILED\n");
else
printf("OK\n");
}
/* loads one byte */
void
icm_one_byte_msb_set(void)
{
int wrong, ok;
unsigned v1;
printf("Test #3 load one byte, msb set --> cc == 1\n");
v1 = 0x80000000;
wrong = ok = 0;
if (branch(0, 8, v1)) ++wrong; else ++ok;
if (branch(1, 8, v1)) ++wrong; else ++ok;
if (branch(2, 8, v1)) ++wrong; else ++ok;
if (branch(3, 8, v1)) ++wrong; else ++ok;
if (branch(4, 8, v1)) ++ok; else ++wrong;
if (branch(5, 8, v1)) ++ok; else ++wrong;
if (branch(6, 8, v1)) ++ok; else ++wrong;
if (branch(7, 8, v1)) ++ok; else ++wrong;
if (branch(8, 8, v1)) ++wrong; else ++ok;
if (branch(9, 8, v1)) ++wrong; else ++ok;
if (branch(10, 8, v1)) ++wrong; else ++ok;
if (branch(11, 8, v1)) ++wrong; else ++ok;
if (branch(12, 8, v1)) ++ok; else ++wrong;
if (branch(13, 8, v1)) ++ok; else ++wrong;
if (branch(14, 8, v1)) ++ok; else ++wrong;
if (branch(15, 8, v1)) ++ok; else ++wrong;
if (branch(0, 4, v1)) ++wrong; else ++ok;
if (branch(1, 4, v1)) ++wrong; else ++ok;
if (branch(2, 4, v1)) ++wrong; else ++ok;
if (branch(3, 4, v1)) ++wrong; else ++ok;
if (branch(4, 4, v1)) ++ok; else ++wrong;
if (branch(5, 4, v1)) ++ok; else ++wrong;
if (branch(6, 4, v1)) ++ok; else ++wrong;
if (branch(7, 4, v1)) ++ok; else ++wrong;
if (branch(8, 4, v1)) ++wrong; else ++ok;
if (branch(9, 4, v1)) ++wrong; else ++ok;
if (branch(10, 4, v1)) ++wrong; else ++ok;
if (branch(11, 4, v1)) ++wrong; else ++ok;
if (branch(12, 4, v1)) ++ok; else ++wrong;
if (branch(13, 4, v1)) ++ok; else ++wrong;
if (branch(14, 4, v1)) ++ok; else ++wrong;
if (branch(15, 4, v1)) ++ok; else ++wrong;
if (branch(0, 2, v1)) ++wrong; else ++ok;
if (branch(1, 2, v1)) ++wrong; else ++ok;
if (branch(2, 2, v1)) ++wrong; else ++ok;
if (branch(3, 2, v1)) ++wrong; else ++ok;
if (branch(4, 2, v1)) ++ok; else ++wrong;
if (branch(5, 2, v1)) ++ok; else ++wrong;
if (branch(6, 2, v1)) ++ok; else ++wrong;
if (branch(7, 2, v1)) ++ok; else ++wrong;
if (branch(8, 2, v1)) ++wrong; else ++ok;
if (branch(9, 2, v1)) ++wrong; else ++ok;
if (branch(10, 2, v1)) ++wrong; else ++ok;
if (branch(11, 2, v1)) ++wrong; else ++ok;
if (branch(12, 2, v1)) ++ok; else ++wrong;
if (branch(13, 2, v1)) ++ok; else ++wrong;
if (branch(14, 2, v1)) ++ok; else ++wrong;
if (branch(15, 2, v1)) ++ok; else ++wrong;
if (branch(0, 1, v1)) ++wrong; else ++ok;
if (branch(1, 1, v1)) ++wrong; else ++ok;
if (branch(2, 1, v1)) ++wrong; else ++ok;
if (branch(3, 1, v1)) ++wrong; else ++ok;
if (branch(4, 1, v1)) ++ok; else ++wrong;
if (branch(5, 1, v1)) ++ok; else ++wrong;
if (branch(6, 1, v1)) ++ok; else ++wrong;
if (branch(7, 1, v1)) ++ok; else ++wrong;
if (branch(8, 1, v1)) ++wrong; else ++ok;
if (branch(9, 1, v1)) ++wrong; else ++ok;
if (branch(10, 1, v1)) ++wrong; else ++ok;
if (branch(11, 1, v1)) ++wrong; else ++ok;
if (branch(12, 1, v1)) ++ok; else ++wrong;
if (branch(13, 1, v1)) ++ok; else ++wrong;
if (branch(14, 1, v1)) ++ok; else ++wrong;
if (branch(15, 1, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 64)
printf("FAILED\n");
else
printf("OK\n");
}
/* loads two bytes */
void
icm_two_bytes_msb_set(void)
{
int wrong, ok;
unsigned v1;
printf("Test #4 load two bytes, msb set --> cc == 1\n");
v1 = 0x80000000;
wrong = ok = 0;
if (branch(0, 12, v1)) ++wrong; else ++ok;
if (branch(1, 12, v1)) ++wrong; else ++ok;
if (branch(2, 12, v1)) ++wrong; else ++ok;
if (branch(3, 12, v1)) ++wrong; else ++ok;
if (branch(4, 12, v1)) ++ok; else ++wrong;
if (branch(5, 12, v1)) ++ok; else ++wrong;
if (branch(6, 12, v1)) ++ok; else ++wrong;
if (branch(7, 12, v1)) ++ok; else ++wrong;
if (branch(8, 12, v1)) ++wrong; else ++ok;
if (branch(9, 12, v1)) ++wrong; else ++ok;
if (branch(10, 12, v1)) ++wrong; else ++ok;
if (branch(11, 12, v1)) ++wrong; else ++ok;
if (branch(12, 12, v1)) ++ok; else ++wrong;
if (branch(13, 12, v1)) ++ok; else ++wrong;
if (branch(14, 12, v1)) ++ok; else ++wrong;
if (branch(15, 12, v1)) ++ok; else ++wrong;
if (branch(0, 10, v1)) ++wrong; else ++ok;
if (branch(1, 10, v1)) ++wrong; else ++ok;
if (branch(2, 10, v1)) ++wrong; else ++ok;
if (branch(3, 10, v1)) ++wrong; else ++ok;
if (branch(4, 10, v1)) ++ok; else ++wrong;
if (branch(5, 10, v1)) ++ok; else ++wrong;
if (branch(6, 10, v1)) ++ok; else ++wrong;
if (branch(7, 10, v1)) ++ok; else ++wrong;
if (branch(8, 10, v1)) ++wrong; else ++ok;
if (branch(9, 10, v1)) ++wrong; else ++ok;
if (branch(10, 10, v1)) ++wrong; else ++ok;
if (branch(11, 10, v1)) ++wrong; else ++ok;
if (branch(12, 10, v1)) ++ok; else ++wrong;
if (branch(13, 10, v1)) ++ok; else ++wrong;
if (branch(14, 10, v1)) ++ok; else ++wrong;
if (branch(15, 10, v1)) ++ok; else ++wrong;
if (branch(0, 9, v1)) ++wrong; else ++ok;
if (branch(1, 9, v1)) ++wrong; else ++ok;
if (branch(2, 9, v1)) ++wrong; else ++ok;
if (branch(3, 9, v1)) ++wrong; else ++ok;
if (branch(4, 9, v1)) ++ok; else ++wrong;
if (branch(5, 9, v1)) ++ok; else ++wrong;
if (branch(6, 9, v1)) ++ok; else ++wrong;
if (branch(7, 9, v1)) ++ok; else ++wrong;
if (branch(8, 9, v1)) ++wrong; else ++ok;
if (branch(9, 9, v1)) ++wrong; else ++ok;
if (branch(10, 9, v1)) ++wrong; else ++ok;
if (branch(11, 9, v1)) ++wrong; else ++ok;
if (branch(12, 9, v1)) ++ok; else ++wrong;
if (branch(13, 9, v1)) ++ok; else ++wrong;
if (branch(14, 9, v1)) ++ok; else ++wrong;
if (branch(15, 9, v1)) ++ok; else ++wrong;
if (branch(0, 6, v1)) ++wrong; else ++ok;
if (branch(1, 6, v1)) ++wrong; else ++ok;
if (branch(2, 6, v1)) ++wrong; else ++ok;
if (branch(3, 6, v1)) ++wrong; else ++ok;
if (branch(4, 6, v1)) ++ok; else ++wrong;
if (branch(5, 6, v1)) ++ok; else ++wrong;
if (branch(6, 6, v1)) ++ok; else ++wrong;
if (branch(7, 6, v1)) ++ok; else ++wrong;
if (branch(8, 6, v1)) ++wrong; else ++ok;
if (branch(9, 6, v1)) ++wrong; else ++ok;
if (branch(10, 6, v1)) ++wrong; else ++ok;
if (branch(11, 6, v1)) ++wrong; else ++ok;
if (branch(12, 6, v1)) ++ok; else ++wrong;
if (branch(13, 6, v1)) ++ok; else ++wrong;
if (branch(14, 6, v1)) ++ok; else ++wrong;
if (branch(15, 6, v1)) ++ok; else ++wrong;
if (branch(0, 5, v1)) ++wrong; else ++ok;
if (branch(1, 5, v1)) ++wrong; else ++ok;
if (branch(2, 5, v1)) ++wrong; else ++ok;
if (branch(3, 5, v1)) ++wrong; else ++ok;
if (branch(4, 5, v1)) ++ok; else ++wrong;
if (branch(5, 5, v1)) ++ok; else ++wrong;
if (branch(6, 5, v1)) ++ok; else ++wrong;
if (branch(7, 5, v1)) ++ok; else ++wrong;
if (branch(8, 5, v1)) ++wrong; else ++ok;
if (branch(9, 5, v1)) ++wrong; else ++ok;
if (branch(10, 5, v1)) ++wrong; else ++ok;
if (branch(11, 5, v1)) ++wrong; else ++ok;
if (branch(12, 5, v1)) ++ok; else ++wrong;
if (branch(13, 5, v1)) ++ok; else ++wrong;
if (branch(14, 5, v1)) ++ok; else ++wrong;
if (branch(15, 5, v1)) ++ok; else ++wrong;
if (branch(0, 3, v1)) ++wrong; else ++ok;
if (branch(1, 3, v1)) ++wrong; else ++ok;
if (branch(2, 3, v1)) ++wrong; else ++ok;
if (branch(3, 3, v1)) ++wrong; else ++ok;
if (branch(4, 3, v1)) ++ok; else ++wrong;
if (branch(5, 3, v1)) ++ok; else ++wrong;
if (branch(6, 3, v1)) ++ok; else ++wrong;
if (branch(7, 3, v1)) ++ok; else ++wrong;
if (branch(8, 3, v1)) ++wrong; else ++ok;
if (branch(9, 3, v1)) ++wrong; else ++ok;
if (branch(10, 3, v1)) ++wrong; else ++ok;
if (branch(11, 3, v1)) ++wrong; else ++ok;
if (branch(12, 3, v1)) ++ok; else ++wrong;
if (branch(13, 3, v1)) ++ok; else ++wrong;
if (branch(14, 3, v1)) ++ok; else ++wrong;
if (branch(15, 3, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 96)
printf("FAILED\n");
else
printf("OK\n");
}
/* loads three bytes */
void
icm_three_bytes_msb_set(void)
{
int wrong, ok;
unsigned v1;
printf("Test #5 load three bytes, msb set --> cc == 1\n");
v1 = 0x80000000;
wrong = ok = 0;
if (branch(0, 14, v1)) ++wrong; else ++ok;
if (branch(1, 14, v1)) ++wrong; else ++ok;
if (branch(2, 14, v1)) ++wrong; else ++ok;
if (branch(3, 14, v1)) ++wrong; else ++ok;
if (branch(4, 14, v1)) ++ok; else ++wrong;
if (branch(5, 14, v1)) ++ok; else ++wrong;
if (branch(6, 14, v1)) ++ok; else ++wrong;
if (branch(7, 14, v1)) ++ok; else ++wrong;
if (branch(8, 14, v1)) ++wrong; else ++ok;
if (branch(9, 14, v1)) ++wrong; else ++ok;
if (branch(10, 14, v1)) ++wrong; else ++ok;
if (branch(11, 14, v1)) ++wrong; else ++ok;
if (branch(12, 14, v1)) ++ok; else ++wrong;
if (branch(13, 14, v1)) ++ok; else ++wrong;
if (branch(14, 14, v1)) ++ok; else ++wrong;
if (branch(15, 14, v1)) ++ok; else ++wrong;
if (branch(0, 13, v1)) ++wrong; else ++ok;
if (branch(1, 13, v1)) ++wrong; else ++ok;
if (branch(2, 13, v1)) ++wrong; else ++ok;
if (branch(3, 13, v1)) ++wrong; else ++ok;
if (branch(4, 13, v1)) ++ok; else ++wrong;
if (branch(5, 13, v1)) ++ok; else ++wrong;
if (branch(6, 13, v1)) ++ok; else ++wrong;
if (branch(7, 13, v1)) ++ok; else ++wrong;
if (branch(8, 13, v1)) ++wrong; else ++ok;
if (branch(9, 13, v1)) ++wrong; else ++ok;
if (branch(10, 13, v1)) ++wrong; else ++ok;
if (branch(11, 13, v1)) ++wrong; else ++ok;
if (branch(12, 13, v1)) ++ok; else ++wrong;
if (branch(13, 13, v1)) ++ok; else ++wrong;
if (branch(14, 13, v1)) ++ok; else ++wrong;
if (branch(15, 13, v1)) ++ok; else ++wrong;
if (branch(0, 11, v1)) ++wrong; else ++ok;
if (branch(1, 11, v1)) ++wrong; else ++ok;
if (branch(2, 11, v1)) ++wrong; else ++ok;
if (branch(3, 11, v1)) ++wrong; else ++ok;
if (branch(4, 11, v1)) ++ok; else ++wrong;
if (branch(5, 11, v1)) ++ok; else ++wrong;
if (branch(6, 11, v1)) ++ok; else ++wrong;
if (branch(7, 11, v1)) ++ok; else ++wrong;
if (branch(8, 11, v1)) ++wrong; else ++ok;
if (branch(9, 11, v1)) ++wrong; else ++ok;
if (branch(10, 11, v1)) ++wrong; else ++ok;
if (branch(11, 11, v1)) ++wrong; else ++ok;
if (branch(12, 11, v1)) ++ok; else ++wrong;
if (branch(13, 11, v1)) ++ok; else ++wrong;
if (branch(14, 11, v1)) ++ok; else ++wrong;
if (branch(15, 11, v1)) ++ok; else ++wrong;
if (branch(0, 7, v1)) ++wrong; else ++ok;
if (branch(1, 7, v1)) ++wrong; else ++ok;
if (branch(2, 7, v1)) ++wrong; else ++ok;
if (branch(3, 7, v1)) ++wrong; else ++ok;
if (branch(4, 7, v1)) ++ok; else ++wrong;
if (branch(5, 7, v1)) ++ok; else ++wrong;
if (branch(6, 7, v1)) ++ok; else ++wrong;
if (branch(7, 7, v1)) ++ok; else ++wrong;
if (branch(8, 7, v1)) ++wrong; else ++ok;
if (branch(9, 7, v1)) ++wrong; else ++ok;
if (branch(10, 7, v1)) ++wrong; else ++ok;
if (branch(11, 7, v1)) ++wrong; else ++ok;
if (branch(12, 7, v1)) ++ok; else ++wrong;
if (branch(13, 7, v1)) ++ok; else ++wrong;
if (branch(14, 7, v1)) ++ok; else ++wrong;
if (branch(15, 7, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 64)
printf("FAILED\n");
else
printf("OK\n");
}
/* loads four bytes */
void
icm_four_bytes_msb_set(void)
{
int wrong, ok;
unsigned v1;
printf("Test #6 load four bytes, msb set --> cc == 1\n");
v1 = 0x80000000;
wrong = ok = 0;
if (branch(0, 15, v1)) ++wrong; else ++ok;
if (branch(1, 15, v1)) ++wrong; else ++ok;
if (branch(2, 15, v1)) ++wrong; else ++ok;
if (branch(3, 15, v1)) ++wrong; else ++ok;
if (branch(4, 15, v1)) ++ok; else ++wrong;
if (branch(5, 15, v1)) ++ok; else ++wrong;
if (branch(6, 15, v1)) ++ok; else ++wrong;
if (branch(7, 15, v1)) ++ok; else ++wrong;
if (branch(8, 15, v1)) ++wrong; else ++ok;
if (branch(9, 15, v1)) ++wrong; else ++ok;
if (branch(10, 15, v1)) ++wrong; else ++ok;
if (branch(11, 15, v1)) ++wrong; else ++ok;
if (branch(12, 15, v1)) ++ok; else ++wrong;
if (branch(13, 15, v1)) ++ok; else ++wrong;
if (branch(14, 15, v1)) ++ok; else ++wrong;
if (branch(15, 15, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 16)
printf("FAILED\n");
else
printf("OK\n");
}
/* loads one byte */
void
icm_one_byte_msb_not_set(void)
{
int wrong, ok, v1;
printf("Test #7 load one byte, msb not set --> cc == 2\n");
v1 = 0x7FFFFFFF;
wrong = ok = 0;
if (branch(0, 8, v1)) ++wrong; else ++ok;
if (branch(1, 8, v1)) ++wrong; else ++ok;
if (branch(2, 8, v1)) ++ok; else ++wrong;
if (branch(3, 8, v1)) ++ok; else ++wrong;
if (branch(4, 8, v1)) ++wrong; else ++ok;
if (branch(5, 8, v1)) ++wrong; else ++ok;
if (branch(6, 8, v1)) ++ok; else ++wrong;
if (branch(7, 8, v1)) ++ok; else ++wrong;
if (branch(8, 8, v1)) ++wrong; else ++ok;
if (branch(9, 8, v1)) ++wrong; else ++ok;
if (branch(10, 8, v1)) ++ok; else ++wrong;
if (branch(11, 8, v1)) ++ok; else ++wrong;
if (branch(12, 8, v1)) ++wrong; else ++ok;
if (branch(13, 8, v1)) ++wrong; else ++ok;
if (branch(14, 8, v1)) ++ok; else ++wrong;
if (branch(15, 8, v1)) ++ok; else ++wrong;
if (branch(0, 4, v1)) ++wrong; else ++ok;
if (branch(1, 4, v1)) ++wrong; else ++ok;
if (branch(2, 4, v1)) ++ok; else ++wrong;
if (branch(3, 4, v1)) ++ok; else ++wrong;
if (branch(4, 4, v1)) ++wrong; else ++ok;
if (branch(5, 4, v1)) ++wrong; else ++ok;
if (branch(6, 4, v1)) ++ok; else ++wrong;
if (branch(7, 4, v1)) ++ok; else ++wrong;
if (branch(8, 4, v1)) ++wrong; else ++ok;
if (branch(9, 4, v1)) ++wrong; else ++ok;
if (branch(10, 4, v1)) ++ok; else ++wrong;
if (branch(11, 4, v1)) ++ok; else ++wrong;
if (branch(12, 4, v1)) ++wrong; else ++ok;
if (branch(13, 4, v1)) ++wrong; else ++ok;
if (branch(14, 4, v1)) ++ok; else ++wrong;
if (branch(15, 4, v1)) ++ok; else ++wrong;
if (branch(0, 2, v1)) ++wrong; else ++ok;
if (branch(1, 2, v1)) ++wrong; else ++ok;
if (branch(2, 2, v1)) ++ok; else ++wrong;
if (branch(3, 2, v1)) ++ok; else ++wrong;
if (branch(4, 2, v1)) ++wrong; else ++ok;
if (branch(5, 2, v1)) ++wrong; else ++ok;
if (branch(6, 2, v1)) ++ok; else ++wrong;
if (branch(7, 2, v1)) ++ok; else ++wrong;
if (branch(8, 2, v1)) ++wrong; else ++ok;
if (branch(9, 2, v1)) ++wrong; else ++ok;
if (branch(10, 2, v1)) ++ok; else ++wrong;
if (branch(11, 2, v1)) ++ok; else ++wrong;
if (branch(12, 2, v1)) ++wrong; else ++ok;
if (branch(13, 2, v1)) ++wrong; else ++ok;
if (branch(14, 2, v1)) ++ok; else ++wrong;
if (branch(15, 2, v1)) ++ok; else ++wrong;
if (branch(0, 1, v1)) ++wrong; else ++ok;
if (branch(1, 1, v1)) ++wrong; else ++ok;
if (branch(2, 1, v1)) ++ok; else ++wrong;
if (branch(3, 1, v1)) ++ok; else ++wrong;
if (branch(4, 1, v1)) ++wrong; else ++ok;
if (branch(5, 1, v1)) ++wrong; else ++ok;
if (branch(6, 1, v1)) ++ok; else ++wrong;
if (branch(7, 1, v1)) ++ok; else ++wrong;
if (branch(8, 1, v1)) ++wrong; else ++ok;
if (branch(9, 1, v1)) ++wrong; else ++ok;
if (branch(10, 1, v1)) ++ok; else ++wrong;
if (branch(11, 1, v1)) ++ok; else ++wrong;
if (branch(12, 1, v1)) ++wrong; else ++ok;
if (branch(13, 1, v1)) ++wrong; else ++ok;
if (branch(14, 1, v1)) ++ok; else ++wrong;
if (branch(15, 1, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 64)
printf("FAILED\n");
else
printf("OK\n");
}
/* loads two bytes */
void
icm_two_bytes_msb_not_set(void)
{
int wrong, ok;
unsigned v1;
printf("Test #8 load two bytes, msb not set --> cc == 2\n");
v1 = 0x7FFFFFFF;
wrong = ok = 0;
if (branch(0, 12, v1)) ++wrong; else ++ok;
if (branch(1, 12, v1)) ++wrong; else ++ok;
if (branch(2, 12, v1)) ++ok; else ++wrong;
if (branch(3, 12, v1)) ++ok; else ++wrong;
if (branch(4, 12, v1)) ++wrong; else ++ok;
if (branch(5, 12, v1)) ++wrong; else ++ok;
if (branch(6, 12, v1)) ++ok; else ++wrong;
if (branch(7, 12, v1)) ++ok; else ++wrong;
if (branch(8, 12, v1)) ++wrong; else ++ok;
if (branch(9, 12, v1)) ++wrong; else ++ok;
if (branch(10, 12, v1)) ++ok; else ++wrong;
if (branch(11, 12, v1)) ++ok; else ++wrong;
if (branch(12, 12, v1)) ++wrong; else ++ok;
if (branch(13, 12, v1)) ++wrong; else ++ok;
if (branch(14, 12, v1)) ++ok; else ++wrong;
if (branch(15, 12, v1)) ++ok; else ++wrong;
if (branch(0, 10, v1)) ++wrong; else ++ok;
if (branch(1, 10, v1)) ++wrong; else ++ok;
if (branch(2, 10, v1)) ++ok; else ++wrong;
if (branch(3, 10, v1)) ++ok; else ++wrong;
if (branch(4, 10, v1)) ++wrong; else ++ok;
if (branch(5, 10, v1)) ++wrong; else ++ok;
if (branch(6, 10, v1)) ++ok; else ++wrong;
if (branch(7, 10, v1)) ++ok; else ++wrong;
if (branch(8, 10, v1)) ++wrong; else ++ok;
if (branch(9, 10, v1)) ++wrong; else ++ok;
if (branch(10, 10, v1)) ++ok; else ++wrong;
if (branch(11, 10, v1)) ++ok; else ++wrong;
if (branch(12, 10, v1)) ++wrong; else ++ok;
if (branch(13, 10, v1)) ++wrong; else ++ok;
if (branch(14, 10, v1)) ++ok; else ++wrong;
if (branch(15, 10, v1)) ++ok; else ++wrong;
if (branch(0, 9, v1)) ++wrong; else ++ok;
if (branch(1, 9, v1)) ++wrong; else ++ok;
if (branch(2, 9, v1)) ++ok; else ++wrong;
if (branch(3, 9, v1)) ++ok; else ++wrong;
if (branch(4, 9, v1)) ++wrong; else ++ok;
if (branch(5, 9, v1)) ++wrong; else ++ok;
if (branch(6, 9, v1)) ++ok; else ++wrong;
if (branch(7, 9, v1)) ++ok; else ++wrong;
if (branch(8, 9, v1)) ++wrong; else ++ok;
if (branch(9, 9, v1)) ++wrong; else ++ok;
if (branch(10, 9, v1)) ++ok; else ++wrong;
if (branch(11, 9, v1)) ++ok; else ++wrong;
if (branch(12, 9, v1)) ++wrong; else ++ok;
if (branch(13, 9, v1)) ++wrong; else ++ok;
if (branch(14, 9, v1)) ++ok; else ++wrong;
if (branch(15, 9, v1)) ++ok; else ++wrong;
if (branch(0, 6, v1)) ++wrong; else ++ok;
if (branch(1, 6, v1)) ++wrong; else ++ok;
if (branch(2, 6, v1)) ++ok; else ++wrong;
if (branch(3, 6, v1)) ++ok; else ++wrong;
if (branch(4, 6, v1)) ++wrong; else ++ok;
if (branch(5, 6, v1)) ++wrong; else ++ok;
if (branch(6, 6, v1)) ++ok; else ++wrong;
if (branch(7, 6, v1)) ++ok; else ++wrong;
if (branch(8, 6, v1)) ++wrong; else ++ok;
if (branch(9, 6, v1)) ++wrong; else ++ok;
if (branch(10, 6, v1)) ++ok; else ++wrong;
if (branch(11, 6, v1)) ++ok; else ++wrong;
if (branch(12, 6, v1)) ++wrong; else ++ok;
if (branch(13, 6, v1)) ++wrong; else ++ok;
if (branch(14, 6, v1)) ++ok; else ++wrong;
if (branch(15, 6, v1)) ++ok; else ++wrong;
if (branch(0, 5, v1)) ++wrong; else ++ok;
if (branch(1, 5, v1)) ++wrong; else ++ok;
if (branch(2, 5, v1)) ++ok; else ++wrong;
if (branch(3, 5, v1)) ++ok; else ++wrong;
if (branch(4, 5, v1)) ++wrong; else ++ok;
if (branch(5, 5, v1)) ++wrong; else ++ok;
if (branch(6, 5, v1)) ++ok; else ++wrong;
if (branch(7, 5, v1)) ++ok; else ++wrong;
if (branch(8, 5, v1)) ++wrong; else ++ok;
if (branch(9, 5, v1)) ++wrong; else ++ok;
if (branch(10, 5, v1)) ++ok; else ++wrong;
if (branch(11, 5, v1)) ++ok; else ++wrong;
if (branch(12, 5, v1)) ++wrong; else ++ok;
if (branch(13, 5, v1)) ++wrong; else ++ok;
if (branch(14, 5, v1)) ++ok; else ++wrong;
if (branch(15, 5, v1)) ++ok; else ++wrong;
if (branch(0, 3, v1)) ++wrong; else ++ok;
if (branch(1, 3, v1)) ++wrong; else ++ok;
if (branch(2, 3, v1)) ++ok; else ++wrong;
if (branch(3, 3, v1)) ++ok; else ++wrong;
if (branch(4, 3, v1)) ++wrong; else ++ok;
if (branch(5, 3, v1)) ++wrong; else ++ok;
if (branch(6, 3, v1)) ++ok; else ++wrong;
if (branch(7, 3, v1)) ++ok; else ++wrong;
if (branch(8, 3, v1)) ++wrong; else ++ok;
if (branch(9, 3, v1)) ++wrong; else ++ok;
if (branch(10, 3, v1)) ++ok; else ++wrong;
if (branch(11, 3, v1)) ++ok; else ++wrong;
if (branch(12, 3, v1)) ++wrong; else ++ok;
if (branch(13, 3, v1)) ++wrong; else ++ok;
if (branch(14, 3, v1)) ++ok; else ++wrong;
if (branch(15, 3, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 96)
printf("FAILED\n");
else
printf("OK\n");
}
/* loads three bytes */
void
icm_three_bytes_msb_not_set(void)
{
int wrong, ok;
unsigned v1;
printf("Test #9 load three bytes, msb not set --> cc == 2\n");
v1 = 0x7FFFFFFF;
wrong = ok = 0;
if (branch(0, 14, v1)) ++wrong; else ++ok;
if (branch(1, 14, v1)) ++wrong; else ++ok;
if (branch(2, 14, v1)) ++ok; else ++wrong;
if (branch(3, 14, v1)) ++ok; else ++wrong;
if (branch(4, 14, v1)) ++wrong; else ++ok;
if (branch(5, 14, v1)) ++wrong; else ++ok;
if (branch(6, 14, v1)) ++ok; else ++wrong;
if (branch(7, 14, v1)) ++ok; else ++wrong;
if (branch(8, 14, v1)) ++wrong; else ++ok;
if (branch(9, 14, v1)) ++wrong; else ++ok;
if (branch(10, 14, v1)) ++ok; else ++wrong;
if (branch(11, 14, v1)) ++ok; else ++wrong;
if (branch(12, 14, v1)) ++wrong; else ++ok;
if (branch(13, 14, v1)) ++wrong; else ++ok;
if (branch(14, 14, v1)) ++ok; else ++wrong;
if (branch(15, 14, v1)) ++ok; else ++wrong;
if (branch(0, 13, v1)) ++wrong; else ++ok;
if (branch(1, 13, v1)) ++wrong; else ++ok;
if (branch(2, 13, v1)) ++ok; else ++wrong;
if (branch(3, 13, v1)) ++ok; else ++wrong;
if (branch(4, 13, v1)) ++wrong; else ++ok;
if (branch(5, 13, v1)) ++wrong; else ++ok;
if (branch(6, 13, v1)) ++ok; else ++wrong;
if (branch(7, 13, v1)) ++ok; else ++wrong;
if (branch(8, 13, v1)) ++wrong; else ++ok;
if (branch(9, 13, v1)) ++wrong; else ++ok;
if (branch(10, 13, v1)) ++ok; else ++wrong;
if (branch(11, 13, v1)) ++ok; else ++wrong;
if (branch(12, 13, v1)) ++wrong; else ++ok;
if (branch(13, 13, v1)) ++wrong; else ++ok;
if (branch(14, 13, v1)) ++ok; else ++wrong;
if (branch(15, 13, v1)) ++ok; else ++wrong;
if (branch(0, 11, v1)) ++wrong; else ++ok;
if (branch(1, 11, v1)) ++wrong; else ++ok;
if (branch(2, 11, v1)) ++ok; else ++wrong;
if (branch(3, 11, v1)) ++ok; else ++wrong;
if (branch(4, 11, v1)) ++wrong; else ++ok;
if (branch(5, 11, v1)) ++wrong; else ++ok;
if (branch(6, 11, v1)) ++ok; else ++wrong;
if (branch(7, 11, v1)) ++ok; else ++wrong;
if (branch(8, 11, v1)) ++wrong; else ++ok;
if (branch(9, 11, v1)) ++wrong; else ++ok;
if (branch(10, 11, v1)) ++ok; else ++wrong;
if (branch(11, 11, v1)) ++ok; else ++wrong;
if (branch(12, 11, v1)) ++wrong; else ++ok;
if (branch(13, 11, v1)) ++wrong; else ++ok;
if (branch(14, 11, v1)) ++ok; else ++wrong;
if (branch(15, 11, v1)) ++ok; else ++wrong;
if (branch(0, 7, v1)) ++wrong; else ++ok;
if (branch(1, 7, v1)) ++wrong; else ++ok;
if (branch(2, 7, v1)) ++ok; else ++wrong;
if (branch(3, 7, v1)) ++ok; else ++wrong;
if (branch(4, 7, v1)) ++wrong; else ++ok;
if (branch(5, 7, v1)) ++wrong; else ++ok;
if (branch(6, 7, v1)) ++ok; else ++wrong;
if (branch(7, 7, v1)) ++ok; else ++wrong;
if (branch(8, 7, v1)) ++wrong; else ++ok;
if (branch(9, 7, v1)) ++wrong; else ++ok;
if (branch(10, 7, v1)) ++ok; else ++wrong;
if (branch(11, 7, v1)) ++ok; else ++wrong;
if (branch(12, 7, v1)) ++wrong; else ++ok;
if (branch(13, 7, v1)) ++wrong; else ++ok;
if (branch(14, 7, v1)) ++ok; else ++wrong;
if (branch(15, 7, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 64)
printf("FAILED\n");
else
printf("OK\n");
}
/* loads four bytes */
void
icm_four_bytes_msb_not_set(void)
{
int wrong, ok;
unsigned v1;
printf("Test #10 load four bytes, msb not set --> cc == 2\n");
v1 = 0x7FFFFFFF;
wrong = ok = 0;
if (branch(0, 15, v1)) ++wrong; else ++ok;
if (branch(1, 15, v1)) ++wrong; else ++ok;
if (branch(2, 15, v1)) ++ok; else ++wrong;
if (branch(3, 15, v1)) ++ok; else ++wrong;
if (branch(4, 15, v1)) ++wrong; else ++ok;
if (branch(5, 15, v1)) ++wrong; else ++ok;
if (branch(6, 15, v1)) ++ok; else ++wrong;
if (branch(7, 15, v1)) ++ok; else ++wrong;
if (branch(8, 15, v1)) ++wrong; else ++ok;
if (branch(9, 15, v1)) ++wrong; else ++ok;
if (branch(10, 15, v1)) ++ok; else ++wrong;
if (branch(11, 15, v1)) ++ok; else ++wrong;
if (branch(12, 15, v1)) ++wrong; else ++ok;
if (branch(13, 15, v1)) ++wrong; else ++ok;
if (branch(14, 15, v1)) ++ok; else ++wrong;
if (branch(15, 15, v1)) ++ok; else ++wrong;
if (wrong != 0 || ok != 16)
printf("FAILED\n");
else
printf("OK\n");
}
int main()
{
icm_mask_0();
icm_value_0();
icm_one_byte_msb_set();
icm_two_bytes_msb_set();
icm_three_bytes_msb_set();
icm_four_bytes_msb_set();
icm_one_byte_msb_not_set();
icm_two_bytes_msb_not_set();
icm_three_bytes_msb_not_set();
icm_four_bytes_msb_not_set();
return 0;
}