xref: /openbmc/qemu/tests/tcg/sh4/test-macw.c (revision 7227c0cd)
1*7227c0cdSZack Buhman /* SPDX-License-Identifier: GPL-2.0-or-later */
2*7227c0cdSZack Buhman 
3*7227c0cdSZack Buhman #include <stdint.h>
4*7227c0cdSZack Buhman #include <stdlib.h>
5*7227c0cdSZack Buhman #include <stdio.h>
6*7227c0cdSZack Buhman 
mac_w(int64_t mac,const int16_t * a,const int16_t * b)7*7227c0cdSZack Buhman int64_t mac_w(int64_t mac, const int16_t *a, const int16_t *b)
8*7227c0cdSZack Buhman {
9*7227c0cdSZack Buhman     register uint32_t macl __asm__("macl") = mac;
10*7227c0cdSZack Buhman     register uint32_t mach __asm__("mach") = mac >> 32;
11*7227c0cdSZack Buhman 
12*7227c0cdSZack Buhman     asm volatile("mac.w @%0+,@%1+"
13*7227c0cdSZack Buhman                  : "+r"(a), "+r"(b), "+x"(macl), "+x"(mach));
14*7227c0cdSZack Buhman 
15*7227c0cdSZack Buhman     return ((uint64_t)mach << 32) | macl;
16*7227c0cdSZack Buhman }
17*7227c0cdSZack Buhman 
18*7227c0cdSZack Buhman typedef struct {
19*7227c0cdSZack Buhman     int64_t mac;
20*7227c0cdSZack Buhman     int16_t a, b;
21*7227c0cdSZack Buhman     int64_t res[2];
22*7227c0cdSZack Buhman } Test;
23*7227c0cdSZack Buhman 
24*7227c0cdSZack Buhman __attribute__((noinline))
test(const Test * t,int sat)25*7227c0cdSZack Buhman void test(const Test *t, int sat)
26*7227c0cdSZack Buhman {
27*7227c0cdSZack Buhman     int64_t res;
28*7227c0cdSZack Buhman 
29*7227c0cdSZack Buhman     if (sat) {
30*7227c0cdSZack Buhman         asm volatile("sets");
31*7227c0cdSZack Buhman     } else {
32*7227c0cdSZack Buhman         asm volatile("clrs");
33*7227c0cdSZack Buhman     }
34*7227c0cdSZack Buhman     res = mac_w(t->mac, &t->a, &t->b);
35*7227c0cdSZack Buhman 
36*7227c0cdSZack Buhman     if (res != t->res[sat]) {
37*7227c0cdSZack Buhman         fprintf(stderr, "%#llx + (%#x * %#x) = %#llx -- got %#llx\n",
38*7227c0cdSZack Buhman                 t->mac, t->a, t->b, t->res[sat], res);
39*7227c0cdSZack Buhman         abort();
40*7227c0cdSZack Buhman     }
41*7227c0cdSZack Buhman }
42*7227c0cdSZack Buhman 
main()43*7227c0cdSZack Buhman int main()
44*7227c0cdSZack Buhman {
45*7227c0cdSZack Buhman     static const Test tests[] = {
46*7227c0cdSZack Buhman         { 0, 2, 3, { 6, 6 } },
47*7227c0cdSZack Buhman         { 0x123456787ffffffell, 2, -3,
48*7227c0cdSZack Buhman           { 0x123456787ffffff8ll, 0x123456787ffffff8ll } },
49*7227c0cdSZack Buhman         { 0xabcdef127ffffffall, 2, 3,
50*7227c0cdSZack Buhman           { 0xabcdef1280000000ll, 0x000000017fffffffll } },
51*7227c0cdSZack Buhman         { 0xfffffffffll, INT16_MAX, INT16_MAX,
52*7227c0cdSZack Buhman           { 0x103fff0000ll, 0xf3fff0000ll } },
53*7227c0cdSZack Buhman     };
54*7227c0cdSZack Buhman 
55*7227c0cdSZack Buhman     for (int i = 0; i < sizeof(tests) / sizeof(tests[0]); ++i) {
56*7227c0cdSZack Buhman         for (int j = 0; j < 2; ++j) {
57*7227c0cdSZack Buhman             test(&tests[i], j);
58*7227c0cdSZack Buhman         }
59*7227c0cdSZack Buhman     }
60*7227c0cdSZack Buhman     return 0;
61*7227c0cdSZack Buhman }
62