12a367db0SAleksandar Markovic /*
22a367db0SAleksandar Markovic  *  Test program for MSA instruction PCKEV.B
32a367db0SAleksandar Markovic  *
4dd8d6a2dSAleksandar Markovic  *  Copyright (C) 2019  Wave Computing, Inc.
5dd8d6a2dSAleksandar Markovic  *  Copyright (C) 2019  Aleksandar Markovic <amarkovic@wavecomp.com>
62a367db0SAleksandar Markovic  *
72a367db0SAleksandar Markovic  *  This program is free software: you can redistribute it and/or modify
82a367db0SAleksandar Markovic  *  it under the terms of the GNU General Public License as published by
92a367db0SAleksandar Markovic  *  the Free Software Foundation, either version 2 of the License, or
102a367db0SAleksandar Markovic  *  (at your option) any later version.
112a367db0SAleksandar Markovic  *`
122a367db0SAleksandar Markovic  *  This program is distributed in the hope that it will be useful,
132a367db0SAleksandar Markovic  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
142a367db0SAleksandar Markovic  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
152a367db0SAleksandar Markovic  *  GNU General Public License for more details.
162a367db0SAleksandar Markovic  *
172a367db0SAleksandar Markovic  *  You should have received a copy of the GNU General Public License
182a367db0SAleksandar Markovic  *  along with this program.  If not, see <https://www.gnu.org/licenses/>.
192a367db0SAleksandar Markovic  *
202a367db0SAleksandar Markovic  */
212a367db0SAleksandar Markovic 
222a367db0SAleksandar Markovic #include <sys/time.h>
232a367db0SAleksandar Markovic #include <stdint.h>
242a367db0SAleksandar Markovic 
252a367db0SAleksandar Markovic #include "../../../../include/wrappers_msa.h"
2681526dffSAleksandar Markovic #include "../../../../include/test_inputs_128.h"
2781526dffSAleksandar Markovic #include "../../../../include/test_utils_128.h"
282a367db0SAleksandar Markovic 
292a367db0SAleksandar Markovic #define TEST_COUNT_TOTAL (                                                \
302a367db0SAleksandar Markovic             (PATTERN_INPUTS_SHORT_COUNT) * (PATTERN_INPUTS_SHORT_COUNT) + \
31f9fa196bSAleksandar Markovic             3 * (RANDOM_INPUTS_SHORT_COUNT) * (RANDOM_INPUTS_SHORT_COUNT))
322a367db0SAleksandar Markovic 
332a367db0SAleksandar Markovic 
main(void)342a367db0SAleksandar Markovic int32_t main(void)
352a367db0SAleksandar Markovic {
368e6fe6b8SAleksandar Markovic     char *isa_ase_name = "MSA";
378e6fe6b8SAleksandar Markovic     char *group_name = "Pack";
382a367db0SAleksandar Markovic     char *instruction_name =  "PCKEV.B";
392a367db0SAleksandar Markovic     int32_t ret;
402a367db0SAleksandar Markovic     uint32_t i, j;
412a367db0SAleksandar Markovic     struct timeval start, end;
422a367db0SAleksandar Markovic     double elapsed_time;
432a367db0SAleksandar Markovic 
442a367db0SAleksandar Markovic     uint64_t b128_result[TEST_COUNT_TOTAL][2];
452a367db0SAleksandar Markovic     uint64_t b128_expect[TEST_COUNT_TOTAL][2] = {
462a367db0SAleksandar Markovic         { 0xffffffffffffffffULL, 0xffffffffffffffffULL, },    /*   0  */
472a367db0SAleksandar Markovic         { 0x0000000000000000ULL, 0xffffffffffffffffULL, },
482a367db0SAleksandar Markovic         { 0xaaaaaaaaaaaaaaaaULL, 0xffffffffffffffffULL, },
492a367db0SAleksandar Markovic         { 0x5555555555555555ULL, 0xffffffffffffffffULL, },
502a367db0SAleksandar Markovic         { 0xccccccccccccccccULL, 0xffffffffffffffffULL, },
512a367db0SAleksandar Markovic         { 0x3333333333333333ULL, 0xffffffffffffffffULL, },
522a367db0SAleksandar Markovic         { 0xe3388ee38ee3388eULL, 0xffffffffffffffffULL, },
532a367db0SAleksandar Markovic         { 0x1cc7711c711cc771ULL, 0xffffffffffffffffULL, },
542a367db0SAleksandar Markovic         { 0xffffffffffffffffULL, 0x0000000000000000ULL, },    /*   8  */
552a367db0SAleksandar Markovic         { 0x0000000000000000ULL, 0x0000000000000000ULL, },
562a367db0SAleksandar Markovic         { 0xaaaaaaaaaaaaaaaaULL, 0x0000000000000000ULL, },
572a367db0SAleksandar Markovic         { 0x5555555555555555ULL, 0x0000000000000000ULL, },
582a367db0SAleksandar Markovic         { 0xccccccccccccccccULL, 0x0000000000000000ULL, },
592a367db0SAleksandar Markovic         { 0x3333333333333333ULL, 0x0000000000000000ULL, },
602a367db0SAleksandar Markovic         { 0xe3388ee38ee3388eULL, 0x0000000000000000ULL, },
612a367db0SAleksandar Markovic         { 0x1cc7711c711cc771ULL, 0x0000000000000000ULL, },
622a367db0SAleksandar Markovic         { 0xffffffffffffffffULL, 0xaaaaaaaaaaaaaaaaULL, },    /*  16  */
632a367db0SAleksandar Markovic         { 0x0000000000000000ULL, 0xaaaaaaaaaaaaaaaaULL, },
642a367db0SAleksandar Markovic         { 0xaaaaaaaaaaaaaaaaULL, 0xaaaaaaaaaaaaaaaaULL, },
652a367db0SAleksandar Markovic         { 0x5555555555555555ULL, 0xaaaaaaaaaaaaaaaaULL, },
662a367db0SAleksandar Markovic         { 0xccccccccccccccccULL, 0xaaaaaaaaaaaaaaaaULL, },
672a367db0SAleksandar Markovic         { 0x3333333333333333ULL, 0xaaaaaaaaaaaaaaaaULL, },
682a367db0SAleksandar Markovic         { 0xe3388ee38ee3388eULL, 0xaaaaaaaaaaaaaaaaULL, },
692a367db0SAleksandar Markovic         { 0x1cc7711c711cc771ULL, 0xaaaaaaaaaaaaaaaaULL, },
702a367db0SAleksandar Markovic         { 0xffffffffffffffffULL, 0x5555555555555555ULL, },    /*  24  */
712a367db0SAleksandar Markovic         { 0x0000000000000000ULL, 0x5555555555555555ULL, },
722a367db0SAleksandar Markovic         { 0xaaaaaaaaaaaaaaaaULL, 0x5555555555555555ULL, },
732a367db0SAleksandar Markovic         { 0x5555555555555555ULL, 0x5555555555555555ULL, },
742a367db0SAleksandar Markovic         { 0xccccccccccccccccULL, 0x5555555555555555ULL, },
752a367db0SAleksandar Markovic         { 0x3333333333333333ULL, 0x5555555555555555ULL, },
762a367db0SAleksandar Markovic         { 0xe3388ee38ee3388eULL, 0x5555555555555555ULL, },
772a367db0SAleksandar Markovic         { 0x1cc7711c711cc771ULL, 0x5555555555555555ULL, },
782a367db0SAleksandar Markovic         { 0xffffffffffffffffULL, 0xccccccccccccccccULL, },    /*  32  */
792a367db0SAleksandar Markovic         { 0x0000000000000000ULL, 0xccccccccccccccccULL, },
802a367db0SAleksandar Markovic         { 0xaaaaaaaaaaaaaaaaULL, 0xccccccccccccccccULL, },
812a367db0SAleksandar Markovic         { 0x5555555555555555ULL, 0xccccccccccccccccULL, },
822a367db0SAleksandar Markovic         { 0xccccccccccccccccULL, 0xccccccccccccccccULL, },
832a367db0SAleksandar Markovic         { 0x3333333333333333ULL, 0xccccccccccccccccULL, },
842a367db0SAleksandar Markovic         { 0xe3388ee38ee3388eULL, 0xccccccccccccccccULL, },
852a367db0SAleksandar Markovic         { 0x1cc7711c711cc771ULL, 0xccccccccccccccccULL, },
862a367db0SAleksandar Markovic         { 0xffffffffffffffffULL, 0x3333333333333333ULL, },    /*  40  */
872a367db0SAleksandar Markovic         { 0x0000000000000000ULL, 0x3333333333333333ULL, },
882a367db0SAleksandar Markovic         { 0xaaaaaaaaaaaaaaaaULL, 0x3333333333333333ULL, },
892a367db0SAleksandar Markovic         { 0x5555555555555555ULL, 0x3333333333333333ULL, },
902a367db0SAleksandar Markovic         { 0xccccccccccccccccULL, 0x3333333333333333ULL, },
912a367db0SAleksandar Markovic         { 0x3333333333333333ULL, 0x3333333333333333ULL, },
922a367db0SAleksandar Markovic         { 0xe3388ee38ee3388eULL, 0x3333333333333333ULL, },
932a367db0SAleksandar Markovic         { 0x1cc7711c711cc771ULL, 0x3333333333333333ULL, },
942a367db0SAleksandar Markovic         { 0xffffffffffffffffULL, 0xe3388ee38ee3388eULL, },    /*  48  */
952a367db0SAleksandar Markovic         { 0x0000000000000000ULL, 0xe3388ee38ee3388eULL, },
962a367db0SAleksandar Markovic         { 0xaaaaaaaaaaaaaaaaULL, 0xe3388ee38ee3388eULL, },
972a367db0SAleksandar Markovic         { 0x5555555555555555ULL, 0xe3388ee38ee3388eULL, },
982a367db0SAleksandar Markovic         { 0xccccccccccccccccULL, 0xe3388ee38ee3388eULL, },
992a367db0SAleksandar Markovic         { 0x3333333333333333ULL, 0xe3388ee38ee3388eULL, },
1002a367db0SAleksandar Markovic         { 0xe3388ee38ee3388eULL, 0xe3388ee38ee3388eULL, },
1012a367db0SAleksandar Markovic         { 0x1cc7711c711cc771ULL, 0xe3388ee38ee3388eULL, },
1022a367db0SAleksandar Markovic         { 0xffffffffffffffffULL, 0x1cc7711c711cc771ULL, },    /*  56  */
1032a367db0SAleksandar Markovic         { 0x0000000000000000ULL, 0x1cc7711c711cc771ULL, },
1042a367db0SAleksandar Markovic         { 0xaaaaaaaaaaaaaaaaULL, 0x1cc7711c711cc771ULL, },
1052a367db0SAleksandar Markovic         { 0x5555555555555555ULL, 0x1cc7711c711cc771ULL, },
1062a367db0SAleksandar Markovic         { 0xccccccccccccccccULL, 0x1cc7711c711cc771ULL, },
1072a367db0SAleksandar Markovic         { 0x3333333333333333ULL, 0x1cc7711c711cc771ULL, },
1082a367db0SAleksandar Markovic         { 0xe3388ee38ee3388eULL, 0x1cc7711c711cc771ULL, },
1092a367db0SAleksandar Markovic         { 0x1cc7711c711cc771ULL, 0x1cc7711c711cc771ULL, },
1102a367db0SAleksandar Markovic         { 0x675e7b0c6acc6240ULL, 0x675e7b0c6acc6240ULL, },    /*  64  */
1112a367db0SAleksandar Markovic         { 0xf71a3ffcbe639308ULL, 0x675e7b0c6acc6240ULL, },
1122a367db0SAleksandar Markovic         { 0xd8ff2b145aaacf80ULL, 0x675e7b0c6acc6240ULL, },
1132a367db0SAleksandar Markovic         { 0xf1d842a04f4d314eULL, 0x675e7b0c6acc6240ULL, },
1142a367db0SAleksandar Markovic         { 0x675e7b0c6acc6240ULL, 0xf71a3ffcbe639308ULL, },
1152a367db0SAleksandar Markovic         { 0xf71a3ffcbe639308ULL, 0xf71a3ffcbe639308ULL, },
1162a367db0SAleksandar Markovic         { 0xd8ff2b145aaacf80ULL, 0xf71a3ffcbe639308ULL, },
1172a367db0SAleksandar Markovic         { 0xf1d842a04f4d314eULL, 0xf71a3ffcbe639308ULL, },
1182a367db0SAleksandar Markovic         { 0x675e7b0c6acc6240ULL, 0xd8ff2b145aaacf80ULL, },    /*  72  */
1192a367db0SAleksandar Markovic         { 0xf71a3ffcbe639308ULL, 0xd8ff2b145aaacf80ULL, },
1202a367db0SAleksandar Markovic         { 0xd8ff2b145aaacf80ULL, 0xd8ff2b145aaacf80ULL, },
1212a367db0SAleksandar Markovic         { 0xf1d842a04f4d314eULL, 0xd8ff2b145aaacf80ULL, },
1222a367db0SAleksandar Markovic         { 0x675e7b0c6acc6240ULL, 0xf1d842a04f4d314eULL, },
1232a367db0SAleksandar Markovic         { 0xf71a3ffcbe639308ULL, 0xf1d842a04f4d314eULL, },
1242a367db0SAleksandar Markovic         { 0xd8ff2b145aaacf80ULL, 0xf1d842a04f4d314eULL, },
1252a367db0SAleksandar Markovic         { 0xf1d842a04f4d314eULL, 0xf1d842a04f4d314eULL, },
126*23dd244bSAleksandar Markovic         { 0x675e7b0c6acc6240ULL, 0xd8a04d4ed8a04d4eULL, },    /*  80  */
127*23dd244bSAleksandar Markovic         { 0xf71a3ffcbe639308ULL, 0xa04ea04e5e0ccc40ULL, },
128*23dd244bSAleksandar Markovic         { 0xd8ff2b145aaacf80ULL, 0x4e4e0c401afc6308ULL, },
129*23dd244bSAleksandar Markovic         { 0xf1d842a04f4d314eULL, 0x4e40fc08ff14aa80ULL, },
130*23dd244bSAleksandar Markovic         { 0x675e7b0c6acc6240ULL, 0x40081480d8a04d4eULL, },
131*23dd244bSAleksandar Markovic         { 0xf71a3ffcbe639308ULL, 0x0880a04e5e0ccc40ULL, },
132*23dd244bSAleksandar Markovic         { 0xd8ff2b145aaacf80ULL, 0x804e0c401afc6308ULL, },
133*23dd244bSAleksandar Markovic         { 0xf1d842a04f4d314eULL, 0x4e40fc08ff14aa80ULL, },
134*23dd244bSAleksandar Markovic         { 0x675e7b0c6acc6240ULL, 0x40081480d8a04d4eULL, },    /*  88  */
135*23dd244bSAleksandar Markovic         { 0xf71a3ffcbe639308ULL, 0x0880a04e5e0ccc40ULL, },
136*23dd244bSAleksandar Markovic         { 0xd8ff2b145aaacf80ULL, 0x804e0c401afc6308ULL, },
137*23dd244bSAleksandar Markovic         { 0xf1d842a04f4d314eULL, 0x4e40fc08ff14aa80ULL, },
138*23dd244bSAleksandar Markovic         { 0x675e7b0c6acc6240ULL, 0x40081480d8a04d4eULL, },
139*23dd244bSAleksandar Markovic         { 0xf71a3ffcbe639308ULL, 0x0880a04e5e0ccc40ULL, },
140*23dd244bSAleksandar Markovic         { 0xd8ff2b145aaacf80ULL, 0x804e0c401afc6308ULL, },
141*23dd244bSAleksandar Markovic         { 0xf1d842a04f4d314eULL, 0x4e40fc08ff14aa80ULL, },
142*23dd244bSAleksandar Markovic         { 0x40081480d8a04d4eULL, 0x675e7b0c6acc6240ULL, },    /*  96  */
143*23dd244bSAleksandar Markovic         { 0x5e0ccc400880a04eULL, 0x675e7b0c6acc6240ULL, },
144*23dd244bSAleksandar Markovic         { 0x5e0ccc400c40804eULL, 0x675e7b0c6acc6240ULL, },
145*23dd244bSAleksandar Markovic         { 0x5e0ccc400c40404eULL, 0x675e7b0c6acc6240ULL, },
146*23dd244bSAleksandar Markovic         { 0x5e0ccc400c40404eULL, 0xf71a3ffcbe639308ULL, },
147*23dd244bSAleksandar Markovic         { 0x1afc63080c40404eULL, 0xf71a3ffcbe639308ULL, },
148*23dd244bSAleksandar Markovic         { 0x1afc6308fc08404eULL, 0xf71a3ffcbe639308ULL, },
149*23dd244bSAleksandar Markovic         { 0x1afc6308fc08084eULL, 0xf71a3ffcbe639308ULL, },
150*23dd244bSAleksandar Markovic         { 0x1afc6308fc08084eULL, 0xd8ff2b145aaacf80ULL, },    /* 104  */
151*23dd244bSAleksandar Markovic         { 0xff14aa80fc08084eULL, 0xd8ff2b145aaacf80ULL, },
152*23dd244bSAleksandar Markovic         { 0xff14aa801480084eULL, 0xd8ff2b145aaacf80ULL, },
153*23dd244bSAleksandar Markovic         { 0xff14aa801480804eULL, 0xd8ff2b145aaacf80ULL, },
154*23dd244bSAleksandar Markovic         { 0xff14aa801480804eULL, 0xf1d842a04f4d314eULL, },
155*23dd244bSAleksandar Markovic         { 0xd8a04d4e1480804eULL, 0xf1d842a04f4d314eULL, },
156*23dd244bSAleksandar Markovic         { 0xd8a04d4ea04e804eULL, 0xf1d842a04f4d314eULL, },
157*23dd244bSAleksandar Markovic         { 0xd8a04d4ea04e4e4eULL, 0xf1d842a04f4d314eULL, },
1582a367db0SAleksandar Markovic     };
1592a367db0SAleksandar Markovic 
160ca693d1cSAleksandar Markovic     reset_msa_registers();
161ca693d1cSAleksandar Markovic 
1622a367db0SAleksandar Markovic     gettimeofday(&start, NULL);
1632a367db0SAleksandar Markovic 
1642a367db0SAleksandar Markovic     for (i = 0; i < PATTERN_INPUTS_SHORT_COUNT; i++) {
1652a367db0SAleksandar Markovic         for (j = 0; j < PATTERN_INPUTS_SHORT_COUNT; j++) {
1662a367db0SAleksandar Markovic             do_msa_PCKEV_B(b128_pattern[i], b128_pattern[j],
1672a367db0SAleksandar Markovic                            b128_result[PATTERN_INPUTS_SHORT_COUNT * i + j]);
1682a367db0SAleksandar Markovic         }
1692a367db0SAleksandar Markovic     }
1702a367db0SAleksandar Markovic 
1712a367db0SAleksandar Markovic     for (i = 0; i < RANDOM_INPUTS_SHORT_COUNT; i++) {
1722a367db0SAleksandar Markovic         for (j = 0; j < RANDOM_INPUTS_SHORT_COUNT; j++) {
1732a367db0SAleksandar Markovic             do_msa_PCKEV_B(b128_random[i], b128_random[j],
1742a367db0SAleksandar Markovic                            b128_result[((PATTERN_INPUTS_SHORT_COUNT) *
1752a367db0SAleksandar Markovic                                         (PATTERN_INPUTS_SHORT_COUNT)) +
1762a367db0SAleksandar Markovic                                        RANDOM_INPUTS_SHORT_COUNT * i + j]);
1772a367db0SAleksandar Markovic         }
1782a367db0SAleksandar Markovic     }
1792a367db0SAleksandar Markovic 
180f9fa196bSAleksandar Markovic     for (i = 0; i < RANDOM_INPUTS_SHORT_COUNT; i++) {
181f9fa196bSAleksandar Markovic         for (j = 0; j < RANDOM_INPUTS_SHORT_COUNT; j++) {
182f9fa196bSAleksandar Markovic             do_msa_PCKEV_B__DDT(b128_random[i], b128_random[j],
183f9fa196bSAleksandar Markovic                                 b128_result[
184f9fa196bSAleksandar Markovic                                     ((PATTERN_INPUTS_SHORT_COUNT) *
185f9fa196bSAleksandar Markovic                                      (PATTERN_INPUTS_SHORT_COUNT)) +
186f9fa196bSAleksandar Markovic                                     ((RANDOM_INPUTS_SHORT_COUNT) *
187f9fa196bSAleksandar Markovic                                      (RANDOM_INPUTS_SHORT_COUNT)) +
188f9fa196bSAleksandar Markovic                                     RANDOM_INPUTS_SHORT_COUNT * i + j]);
189f9fa196bSAleksandar Markovic         }
190f9fa196bSAleksandar Markovic     }
191f9fa196bSAleksandar Markovic 
192f9fa196bSAleksandar Markovic     for (i = 0; i < RANDOM_INPUTS_SHORT_COUNT; i++) {
193f9fa196bSAleksandar Markovic         for (j = 0; j < RANDOM_INPUTS_SHORT_COUNT; j++) {
194f9fa196bSAleksandar Markovic             do_msa_PCKEV_B__DSD(b128_random[i], b128_random[j],
195f9fa196bSAleksandar Markovic                                 b128_result[
196f9fa196bSAleksandar Markovic                                     ((PATTERN_INPUTS_SHORT_COUNT) *
197f9fa196bSAleksandar Markovic                                      (PATTERN_INPUTS_SHORT_COUNT)) +
198f9fa196bSAleksandar Markovic                                     (2 * (RANDOM_INPUTS_SHORT_COUNT) *
199f9fa196bSAleksandar Markovic                                      (RANDOM_INPUTS_SHORT_COUNT)) +
200f9fa196bSAleksandar Markovic                                     RANDOM_INPUTS_SHORT_COUNT * i + j]);
201f9fa196bSAleksandar Markovic         }
202f9fa196bSAleksandar Markovic     }
203f9fa196bSAleksandar Markovic 
2042a367db0SAleksandar Markovic     gettimeofday(&end, NULL);
2052a367db0SAleksandar Markovic 
2062a367db0SAleksandar Markovic     elapsed_time = (end.tv_sec - start.tv_sec) * 1000.0;
2072a367db0SAleksandar Markovic     elapsed_time += (end.tv_usec - start.tv_usec) / 1000.0;
2082a367db0SAleksandar Markovic 
2098e6fe6b8SAleksandar Markovic     ret = check_results_128(isa_ase_name, group_name, instruction_name,
2108e6fe6b8SAleksandar Markovic                             TEST_COUNT_TOTAL, elapsed_time,
2112a367db0SAleksandar Markovic                             &b128_result[0][0], &b128_expect[0][0]);
2122a367db0SAleksandar Markovic 
2132a367db0SAleksandar Markovic     return ret;
2142a367db0SAleksandar Markovic }
215