1*2a367db0SAleksandar Markovic /* 2*2a367db0SAleksandar Markovic * Test program for MSA instruction PCKEV.B 3*2a367db0SAleksandar Markovic * 4*2a367db0SAleksandar Markovic * Copyright (C) 2018 Wave Computing, Inc. 5*2a367db0SAleksandar Markovic * Copyright (C) 2018 Aleksandar Markovic <amarkovic@wavecomp.com> 6*2a367db0SAleksandar Markovic * 7*2a367db0SAleksandar Markovic * This program is free software: you can redistribute it and/or modify 8*2a367db0SAleksandar Markovic * it under the terms of the GNU General Public License as published by 9*2a367db0SAleksandar Markovic * the Free Software Foundation, either version 2 of the License, or 10*2a367db0SAleksandar Markovic * (at your option) any later version. 11*2a367db0SAleksandar Markovic *` 12*2a367db0SAleksandar Markovic * This program is distributed in the hope that it will be useful, 13*2a367db0SAleksandar Markovic * but WITHOUT ANY WARRANTY; without even the implied warranty of 14*2a367db0SAleksandar Markovic * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15*2a367db0SAleksandar Markovic * GNU General Public License for more details. 16*2a367db0SAleksandar Markovic * 17*2a367db0SAleksandar Markovic * You should have received a copy of the GNU General Public License 18*2a367db0SAleksandar Markovic * along with this program. If not, see <https://www.gnu.org/licenses/>. 19*2a367db0SAleksandar Markovic * 20*2a367db0SAleksandar Markovic */ 21*2a367db0SAleksandar Markovic 22*2a367db0SAleksandar Markovic #include <sys/time.h> 23*2a367db0SAleksandar Markovic #include <stdint.h> 24*2a367db0SAleksandar Markovic 25*2a367db0SAleksandar Markovic #include "../../../../include/wrappers_msa.h" 26*2a367db0SAleksandar Markovic #include "../../../../include/test_inputs.h" 27*2a367db0SAleksandar Markovic #include "../../../../include/test_utils.h" 28*2a367db0SAleksandar Markovic 29*2a367db0SAleksandar Markovic #define TEST_COUNT_TOTAL ( \ 30*2a367db0SAleksandar Markovic (PATTERN_INPUTS_SHORT_COUNT) * (PATTERN_INPUTS_SHORT_COUNT) + \ 31*2a367db0SAleksandar Markovic (RANDOM_INPUTS_SHORT_COUNT) * (RANDOM_INPUTS_SHORT_COUNT)) 32*2a367db0SAleksandar Markovic 33*2a367db0SAleksandar Markovic 34*2a367db0SAleksandar Markovic int32_t main(void) 35*2a367db0SAleksandar Markovic { 36*2a367db0SAleksandar Markovic char *instruction_name = "PCKEV.B"; 37*2a367db0SAleksandar Markovic int32_t ret; 38*2a367db0SAleksandar Markovic uint32_t i, j; 39*2a367db0SAleksandar Markovic struct timeval start, end; 40*2a367db0SAleksandar Markovic double elapsed_time; 41*2a367db0SAleksandar Markovic 42*2a367db0SAleksandar Markovic uint64_t b128_result[TEST_COUNT_TOTAL][2]; 43*2a367db0SAleksandar Markovic uint64_t b128_expect[TEST_COUNT_TOTAL][2] = { 44*2a367db0SAleksandar Markovic { 0xffffffffffffffffULL, 0xffffffffffffffffULL, }, /* 0 */ 45*2a367db0SAleksandar Markovic { 0x0000000000000000ULL, 0xffffffffffffffffULL, }, 46*2a367db0SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0xffffffffffffffffULL, }, 47*2a367db0SAleksandar Markovic { 0x5555555555555555ULL, 0xffffffffffffffffULL, }, 48*2a367db0SAleksandar Markovic { 0xccccccccccccccccULL, 0xffffffffffffffffULL, }, 49*2a367db0SAleksandar Markovic { 0x3333333333333333ULL, 0xffffffffffffffffULL, }, 50*2a367db0SAleksandar Markovic { 0xe3388ee38ee3388eULL, 0xffffffffffffffffULL, }, 51*2a367db0SAleksandar Markovic { 0x1cc7711c711cc771ULL, 0xffffffffffffffffULL, }, 52*2a367db0SAleksandar Markovic { 0xffffffffffffffffULL, 0x0000000000000000ULL, }, /* 8 */ 53*2a367db0SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 54*2a367db0SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0x0000000000000000ULL, }, 55*2a367db0SAleksandar Markovic { 0x5555555555555555ULL, 0x0000000000000000ULL, }, 56*2a367db0SAleksandar Markovic { 0xccccccccccccccccULL, 0x0000000000000000ULL, }, 57*2a367db0SAleksandar Markovic { 0x3333333333333333ULL, 0x0000000000000000ULL, }, 58*2a367db0SAleksandar Markovic { 0xe3388ee38ee3388eULL, 0x0000000000000000ULL, }, 59*2a367db0SAleksandar Markovic { 0x1cc7711c711cc771ULL, 0x0000000000000000ULL, }, 60*2a367db0SAleksandar Markovic { 0xffffffffffffffffULL, 0xaaaaaaaaaaaaaaaaULL, }, /* 16 */ 61*2a367db0SAleksandar Markovic { 0x0000000000000000ULL, 0xaaaaaaaaaaaaaaaaULL, }, 62*2a367db0SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0xaaaaaaaaaaaaaaaaULL, }, 63*2a367db0SAleksandar Markovic { 0x5555555555555555ULL, 0xaaaaaaaaaaaaaaaaULL, }, 64*2a367db0SAleksandar Markovic { 0xccccccccccccccccULL, 0xaaaaaaaaaaaaaaaaULL, }, 65*2a367db0SAleksandar Markovic { 0x3333333333333333ULL, 0xaaaaaaaaaaaaaaaaULL, }, 66*2a367db0SAleksandar Markovic { 0xe3388ee38ee3388eULL, 0xaaaaaaaaaaaaaaaaULL, }, 67*2a367db0SAleksandar Markovic { 0x1cc7711c711cc771ULL, 0xaaaaaaaaaaaaaaaaULL, }, 68*2a367db0SAleksandar Markovic { 0xffffffffffffffffULL, 0x5555555555555555ULL, }, /* 24 */ 69*2a367db0SAleksandar Markovic { 0x0000000000000000ULL, 0x5555555555555555ULL, }, 70*2a367db0SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0x5555555555555555ULL, }, 71*2a367db0SAleksandar Markovic { 0x5555555555555555ULL, 0x5555555555555555ULL, }, 72*2a367db0SAleksandar Markovic { 0xccccccccccccccccULL, 0x5555555555555555ULL, }, 73*2a367db0SAleksandar Markovic { 0x3333333333333333ULL, 0x5555555555555555ULL, }, 74*2a367db0SAleksandar Markovic { 0xe3388ee38ee3388eULL, 0x5555555555555555ULL, }, 75*2a367db0SAleksandar Markovic { 0x1cc7711c711cc771ULL, 0x5555555555555555ULL, }, 76*2a367db0SAleksandar Markovic { 0xffffffffffffffffULL, 0xccccccccccccccccULL, }, /* 32 */ 77*2a367db0SAleksandar Markovic { 0x0000000000000000ULL, 0xccccccccccccccccULL, }, 78*2a367db0SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0xccccccccccccccccULL, }, 79*2a367db0SAleksandar Markovic { 0x5555555555555555ULL, 0xccccccccccccccccULL, }, 80*2a367db0SAleksandar Markovic { 0xccccccccccccccccULL, 0xccccccccccccccccULL, }, 81*2a367db0SAleksandar Markovic { 0x3333333333333333ULL, 0xccccccccccccccccULL, }, 82*2a367db0SAleksandar Markovic { 0xe3388ee38ee3388eULL, 0xccccccccccccccccULL, }, 83*2a367db0SAleksandar Markovic { 0x1cc7711c711cc771ULL, 0xccccccccccccccccULL, }, 84*2a367db0SAleksandar Markovic { 0xffffffffffffffffULL, 0x3333333333333333ULL, }, /* 40 */ 85*2a367db0SAleksandar Markovic { 0x0000000000000000ULL, 0x3333333333333333ULL, }, 86*2a367db0SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0x3333333333333333ULL, }, 87*2a367db0SAleksandar Markovic { 0x5555555555555555ULL, 0x3333333333333333ULL, }, 88*2a367db0SAleksandar Markovic { 0xccccccccccccccccULL, 0x3333333333333333ULL, }, 89*2a367db0SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 90*2a367db0SAleksandar Markovic { 0xe3388ee38ee3388eULL, 0x3333333333333333ULL, }, 91*2a367db0SAleksandar Markovic { 0x1cc7711c711cc771ULL, 0x3333333333333333ULL, }, 92*2a367db0SAleksandar Markovic { 0xffffffffffffffffULL, 0xe3388ee38ee3388eULL, }, /* 48 */ 93*2a367db0SAleksandar Markovic { 0x0000000000000000ULL, 0xe3388ee38ee3388eULL, }, 94*2a367db0SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0xe3388ee38ee3388eULL, }, 95*2a367db0SAleksandar Markovic { 0x5555555555555555ULL, 0xe3388ee38ee3388eULL, }, 96*2a367db0SAleksandar Markovic { 0xccccccccccccccccULL, 0xe3388ee38ee3388eULL, }, 97*2a367db0SAleksandar Markovic { 0x3333333333333333ULL, 0xe3388ee38ee3388eULL, }, 98*2a367db0SAleksandar Markovic { 0xe3388ee38ee3388eULL, 0xe3388ee38ee3388eULL, }, 99*2a367db0SAleksandar Markovic { 0x1cc7711c711cc771ULL, 0xe3388ee38ee3388eULL, }, 100*2a367db0SAleksandar Markovic { 0xffffffffffffffffULL, 0x1cc7711c711cc771ULL, }, /* 56 */ 101*2a367db0SAleksandar Markovic { 0x0000000000000000ULL, 0x1cc7711c711cc771ULL, }, 102*2a367db0SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0x1cc7711c711cc771ULL, }, 103*2a367db0SAleksandar Markovic { 0x5555555555555555ULL, 0x1cc7711c711cc771ULL, }, 104*2a367db0SAleksandar Markovic { 0xccccccccccccccccULL, 0x1cc7711c711cc771ULL, }, 105*2a367db0SAleksandar Markovic { 0x3333333333333333ULL, 0x1cc7711c711cc771ULL, }, 106*2a367db0SAleksandar Markovic { 0xe3388ee38ee3388eULL, 0x1cc7711c711cc771ULL, }, 107*2a367db0SAleksandar Markovic { 0x1cc7711c711cc771ULL, 0x1cc7711c711cc771ULL, }, 108*2a367db0SAleksandar Markovic { 0x675e7b0c6acc6240ULL, 0x675e7b0c6acc6240ULL, }, /* 64 */ 109*2a367db0SAleksandar Markovic { 0xf71a3ffcbe639308ULL, 0x675e7b0c6acc6240ULL, }, 110*2a367db0SAleksandar Markovic { 0xd8ff2b145aaacf80ULL, 0x675e7b0c6acc6240ULL, }, 111*2a367db0SAleksandar Markovic { 0xf1d842a04f4d314eULL, 0x675e7b0c6acc6240ULL, }, 112*2a367db0SAleksandar Markovic { 0x675e7b0c6acc6240ULL, 0xf71a3ffcbe639308ULL, }, 113*2a367db0SAleksandar Markovic { 0xf71a3ffcbe639308ULL, 0xf71a3ffcbe639308ULL, }, 114*2a367db0SAleksandar Markovic { 0xd8ff2b145aaacf80ULL, 0xf71a3ffcbe639308ULL, }, 115*2a367db0SAleksandar Markovic { 0xf1d842a04f4d314eULL, 0xf71a3ffcbe639308ULL, }, 116*2a367db0SAleksandar Markovic { 0x675e7b0c6acc6240ULL, 0xd8ff2b145aaacf80ULL, }, /* 72 */ 117*2a367db0SAleksandar Markovic { 0xf71a3ffcbe639308ULL, 0xd8ff2b145aaacf80ULL, }, 118*2a367db0SAleksandar Markovic { 0xd8ff2b145aaacf80ULL, 0xd8ff2b145aaacf80ULL, }, 119*2a367db0SAleksandar Markovic { 0xf1d842a04f4d314eULL, 0xd8ff2b145aaacf80ULL, }, 120*2a367db0SAleksandar Markovic { 0x675e7b0c6acc6240ULL, 0xf1d842a04f4d314eULL, }, 121*2a367db0SAleksandar Markovic { 0xf71a3ffcbe639308ULL, 0xf1d842a04f4d314eULL, }, 122*2a367db0SAleksandar Markovic { 0xd8ff2b145aaacf80ULL, 0xf1d842a04f4d314eULL, }, 123*2a367db0SAleksandar Markovic { 0xf1d842a04f4d314eULL, 0xf1d842a04f4d314eULL, }, 124*2a367db0SAleksandar Markovic }; 125*2a367db0SAleksandar Markovic 126*2a367db0SAleksandar Markovic gettimeofday(&start, NULL); 127*2a367db0SAleksandar Markovic 128*2a367db0SAleksandar Markovic for (i = 0; i < PATTERN_INPUTS_SHORT_COUNT; i++) { 129*2a367db0SAleksandar Markovic for (j = 0; j < PATTERN_INPUTS_SHORT_COUNT; j++) { 130*2a367db0SAleksandar Markovic do_msa_PCKEV_B(b128_pattern[i], b128_pattern[j], 131*2a367db0SAleksandar Markovic b128_result[PATTERN_INPUTS_SHORT_COUNT * i + j]); 132*2a367db0SAleksandar Markovic } 133*2a367db0SAleksandar Markovic } 134*2a367db0SAleksandar Markovic 135*2a367db0SAleksandar Markovic for (i = 0; i < RANDOM_INPUTS_SHORT_COUNT; i++) { 136*2a367db0SAleksandar Markovic for (j = 0; j < RANDOM_INPUTS_SHORT_COUNT; j++) { 137*2a367db0SAleksandar Markovic do_msa_PCKEV_B(b128_random[i], b128_random[j], 138*2a367db0SAleksandar Markovic b128_result[((PATTERN_INPUTS_SHORT_COUNT) * 139*2a367db0SAleksandar Markovic (PATTERN_INPUTS_SHORT_COUNT)) + 140*2a367db0SAleksandar Markovic RANDOM_INPUTS_SHORT_COUNT * i + j]); 141*2a367db0SAleksandar Markovic } 142*2a367db0SAleksandar Markovic } 143*2a367db0SAleksandar Markovic 144*2a367db0SAleksandar Markovic gettimeofday(&end, NULL); 145*2a367db0SAleksandar Markovic 146*2a367db0SAleksandar Markovic elapsed_time = (end.tv_sec - start.tv_sec) * 1000.0; 147*2a367db0SAleksandar Markovic elapsed_time += (end.tv_usec - start.tv_usec) / 1000.0; 148*2a367db0SAleksandar Markovic 149*2a367db0SAleksandar Markovic ret = check_results(instruction_name, TEST_COUNT_TOTAL, elapsed_time, 150*2a367db0SAleksandar Markovic &b128_result[0][0], &b128_expect[0][0]); 151*2a367db0SAleksandar Markovic 152*2a367db0SAleksandar Markovic return ret; 153*2a367db0SAleksandar Markovic } 154