#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; }