2015-06-27 20:10:45 -04:00
|
|
|
// This is free and unencumbered software released into the public domain.
|
2015-07-02 04:49:35 -04:00
|
|
|
//
|
2015-06-27 20:10:45 -04:00
|
|
|
// Anyone is free to copy, modify, publish, use, compile, sell, or
|
|
|
|
// distribute this software, either in source code form or as a compiled
|
|
|
|
// binary, for any purpose, commercial or non-commercial, and by any
|
|
|
|
// means.
|
|
|
|
|
2015-06-26 17:14:38 -04:00
|
|
|
#include "firmware.h"
|
|
|
|
|
2015-07-04 05:47:19 -04:00
|
|
|
static uint32_t xorshift32(void) {
|
2015-06-26 17:14:38 -04:00
|
|
|
static uint32_t x = 314159265;
|
|
|
|
x ^= x << 13;
|
|
|
|
x ^= x >> 17;
|
|
|
|
x ^= x << 5;
|
|
|
|
return x;
|
|
|
|
}
|
|
|
|
|
2015-07-04 05:47:19 -04:00
|
|
|
void multest(void)
|
2015-06-26 17:14:38 -04:00
|
|
|
{
|
2015-07-04 05:47:43 -04:00
|
|
|
for (int i = 0; i < 10; i++)
|
2015-06-26 17:14:38 -04:00
|
|
|
{
|
|
|
|
uint32_t a = xorshift32();
|
|
|
|
uint32_t b = xorshift32();
|
|
|
|
|
|
|
|
uint64_t au = a, bu = b;
|
|
|
|
int64_t as = (int32_t)a, bs = (int32_t)b;
|
|
|
|
|
|
|
|
print_str("input [");
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(as >> 32, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str("] ");
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(a, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str(" [");
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(bs >> 32, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str("] ");
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(b, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_chr('\n');
|
|
|
|
|
|
|
|
uint32_t h_mul, h_mulh, h_mulhsu, h_mulhu;
|
|
|
|
print_str("hard ");
|
|
|
|
|
|
|
|
h_mul = hard_mul(a, b);
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(h_mul, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str(" ");
|
|
|
|
|
|
|
|
h_mulh = hard_mulh(a, b);
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(h_mulh, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str(" ");
|
|
|
|
|
|
|
|
h_mulhsu = hard_mulhsu(a, b);
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(h_mulhsu, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str(" ");
|
|
|
|
|
|
|
|
h_mulhu = hard_mulhu(a, b);
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(h_mulhu, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_chr('\n');
|
|
|
|
|
|
|
|
uint32_t s_mul, s_mulh, s_mulhsu, s_mulhu;
|
|
|
|
print_str("soft ");
|
|
|
|
|
|
|
|
s_mul = a * b;
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(s_mul, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str(" ");
|
|
|
|
|
|
|
|
s_mulh = (as * bs) >> 32;
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(s_mulh, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str(" ");
|
|
|
|
|
|
|
|
s_mulhsu = (as * bu) >> 32;
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(s_mulhsu, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str(" ");
|
|
|
|
|
|
|
|
s_mulhu = (au * bu) >> 32;
|
2015-11-19 08:01:16 -05:00
|
|
|
print_hex(s_mulhu, 8);
|
2015-06-26 17:14:38 -04:00
|
|
|
print_str(" ");
|
|
|
|
|
|
|
|
if (s_mul != h_mul || s_mulh != h_mulh || s_mulhsu != h_mulhsu || s_mulhu != h_mulhu) {
|
|
|
|
print_str("ERROR!\n");
|
2015-07-04 05:47:19 -04:00
|
|
|
__asm__ volatile ("sbreak");
|
2015-06-26 17:14:38 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
print_str(" OK\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|