| #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 0xffffffff\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; |
| } |