11e6bea79SAleksandar Markovic /* 21e6bea79SAleksandar Markovic * Test program for MSA instruction MIN_U.D 31e6bea79SAleksandar Markovic * 4dd8d6a2dSAleksandar Markovic * Copyright (C) 2019 Wave Computing, Inc. 5dd8d6a2dSAleksandar Markovic * Copyright (C) 2019 Aleksandar Markovic <amarkovic@wavecomp.com> 6750541c4SAleksandar Markovic * Copyright (C) 2019 RT-RK Computer Based Systems LLC 7750541c4SAleksandar Markovic * Copyright (C) 2019 Mateja Marjanovic <mateja.marjanovic@rt-rk.com> 81e6bea79SAleksandar Markovic * 91e6bea79SAleksandar Markovic * This program is free software: you can redistribute it and/or modify 101e6bea79SAleksandar Markovic * it under the terms of the GNU General Public License as published by 111e6bea79SAleksandar Markovic * the Free Software Foundation, either version 2 of the License, or 121e6bea79SAleksandar Markovic * (at your option) any later version. 131e6bea79SAleksandar Markovic * 141e6bea79SAleksandar Markovic * This program is distributed in the hope that it will be useful, 151e6bea79SAleksandar Markovic * but WITHOUT ANY WARRANTY; without even the implied warranty of 161e6bea79SAleksandar Markovic * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 171e6bea79SAleksandar Markovic * GNU General Public License for more details. 181e6bea79SAleksandar Markovic * 191e6bea79SAleksandar Markovic * You should have received a copy of the GNU General Public License 201e6bea79SAleksandar Markovic * along with this program. If not, see <https://www.gnu.org/licenses/>. 211e6bea79SAleksandar Markovic * 221e6bea79SAleksandar Markovic */ 231e6bea79SAleksandar Markovic 241e6bea79SAleksandar Markovic #include <sys/time.h> 251e6bea79SAleksandar Markovic #include <stdint.h> 261e6bea79SAleksandar Markovic 271e6bea79SAleksandar Markovic #include "../../../../include/wrappers_msa.h" 2881526dffSAleksandar Markovic #include "../../../../include/test_inputs_128.h" 2981526dffSAleksandar Markovic #include "../../../../include/test_utils_128.h" 301e6bea79SAleksandar Markovic 311e6bea79SAleksandar Markovic #define TEST_COUNT_TOTAL ( \ 321e6bea79SAleksandar Markovic (PATTERN_INPUTS_SHORT_COUNT) * (PATTERN_INPUTS_SHORT_COUNT) + \ 331e6bea79SAleksandar Markovic (RANDOM_INPUTS_SHORT_COUNT) * (RANDOM_INPUTS_SHORT_COUNT)) 341e6bea79SAleksandar Markovic 351e6bea79SAleksandar Markovic 361e6bea79SAleksandar Markovic int32_t main(void) 371e6bea79SAleksandar Markovic { 381e6bea79SAleksandar Markovic char *instruction_name = "MIN_U.D"; 391e6bea79SAleksandar Markovic int32_t ret; 401e6bea79SAleksandar Markovic uint32_t i, j; 411e6bea79SAleksandar Markovic struct timeval start, end; 421e6bea79SAleksandar Markovic double elapsed_time; 431e6bea79SAleksandar Markovic 441e6bea79SAleksandar Markovic uint64_t b128_result[TEST_COUNT_TOTAL][2]; 451e6bea79SAleksandar Markovic uint64_t b128_expect[TEST_COUNT_TOTAL][2] = { 461e6bea79SAleksandar Markovic { 0xffffffffffffffffULL, 0xffffffffffffffffULL, }, /* 0 */ 471e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 481e6bea79SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0xaaaaaaaaaaaaaaaaULL, }, 491e6bea79SAleksandar Markovic { 0x5555555555555555ULL, 0x5555555555555555ULL, }, 501e6bea79SAleksandar Markovic { 0xccccccccccccccccULL, 0xccccccccccccccccULL, }, 511e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 521e6bea79SAleksandar Markovic { 0xe38e38e38e38e38eULL, 0x38e38e38e38e38e3ULL, }, 531e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0xc71c71c71c71c71cULL, }, 541e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, /* 8 */ 551e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 561e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 571e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 581e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 591e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 601e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 611e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 621e6bea79SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0xaaaaaaaaaaaaaaaaULL, }, /* 16 */ 631e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 641e6bea79SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0xaaaaaaaaaaaaaaaaULL, }, 651e6bea79SAleksandar Markovic { 0x5555555555555555ULL, 0x5555555555555555ULL, }, 661e6bea79SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0xaaaaaaaaaaaaaaaaULL, }, 671e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 681e6bea79SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0x38e38e38e38e38e3ULL, }, 691e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0xaaaaaaaaaaaaaaaaULL, }, 701e6bea79SAleksandar Markovic { 0x5555555555555555ULL, 0x5555555555555555ULL, }, /* 24 */ 711e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 721e6bea79SAleksandar Markovic { 0x5555555555555555ULL, 0x5555555555555555ULL, }, 731e6bea79SAleksandar Markovic { 0x5555555555555555ULL, 0x5555555555555555ULL, }, 741e6bea79SAleksandar Markovic { 0x5555555555555555ULL, 0x5555555555555555ULL, }, 751e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 761e6bea79SAleksandar Markovic { 0x5555555555555555ULL, 0x38e38e38e38e38e3ULL, }, 771e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0x5555555555555555ULL, }, 781e6bea79SAleksandar Markovic { 0xccccccccccccccccULL, 0xccccccccccccccccULL, }, /* 32 */ 791e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 801e6bea79SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0xaaaaaaaaaaaaaaaaULL, }, 811e6bea79SAleksandar Markovic { 0x5555555555555555ULL, 0x5555555555555555ULL, }, 821e6bea79SAleksandar Markovic { 0xccccccccccccccccULL, 0xccccccccccccccccULL, }, 831e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 841e6bea79SAleksandar Markovic { 0xccccccccccccccccULL, 0x38e38e38e38e38e3ULL, }, 851e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0xc71c71c71c71c71cULL, }, 861e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, /* 40 */ 871e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 881e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 891e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 901e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 911e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 921e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 931e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0x3333333333333333ULL, }, 941e6bea79SAleksandar Markovic { 0xe38e38e38e38e38eULL, 0x38e38e38e38e38e3ULL, }, /* 48 */ 951e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 961e6bea79SAleksandar Markovic { 0xaaaaaaaaaaaaaaaaULL, 0x38e38e38e38e38e3ULL, }, 971e6bea79SAleksandar Markovic { 0x5555555555555555ULL, 0x38e38e38e38e38e3ULL, }, 981e6bea79SAleksandar Markovic { 0xccccccccccccccccULL, 0x38e38e38e38e38e3ULL, }, 991e6bea79SAleksandar Markovic { 0x3333333333333333ULL, 0x3333333333333333ULL, }, 1001e6bea79SAleksandar Markovic { 0xe38e38e38e38e38eULL, 0x38e38e38e38e38e3ULL, }, 1011e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0x38e38e38e38e38e3ULL, }, 1021e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0xc71c71c71c71c71cULL, }, /* 56 */ 1031e6bea79SAleksandar Markovic { 0x0000000000000000ULL, 0x0000000000000000ULL, }, 1041e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0xaaaaaaaaaaaaaaaaULL, }, 1051e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0x5555555555555555ULL, }, 1061e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0xc71c71c71c71c71cULL, }, 1071e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0x3333333333333333ULL, }, 1081e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0x38e38e38e38e38e3ULL, }, 1091e6bea79SAleksandar Markovic { 0x1c71c71c71c71c71ULL, 0xc71c71c71c71c71cULL, }, 1101e6bea79SAleksandar Markovic { 0x886ae6cc28625540ULL, 0x4b670b5efe7bb00cULL, }, /* 64 */ 1111e6bea79SAleksandar Markovic { 0x886ae6cc28625540ULL, 0x12f7bb1a153f52fcULL, }, 1121e6bea79SAleksandar Markovic { 0x886ae6cc28625540ULL, 0x27d8c6ffab2b2514ULL, }, 1131e6bea79SAleksandar Markovic { 0x704f164d5e31e24eULL, 0x4b670b5efe7bb00cULL, }, 1141e6bea79SAleksandar Markovic { 0x886ae6cc28625540ULL, 0x12f7bb1a153f52fcULL, }, 1151e6bea79SAleksandar Markovic { 0xfbbe00634d93c708ULL, 0x12f7bb1a153f52fcULL, }, 1161e6bea79SAleksandar Markovic { 0xac5aaeaab9cf8b80ULL, 0x12f7bb1a153f52fcULL, }, 1171e6bea79SAleksandar Markovic { 0x704f164d5e31e24eULL, 0x12f7bb1a153f52fcULL, }, 1181e6bea79SAleksandar Markovic { 0x886ae6cc28625540ULL, 0x27d8c6ffab2b2514ULL, }, /* 72 */ 1191e6bea79SAleksandar Markovic { 0xac5aaeaab9cf8b80ULL, 0x12f7bb1a153f52fcULL, }, 1201e6bea79SAleksandar Markovic { 0xac5aaeaab9cf8b80ULL, 0x27d8c6ffab2b2514ULL, }, 1211e6bea79SAleksandar Markovic { 0x704f164d5e31e24eULL, 0x27d8c6ffab2b2514ULL, }, 1221e6bea79SAleksandar Markovic { 0x704f164d5e31e24eULL, 0x4b670b5efe7bb00cULL, }, 1231e6bea79SAleksandar Markovic { 0x704f164d5e31e24eULL, 0x12f7bb1a153f52fcULL, }, 1241e6bea79SAleksandar Markovic { 0x704f164d5e31e24eULL, 0x27d8c6ffab2b2514ULL, }, 1251e6bea79SAleksandar Markovic { 0x704f164d5e31e24eULL, 0x8df188d8a942e2a0ULL, }, 1261e6bea79SAleksandar Markovic }; 1271e6bea79SAleksandar Markovic 128*ca693d1cSAleksandar Markovic reset_msa_registers(); 129*ca693d1cSAleksandar Markovic 1301e6bea79SAleksandar Markovic gettimeofday(&start, NULL); 1311e6bea79SAleksandar Markovic 1321e6bea79SAleksandar Markovic for (i = 0; i < PATTERN_INPUTS_SHORT_COUNT; i++) { 1331e6bea79SAleksandar Markovic for (j = 0; j < PATTERN_INPUTS_SHORT_COUNT; j++) { 1341e6bea79SAleksandar Markovic do_msa_MIN_U_D(b128_pattern[i], b128_pattern[j], 1351e6bea79SAleksandar Markovic b128_result[PATTERN_INPUTS_SHORT_COUNT * i + j]); 1361e6bea79SAleksandar Markovic } 1371e6bea79SAleksandar Markovic } 1381e6bea79SAleksandar Markovic 1391e6bea79SAleksandar Markovic for (i = 0; i < RANDOM_INPUTS_SHORT_COUNT; i++) { 1401e6bea79SAleksandar Markovic for (j = 0; j < RANDOM_INPUTS_SHORT_COUNT; j++) { 1411e6bea79SAleksandar Markovic do_msa_MIN_U_D(b128_random[i], b128_random[j], 1421e6bea79SAleksandar Markovic b128_result[((PATTERN_INPUTS_SHORT_COUNT) * 1431e6bea79SAleksandar Markovic (PATTERN_INPUTS_SHORT_COUNT)) + 1441e6bea79SAleksandar Markovic RANDOM_INPUTS_SHORT_COUNT * i + j]); 1451e6bea79SAleksandar Markovic } 1461e6bea79SAleksandar Markovic } 1471e6bea79SAleksandar Markovic 1481e6bea79SAleksandar Markovic gettimeofday(&end, NULL); 1491e6bea79SAleksandar Markovic 1501e6bea79SAleksandar Markovic elapsed_time = (end.tv_sec - start.tv_sec) * 1000.0; 1511e6bea79SAleksandar Markovic elapsed_time += (end.tv_usec - start.tv_usec) / 1000.0; 1521e6bea79SAleksandar Markovic 1531e6bea79SAleksandar Markovic ret = check_results(instruction_name, TEST_COUNT_TOTAL, elapsed_time, 1541e6bea79SAleksandar Markovic &b128_result[0][0], &b128_expect[0][0]); 1551e6bea79SAleksandar Markovic 1561e6bea79SAleksandar Markovic return ret; 1571e6bea79SAleksandar Markovic } 158