blob: 5d05adefdea16378e3642583ed53e88c11383a35 [file] [log] [blame]
// Copyright 2023 Google LLC
#include "VVAlu.h"
#include "tests/verilator_sim/kelvin/valu.h"
#include "tests/verilator_sim/sysc_tb.h"
struct VAlu_tb : Sysc_tb {
sc_in<bool> io_in_ready;
sc_out<bool> io_in_valid;
sc_out<bool> io_in_bits_0_valid;
sc_out<bool> io_in_bits_0_bits_m;
sc_out<bool> io_in_bits_0_bits_vd_valid;
sc_out<bool> io_in_bits_0_bits_ve_valid;
sc_out<bool> io_in_bits_0_bits_vf_valid;
sc_out<bool> io_in_bits_0_bits_vg_valid;
sc_out<bool> io_in_bits_0_bits_vs_valid;
sc_out<bool> io_in_bits_0_bits_vt_valid;
sc_out<bool> io_in_bits_0_bits_vu_valid;
sc_out<bool> io_in_bits_0_bits_vx_valid;
sc_out<bool> io_in_bits_0_bits_vy_valid;
sc_out<bool> io_in_bits_0_bits_vz_valid;
sc_out<bool> io_in_bits_0_bits_sv_valid;
sc_out<bool> io_in_bits_0_bits_cmdsync;
sc_out<bool> io_in_bits_1_valid;
sc_out<bool> io_in_bits_1_bits_m;
sc_out<bool> io_in_bits_1_bits_vd_valid;
sc_out<bool> io_in_bits_1_bits_ve_valid;
sc_out<bool> io_in_bits_1_bits_vf_valid;
sc_out<bool> io_in_bits_1_bits_vg_valid;
sc_out<bool> io_in_bits_1_bits_vs_valid;
sc_out<bool> io_in_bits_1_bits_vt_valid;
sc_out<bool> io_in_bits_1_bits_vu_valid;
sc_out<bool> io_in_bits_1_bits_vx_valid;
sc_out<bool> io_in_bits_1_bits_vy_valid;
sc_out<bool> io_in_bits_1_bits_vz_valid;
sc_out<bool> io_in_bits_1_bits_sv_valid;
sc_out<bool> io_in_bits_1_bits_cmdsync;
sc_out<bool> io_in_bits_2_valid;
sc_out<bool> io_in_bits_2_bits_m;
sc_out<bool> io_in_bits_2_bits_vd_valid;
sc_out<bool> io_in_bits_2_bits_ve_valid;
sc_out<bool> io_in_bits_2_bits_vf_valid;
sc_out<bool> io_in_bits_2_bits_vg_valid;
sc_out<bool> io_in_bits_2_bits_vs_valid;
sc_out<bool> io_in_bits_2_bits_vt_valid;
sc_out<bool> io_in_bits_2_bits_vu_valid;
sc_out<bool> io_in_bits_2_bits_vx_valid;
sc_out<bool> io_in_bits_2_bits_vy_valid;
sc_out<bool> io_in_bits_2_bits_vz_valid;
sc_out<bool> io_in_bits_2_bits_sv_valid;
sc_out<bool> io_in_bits_2_bits_cmdsync;
sc_out<bool> io_in_bits_3_valid;
sc_out<bool> io_in_bits_3_bits_m;
sc_out<bool> io_in_bits_3_bits_vd_valid;
sc_out<bool> io_in_bits_3_bits_ve_valid;
sc_out<bool> io_in_bits_3_bits_vf_valid;
sc_out<bool> io_in_bits_3_bits_vg_valid;
sc_out<bool> io_in_bits_3_bits_vs_valid;
sc_out<bool> io_in_bits_3_bits_vt_valid;
sc_out<bool> io_in_bits_3_bits_vu_valid;
sc_out<bool> io_in_bits_3_bits_vx_valid;
sc_out<bool> io_in_bits_3_bits_vy_valid;
sc_out<bool> io_in_bits_3_bits_vz_valid;
sc_out<bool> io_in_bits_3_bits_sv_valid;
sc_out<bool> io_in_bits_3_bits_cmdsync;
sc_in<bool> io_read_0_valid;
sc_in<bool> io_read_1_valid;
sc_in<bool> io_read_2_valid;
sc_in<bool> io_read_3_valid;
sc_in<bool> io_read_4_valid;
sc_in<bool> io_read_5_valid;
sc_in<bool> io_read_6_valid;
sc_in<bool> io_read_0_ready;
sc_in<bool> io_read_1_ready;
sc_in<bool> io_read_2_ready;
sc_in<bool> io_read_3_ready;
sc_in<bool> io_read_4_ready;
sc_in<bool> io_read_5_ready;
sc_in<bool> io_read_6_ready;
sc_in<bool> io_write_0_valid;
sc_in<bool> io_write_1_valid;
sc_in<bool> io_write_2_valid;
sc_in<bool> io_write_3_valid;
sc_in<bool> io_whint_0_valid;
sc_in<bool> io_whint_1_valid;
sc_in<bool> io_whint_2_valid;
sc_in<bool> io_whint_3_valid;
sc_in<bool> io_scalar_0_valid;
sc_in<bool> io_scalar_1_valid;
sc_out<sc_bv<7> > io_in_bits_0_bits_op;
sc_out<sc_bv<3> > io_in_bits_0_bits_f2;
sc_out<sc_bv<3> > io_in_bits_0_bits_sz;
sc_out<sc_bv<6> > io_in_bits_0_bits_vd_addr;
sc_out<sc_bv<6> > io_in_bits_0_bits_ve_addr;
sc_out<sc_bv<6> > io_in_bits_0_bits_vf_addr;
sc_out<sc_bv<6> > io_in_bits_0_bits_vg_addr;
sc_out<sc_bv<6> > io_in_bits_0_bits_vs_addr;
sc_out<sc_bv<6> > io_in_bits_0_bits_vt_addr;
sc_out<sc_bv<6> > io_in_bits_0_bits_vu_addr;
sc_out<sc_bv<6> > io_in_bits_0_bits_vx_addr;
sc_out<sc_bv<6> > io_in_bits_0_bits_vy_addr;
sc_out<sc_bv<6> > io_in_bits_0_bits_vz_addr;
sc_out<sc_bv<4> > io_in_bits_0_bits_vs_tag;
sc_out<sc_bv<4> > io_in_bits_0_bits_vt_tag;
sc_out<sc_bv<4> > io_in_bits_0_bits_vu_tag;
sc_out<sc_bv<4> > io_in_bits_0_bits_vx_tag;
sc_out<sc_bv<4> > io_in_bits_0_bits_vy_tag;
sc_out<sc_bv<4> > io_in_bits_0_bits_vz_tag;
sc_out<sc_bv<32> > io_in_bits_0_bits_sv_addr;
sc_out<sc_bv<32> > io_in_bits_0_bits_sv_data;
sc_out<sc_bv<7> > io_in_bits_1_bits_op;
sc_out<sc_bv<3> > io_in_bits_1_bits_f2;
sc_out<sc_bv<3> > io_in_bits_1_bits_sz;
sc_out<sc_bv<6> > io_in_bits_1_bits_vd_addr;
sc_out<sc_bv<6> > io_in_bits_1_bits_ve_addr;
sc_out<sc_bv<6> > io_in_bits_1_bits_vf_addr;
sc_out<sc_bv<6> > io_in_bits_1_bits_vg_addr;
sc_out<sc_bv<6> > io_in_bits_1_bits_vs_addr;
sc_out<sc_bv<6> > io_in_bits_1_bits_vt_addr;
sc_out<sc_bv<6> > io_in_bits_1_bits_vu_addr;
sc_out<sc_bv<6> > io_in_bits_1_bits_vx_addr;
sc_out<sc_bv<6> > io_in_bits_1_bits_vy_addr;
sc_out<sc_bv<6> > io_in_bits_1_bits_vz_addr;
sc_out<sc_bv<4> > io_in_bits_1_bits_vs_tag;
sc_out<sc_bv<4> > io_in_bits_1_bits_vt_tag;
sc_out<sc_bv<4> > io_in_bits_1_bits_vu_tag;
sc_out<sc_bv<4> > io_in_bits_1_bits_vx_tag;
sc_out<sc_bv<4> > io_in_bits_1_bits_vy_tag;
sc_out<sc_bv<4> > io_in_bits_1_bits_vz_tag;
sc_out<sc_bv<32> > io_in_bits_1_bits_sv_addr;
sc_out<sc_bv<32> > io_in_bits_1_bits_sv_data;
sc_out<sc_bv<7> > io_in_bits_2_bits_op;
sc_out<sc_bv<3> > io_in_bits_2_bits_f2;
sc_out<sc_bv<3> > io_in_bits_2_bits_sz;
sc_out<sc_bv<6> > io_in_bits_2_bits_vd_addr;
sc_out<sc_bv<6> > io_in_bits_2_bits_ve_addr;
sc_out<sc_bv<6> > io_in_bits_2_bits_vf_addr;
sc_out<sc_bv<6> > io_in_bits_2_bits_vg_addr;
sc_out<sc_bv<6> > io_in_bits_2_bits_vs_addr;
sc_out<sc_bv<6> > io_in_bits_2_bits_vt_addr;
sc_out<sc_bv<6> > io_in_bits_2_bits_vu_addr;
sc_out<sc_bv<6> > io_in_bits_2_bits_vx_addr;
sc_out<sc_bv<6> > io_in_bits_2_bits_vy_addr;
sc_out<sc_bv<6> > io_in_bits_2_bits_vz_addr;
sc_out<sc_bv<4> > io_in_bits_2_bits_vs_tag;
sc_out<sc_bv<4> > io_in_bits_2_bits_vt_tag;
sc_out<sc_bv<4> > io_in_bits_2_bits_vu_tag;
sc_out<sc_bv<4> > io_in_bits_2_bits_vx_tag;
sc_out<sc_bv<4> > io_in_bits_2_bits_vy_tag;
sc_out<sc_bv<4> > io_in_bits_2_bits_vz_tag;
sc_out<sc_bv<32> > io_in_bits_2_bits_sv_addr;
sc_out<sc_bv<32> > io_in_bits_2_bits_sv_data;
sc_out<sc_bv<7> > io_in_bits_3_bits_op;
sc_out<sc_bv<3> > io_in_bits_3_bits_f2;
sc_out<sc_bv<3> > io_in_bits_3_bits_sz;
sc_out<sc_bv<6> > io_in_bits_3_bits_vd_addr;
sc_out<sc_bv<6> > io_in_bits_3_bits_ve_addr;
sc_out<sc_bv<6> > io_in_bits_3_bits_vf_addr;
sc_out<sc_bv<6> > io_in_bits_3_bits_vg_addr;
sc_out<sc_bv<6> > io_in_bits_3_bits_vs_addr;
sc_out<sc_bv<6> > io_in_bits_3_bits_vt_addr;
sc_out<sc_bv<6> > io_in_bits_3_bits_vu_addr;
sc_out<sc_bv<6> > io_in_bits_3_bits_vx_addr;
sc_out<sc_bv<6> > io_in_bits_3_bits_vy_addr;
sc_out<sc_bv<6> > io_in_bits_3_bits_vz_addr;
sc_out<sc_bv<4> > io_in_bits_3_bits_vs_tag;
sc_out<sc_bv<4> > io_in_bits_3_bits_vt_tag;
sc_out<sc_bv<4> > io_in_bits_3_bits_vu_tag;
sc_out<sc_bv<4> > io_in_bits_3_bits_vx_tag;
sc_out<sc_bv<4> > io_in_bits_3_bits_vy_tag;
sc_out<sc_bv<4> > io_in_bits_3_bits_vz_tag;
sc_out<sc_bv<32> > io_in_bits_3_bits_sv_addr;
sc_out<sc_bv<32> > io_in_bits_3_bits_sv_data;
sc_in<sc_bv<64> > io_active;
sc_out<sc_bv<128> > io_vrfsb;
sc_in<sc_bv<6> > io_read_0_addr;
sc_in<bool> io_read_0_tag;
sc_out<sc_bv<kVector> > io_read_0_data;
sc_in<sc_bv<6> > io_read_1_addr;
sc_in<bool> io_read_1_tag;
sc_out<sc_bv<kVector> > io_read_1_data;
sc_in<sc_bv<6> > io_read_2_addr;
sc_in<bool> io_read_2_tag;
sc_out<sc_bv<kVector> > io_read_2_data;
sc_in<sc_bv<6> > io_read_3_addr;
sc_in<bool> io_read_3_tag;
sc_out<sc_bv<kVector> > io_read_3_data;
sc_in<sc_bv<6> > io_read_4_addr;
sc_in<bool> io_read_4_tag;
sc_out<sc_bv<kVector> > io_read_4_data;
sc_in<sc_bv<6> > io_read_5_addr;
sc_in<bool> io_read_5_tag;
sc_out<sc_bv<kVector> > io_read_5_data;
sc_in<sc_bv<6> > io_read_6_addr;
sc_in<bool> io_read_6_tag;
sc_out<sc_bv<kVector> > io_read_6_data;
sc_in<sc_bv<6> > io_write_0_addr;
sc_in<sc_bv<kVector> > io_write_0_data;
sc_in<sc_bv<6> > io_write_1_addr;
sc_in<sc_bv<kVector> > io_write_1_data;
sc_in<sc_bv<6> > io_write_2_addr;
sc_in<sc_bv<kVector> > io_write_2_data;
sc_in<sc_bv<6> > io_write_3_addr;
sc_in<sc_bv<kVector> > io_write_3_data;
sc_in<sc_bv<6> > io_whint_0_addr;
sc_in<sc_bv<6> > io_whint_1_addr;
sc_in<sc_bv<6> > io_whint_2_addr;
sc_in<sc_bv<6> > io_whint_3_addr;
sc_in<sc_bv<32> > io_scalar_0_data;
sc_in<sc_bv<32> > io_scalar_1_data;
using Sysc_tb::Sysc_tb;
void init() {
// Initialize registers to fixed values.
// This testbench is not for checking ALU arithmetic,
// it is for checking command queues and integration.
for (int i = 0; i < 60; ++i) {
for (int j = 0; j < kLanes; ++j) {
regs_[i][j] = rand_uint32();
}
}
for (int i = 60; i < 64; ++i) {
for (int j = 0; j < kLanes; ++j) {
regs_[i][j] = kLanes * (i - 60) + j;
}
}
for (int j = 0; j < kLanes; ++j) {
scalar_[j] = rand_uint32();
}
#if 0
for (int i = 0; i < 64; ++i) {
for (int j = 0; j < kLanes; ++j) {
regs_[i][j] = i;
}
}
#endif
}
void posedge() {
//-------------------------------------------------------------------------
// Active.
const uint64_t active = io_active.read().get_word(0) |
(uint64_t(io_active.read().get_word(1)) << 32);
// Tracking reads.
check(active == Ractive(), "io.active[1]");
// Tracking writes. Reads can retires 2-10cc before write.
check((active & ~Wactive()) == 0, "io.active[2]");
//-------------------------------------------------------------------------
// Inputs.
ProcessInputs(0);
ProcessInputs(1);
ProcessInputs(2);
ProcessInputs(3);
#if 0
printf("wactive ");
for (int i = 0; i < 64; ++i) {
printf("%d", write_[63 - i].valid);
}
printf("\n");
#endif
// -------------------------------------------------------------------------
// Outputs.
ProcessOutputs(0);
ProcessOutputs(1);
ProcessOutputs(2);
ProcessOutputs(3);
// -------------------------------------------------------------------------
// Scoreboard.
sc_bv<128> vrfsb = 0;
// Set upto four entries.
for (int i = 0; i < 4; ++i) {
vrfsb.set_bit(rand_int(0, 127), sc_dt::Log_1);
}
io_vrfsb = vrfsb;
// -------------------------------------------------------------------------
// Inputs.
io_in_valid = rand_bool();
// Speculatively set wactive in cycle. Will be updated above in write cycle.
uint64_t wactive = wactive_;
PrepareInputs(0, wactive);
PrepareInputs(1, wactive);
PrepareInputs(2, wactive);
PrepareInputs(3, wactive);
// -----------------------------------------------------------------------------
// Register reads.
ReadData(0);
ReadData(1);
ReadData(2);
ReadData(3);
ReadData(4);
ReadData(5);
ReadData(6);
}
private:
fifo_t<valu_t> cmdq_[4];
uint32_t regs_[64][kLanes]; // read-only
uint32_t scalar_[kLanes]; // read-only
int read_[64] = {0};
struct write_t {
bool valid;
// write
uint32_t data[kLanes];
// read
struct {
bool valid;
int addr;
} r[kReadPorts];
// tracking fields
uint8_t op : 7;
uint8_t f2 : 3;
uint8_t sz : 3;
} write_[64] = {0};
struct inputs_t {
uint8_t op : 7;
uint8_t f2 : 3;
uint8_t sz : 3;
bool m;
bool cmdsync;
struct {
bool valid;
int addr;
int data;
} sv;
struct {
bool valid;
int addr;
int tag;
} r[kReadPorts];
struct {
bool valid;
int addr;
} w[kWritePorts];
};
uint64_t wactive_ = 0;
uint64_t Ractive() {
uint64_t active = 0;
for (int i = 0; i < 64; ++i) {
if (read_[i] != 0) {
active |= 1ull << i;
}
}
return active;
}
uint64_t Wactive() {
uint64_t active = 0;
for (int i = 0; i < 64; ++i) {
if (!write_[i].valid) continue;
for (int j = 0; j < kReadPorts; ++j) {
if (!write_[i].r[j].valid) continue;
active |= 1ull << write_[i].r[j].addr;
}
}
return active;
}
bool FindInactiveWriteAddr(const bool m, uint64_t& wactive, int& addr) {
for (int retry = 0; retry < 16; ++retry) {
addr = rand_int(0, 63);
if (m) addr &= ~3;
uint64_t mask = (m ? 15ull : 1ull) << addr;
if (wactive & mask) continue;
wactive |= mask;
return true;
}
return false;
}
bool FindInactiveWriteAddr2(const bool m, uint64_t& wactive, int& addr) {
for (int retry = 0; retry < 16; ++retry) {
addr = rand_int(0, m ? 56 : 62);
if (m) addr &= ~3;
uint64_t mask = (m ? 255ull : 3ull) << addr;
if (wactive & mask) continue;
wactive |= mask;
return true;
}
return false;
}
void ReadData(const int idx) {
#define READ_DATA(idx) \
{ \
uint32_t addr = io_read_##idx##_addr.read().get_word(0); \
sc_bv<kVector> rdata = 0; \
if (io_read_##idx##_valid) { \
for (int i = 0; i < kLanes; ++i) { \
rdata.set_word(i, regs_[addr][i]); \
} \
if (io_read_##idx##_ready) { \
assert(read_[addr] > 0); \
read_[addr]--; \
} \
} \
if (idx == 1 && io_scalar_0_valid) { \
for (int i = 0; i < kLanes; ++i) { \
rdata.set_word(i, scalar_[i]); \
} \
} \
if (idx == 4 && io_scalar_1_valid) { \
for (int i = 0; i < kLanes; ++i) { \
rdata.set_word(i, scalar_[i]); \
} \
} \
io_read_##idx##_data = rdata; \
}
if (idx == 0) READ_DATA(0);
if (idx == 1) READ_DATA(1);
if (idx == 2) READ_DATA(2);
if (idx == 3) READ_DATA(3);
if (idx == 4) READ_DATA(4);
if (idx == 5) READ_DATA(5);
if (idx == 6) READ_DATA(6);
}
void PrepareInputs(const int idx, uint64_t& wactive) {
bool valid = rand_int(0, 3);
inputs_t in;
in.op = rand_int(0, encode::kOpEntries - 1);
in.f2 = rand_int(0, 7);
in.sz = 1u << rand_int(0, 2);
in.m = rand_int(0, 7) == 0;
in.cmdsync = false;
in.sv.valid = rand_int(0, 7) == 0;
in.sv.addr = rand_uint32();
in.sv.data = rand_uint32();
if (in.op == encode::vevn || in.op == encode::vevnodd ||
in.op == encode::vodd) {
// Disallow even/odd in CRT.
in.op = encode::vadd;
}
if (in.op == encode::vdwconv) {
// Disallow DW in CRT.
in.op = encode::vadd;
}
// Assign random values to inactive read addr/tag.
for (int i = 0; i < kReadPorts; ++i) {
in.r[i].valid = false;
in.r[i].addr = rand_uint32() & (in.m ? 60 : 63);
in.r[i].tag = rand_int(0, 15);
}
// Assign random values to inactive write addr, will be overridden.
for (int i = 0; i < kWritePorts; ++i) {
in.w[i].valid = false;
in.w[i].addr = rand_uint32() & (in.m ? 60 : 63);
}
switch (in.op) {
case encode::vabsd:
case encode::vadd:
case encode::vadds:
case encode::vhadd:
case encode::vhsub:
case encode::vmax:
case encode::vmin:
case encode::vrsub:
case encode::vsub:
case encode::vsubs:
case encode::veq:
case encode::vne:
case encode::vlt:
case encode::vle:
case encode::vgt:
case encode::vge:
case encode::vand:
case encode::vclb:
case encode::vclz:
case encode::vcpop:
case encode::vevn:
case encode::vor:
case encode::vrev:
case encode::vror:
case encode::vxor:
case encode::vdmulh:
case encode::vmul:
case encode::vmulh:
case encode::vmuls:
case encode::vshl:
case encode::vshr:
case encode::vshf:
in.r[0].valid = true;
in.r[1].valid = true;
in.w[0].valid = true;
break;
case encode::vaddw:
case encode::vevnodd:
case encode::vsubw:
case encode::vmulw:
case encode::vmvp:
case encode::vzip:
in.r[0].valid = true;
in.r[1].valid = true;
in.w[0].valid = true;
in.w[1].valid = true;
break;
case encode::vacc:
in.r[0].valid = true;
in.r[1].valid = true;
in.r[2].valid = true;
in.w[0].valid = true;
in.w[1].valid = true;
break;
case encode::vadd3:
case encode::vmadd:
case encode::vsrans:
in.r[0].valid = true;
in.r[1].valid = true;
in.r[2].valid = true;
in.w[0].valid = true;
break;
case encode::vsraqs:
in.r[0].valid = true;
in.r[1].valid = true;
in.r[2].valid = true;
in.r[3].valid = true;
in.r[5].valid = true;
in.w[0].valid = true;
in.cmdsync = true;
break;
case encode::vdup:
in.r[1].valid = true;
in.w[0].valid = true;
break;
case encode::vmv:
case encode::vpadd:
case encode::vpsub:
in.r[0].valid = true;
in.w[0].valid = true;
break;
case encode::vodd:
in.r[0].valid = true;
in.r[1].valid = true;
in.w[1].valid = true;
break;
case encode::vdwconv:
in.r[0].valid = true;
in.r[1].valid = true;
in.r[2].valid = true;
in.r[3].valid = true;
in.r[4].valid = true;
in.r[5].valid = true;
in.w[0].valid = true;
in.w[1].valid = true;
in.w[2].valid = true;
in.w[3].valid = true;
in.cmdsync = true;
break;
default:
valid = false;
// Assign random values, should not be accepted by queue.
for (int i = 0; i < kReadPorts; ++i) {
in.r[i].valid = rand_bool();
}
for (int i = 0; i < kWritePorts; ++i) {
in.w[i].valid = rand_bool();
}
break;
}
if (in.sv.valid) {
in.r[1].valid = false;
}
// Assign inactive write addresses.
if (in.op == encode::vzip) {
int addr = 0;
valid = valid && FindInactiveWriteAddr2(in.m, wactive, addr);
in.w[0].valid = valid;
in.w[0].addr = addr;
in.w[1].valid = valid;
in.w[1].addr = addr + 1;
} else {
for (int i = 0; i < kWritePorts; ++i) {
if (in.w[i].valid) {
int addr = 0;
valid = valid && FindInactiveWriteAddr(in.m, wactive, addr);
in.w[i].addr = addr;
}
}
for (int i = 0; i < kWritePorts; ++i) {
in.w[i].valid &= valid;
}
}
if (valid) {
int raddr[7] = {in.r[0].addr, in.r[1].addr, in.r[2].addr, in.r[3].addr,
in.r[4].addr, in.r[5].addr, in.r[6].addr};
int waddr[4] = {in.w[0].addr, in.w[1].addr, in.w[2].addr, in.w[3].addr};
for (int m = 0; m < (in.m ? 4 : 1); ++m) {
valu_t alu;
alu.op = in.op;
alu.f2 = in.f2;
alu.sz = in.sz;
alu.sv.data = in.sv.data;
for (int i = 0; i < kReadPorts; ++i) {
alu.r[i].valid = in.r[i].valid;
alu.r[i].addr = raddr[i];
for (int j = 0; j < kLanes; ++j) {
alu.in[i].data[j] = regs_[raddr[i]][j];
}
raddr[i]++; // stripmine update
}
// Scalar read first register.
alu.scalar.valid = in.sv.valid;
if (in.sv.valid) {
for (int j = 0; j < kLanes; ++j) {
alu.in[1].data[j] = scalar_[j];
}
}
for (int i = 0; i < kWritePorts; ++i) {
alu.w[i].valid = false;
alu.w[i].addr = waddr[i];
}
VAlu(alu); // the reference model
for (int i = 0; i < kWritePorts; ++i) {
if (alu.w[i].valid) {
wactive |= 1ull << waddr[i];
if (in.op == encode::vzip) {
waddr[i] += 2;
} else {
waddr[i]++; // stripmine update
}
}
}
cmdq_[idx].write(alu);
}
}
#define IN_BITS(idx) \
{ \
io_in_bits_##idx##_valid = valid; \
io_in_bits_##idx##_bits_op = in.op; \
io_in_bits_##idx##_bits_f2 = in.f2; \
io_in_bits_##idx##_bits_sz = in.sz; \
io_in_bits_##idx##_bits_m = in.m; \
io_in_bits_##idx##_bits_vd_valid = in.w[0].valid; \
io_in_bits_##idx##_bits_ve_valid = in.w[1].valid; \
io_in_bits_##idx##_bits_vf_valid = in.w[2].valid; \
io_in_bits_##idx##_bits_vg_valid = in.w[3].valid; \
io_in_bits_##idx##_bits_vs_valid = in.r[0].valid; \
io_in_bits_##idx##_bits_vt_valid = in.r[1].valid; \
io_in_bits_##idx##_bits_vu_valid = in.r[2].valid; \
io_in_bits_##idx##_bits_vx_valid = in.r[3].valid; \
io_in_bits_##idx##_bits_vy_valid = in.r[4].valid; \
io_in_bits_##idx##_bits_vz_valid = in.r[5].valid; \
io_in_bits_##idx##_bits_vd_addr = in.w[0].addr; \
io_in_bits_##idx##_bits_ve_addr = in.w[1].addr; \
io_in_bits_##idx##_bits_vf_addr = in.w[2].addr; \
io_in_bits_##idx##_bits_vg_addr = in.w[3].addr; \
io_in_bits_##idx##_bits_vs_addr = in.r[0].addr; \
io_in_bits_##idx##_bits_vt_addr = in.r[1].addr; \
io_in_bits_##idx##_bits_vu_addr = in.r[2].addr; \
io_in_bits_##idx##_bits_vx_addr = in.r[3].addr; \
io_in_bits_##idx##_bits_vy_addr = in.r[4].addr; \
io_in_bits_##idx##_bits_vz_addr = in.r[5].addr; \
io_in_bits_##idx##_bits_vs_tag = in.r[0].tag; \
io_in_bits_##idx##_bits_vt_tag = in.r[1].tag; \
io_in_bits_##idx##_bits_vu_tag = in.r[2].tag; \
io_in_bits_##idx##_bits_vx_tag = in.r[3].tag; \
io_in_bits_##idx##_bits_vy_tag = in.r[4].tag; \
io_in_bits_##idx##_bits_vz_tag = in.r[5].tag; \
io_in_bits_##idx##_bits_sv_valid = in.sv.valid; \
io_in_bits_##idx##_bits_sv_addr = in.sv.addr; \
io_in_bits_##idx##_bits_sv_data = in.sv.data; \
io_in_bits_##idx##_bits_cmdsync = in.cmdsync; \
}
if (idx == 0) IN_BITS(0);
if (idx == 1) IN_BITS(1);
if (idx == 2) IN_BITS(2);
if (idx == 3) IN_BITS(3);
}
void ProcessInputs(const int idx) {
// clang-format off
if (!(io_in_valid && io_in_ready) ||
(idx == 0 && !io_in_bits_0_valid) ||
(idx == 1 && !io_in_bits_1_valid) ||
(idx == 2 && !io_in_bits_2_valid) ||
(idx == 3 && !io_in_bits_3_valid)) {
cmdq_[idx].clear();
return;
}
// clang-format on
valu_t op;
while (cmdq_[idx].read(op)) {
bool has_write = false;
for (int i = 0; i < kWritePorts; ++i) {
if (op.w[i].valid) {
const int addr = op.w[i].addr;
const uint32_t* data = op.out[i].data;
check(!write_[addr].valid, "ProcessInputs::io.write.valid");
write_[addr].valid = true;
wactive_ |= 1ull << addr;
write_[addr].op = op.op;
write_[addr].f2 = op.f2;
write_[addr].sz = op.sz;
for (int j = 0; j < kReadPorts; ++j) {
write_[addr].r[j].valid = op.r[j].valid;
write_[addr].r[j].addr = op.r[j].addr;
}
for (int j = 0; j < kLanes; ++j) {
write_[addr].data[j] = data[j];
}
}
has_write = true;
}
if (has_write) {
for (int j = 0; j < kReadPorts; ++j) {
if (op.r[j].valid) { // only add reads once
read_[op.r[j].addr]++;
}
}
}
}
}
void ProcessOutputs(const int idx) {
// clang-format off
if ((idx == 0 && !io_write_0_valid) ||
(idx == 1 && !io_write_1_valid) ||
(idx == 2 && !io_write_2_valid) ||
(idx == 3 && !io_write_3_valid)) {
return;
}
// clang-format on
int addr;
uint32_t dut[kLanes];
#define OUT_WRITE(idx) \
{ \
addr = io_write_##idx##_addr.read().get_word(0); \
for (int i = 0; i < kLanes; ++i) { \
dut[i] = io_write_##idx##_data.read().get_word(i); \
} \
}
if (idx == 0) OUT_WRITE(0);
if (idx == 1) OUT_WRITE(1);
if (idx == 2) OUT_WRITE(2);
if (idx == 3) OUT_WRITE(3);
check(write_[addr].valid, "ProcessOutputs::io.write.valid");
write_[addr].valid = false;
wactive_ &= ~(1ull << addr);
uint32_t* ref = write_[addr].data;
if (memcmp(dut, ref, kLanes * 4)) {
char s[100];
snprintf(s, sizeof(s), "valu op=%d f2=%d sz=%d", write_[addr].op,
write_[addr].f2, write_[addr].sz);
printf("ref[%2d] ", addr);
for (int i = 0; i < kLanes; ++i) {
printf(" %08x", ref[i]);
}
printf("\n");
printf("dut[%2d] ", addr);
for (int i = 0; i < kLanes; ++i) {
printf(" %08x", dut[i]);
}
printf("\n");
for (int j = 0; j < kReadPorts; ++j) {
bool active = write_[addr].r[j].valid;
const int ridx = write_[addr].r[j].addr;
printf("read[%c][%2d] ", active ? 'x' : ' ', ridx);
for (int i = 0; i < kLanes; ++i) {
printf(" %08x", regs_[ridx][i]);
}
printf("\n");
}
check(false, s);
}
}
};
static void VAlu_test(char* name, int loops, bool trace) {
sc_signal<bool> io_in_ready;
sc_signal<bool> io_in_valid;
sc_signal<bool> io_in_bits_0_valid;
sc_signal<bool> io_in_bits_0_bits_m;
sc_signal<bool> io_in_bits_0_bits_vd_valid;
sc_signal<bool> io_in_bits_0_bits_ve_valid;
sc_signal<bool> io_in_bits_0_bits_vf_valid;
sc_signal<bool> io_in_bits_0_bits_vg_valid;
sc_signal<bool> io_in_bits_0_bits_vs_valid;
sc_signal<bool> io_in_bits_0_bits_vt_valid;
sc_signal<bool> io_in_bits_0_bits_vu_valid;
sc_signal<bool> io_in_bits_0_bits_vx_valid;
sc_signal<bool> io_in_bits_0_bits_vy_valid;
sc_signal<bool> io_in_bits_0_bits_vz_valid;
sc_signal<bool> io_in_bits_0_bits_sv_valid;
sc_signal<bool> io_in_bits_0_bits_cmdsync;
sc_signal<bool> io_in_bits_1_valid;
sc_signal<bool> io_in_bits_1_bits_m;
sc_signal<bool> io_in_bits_1_bits_vd_valid;
sc_signal<bool> io_in_bits_1_bits_ve_valid;
sc_signal<bool> io_in_bits_1_bits_vf_valid;
sc_signal<bool> io_in_bits_1_bits_vg_valid;
sc_signal<bool> io_in_bits_1_bits_vs_valid;
sc_signal<bool> io_in_bits_1_bits_vt_valid;
sc_signal<bool> io_in_bits_1_bits_vu_valid;
sc_signal<bool> io_in_bits_1_bits_vx_valid;
sc_signal<bool> io_in_bits_1_bits_vy_valid;
sc_signal<bool> io_in_bits_1_bits_vz_valid;
sc_signal<bool> io_in_bits_1_bits_sv_valid;
sc_signal<bool> io_in_bits_1_bits_cmdsync;
sc_signal<bool> io_in_bits_2_valid;
sc_signal<bool> io_in_bits_2_bits_m;
sc_signal<bool> io_in_bits_2_bits_vd_valid;
sc_signal<bool> io_in_bits_2_bits_ve_valid;
sc_signal<bool> io_in_bits_2_bits_vf_valid;
sc_signal<bool> io_in_bits_2_bits_vg_valid;
sc_signal<bool> io_in_bits_2_bits_vs_valid;
sc_signal<bool> io_in_bits_2_bits_vt_valid;
sc_signal<bool> io_in_bits_2_bits_vu_valid;
sc_signal<bool> io_in_bits_2_bits_vx_valid;
sc_signal<bool> io_in_bits_2_bits_vy_valid;
sc_signal<bool> io_in_bits_2_bits_vz_valid;
sc_signal<bool> io_in_bits_2_bits_sv_valid;
sc_signal<bool> io_in_bits_2_bits_cmdsync;
sc_signal<bool> io_in_bits_3_valid;
sc_signal<bool> io_in_bits_3_bits_m;
sc_signal<bool> io_in_bits_3_bits_vd_valid;
sc_signal<bool> io_in_bits_3_bits_ve_valid;
sc_signal<bool> io_in_bits_3_bits_vf_valid;
sc_signal<bool> io_in_bits_3_bits_vg_valid;
sc_signal<bool> io_in_bits_3_bits_vs_valid;
sc_signal<bool> io_in_bits_3_bits_vt_valid;
sc_signal<bool> io_in_bits_3_bits_vu_valid;
sc_signal<bool> io_in_bits_3_bits_vx_valid;
sc_signal<bool> io_in_bits_3_bits_vy_valid;
sc_signal<bool> io_in_bits_3_bits_vz_valid;
sc_signal<bool> io_in_bits_3_bits_sv_valid;
sc_signal<bool> io_in_bits_3_bits_cmdsync;
sc_signal<bool> io_read_0_valid;
sc_signal<bool> io_read_1_valid;
sc_signal<bool> io_read_2_valid;
sc_signal<bool> io_read_3_valid;
sc_signal<bool> io_read_4_valid;
sc_signal<bool> io_read_5_valid;
sc_signal<bool> io_read_6_valid;
sc_signal<bool> io_read_0_ready;
sc_signal<bool> io_read_1_ready;
sc_signal<bool> io_read_2_ready;
sc_signal<bool> io_read_3_ready;
sc_signal<bool> io_read_4_ready;
sc_signal<bool> io_read_5_ready;
sc_signal<bool> io_read_6_ready;
sc_signal<bool> io_write_0_valid;
sc_signal<bool> io_write_1_valid;
sc_signal<bool> io_write_2_valid;
sc_signal<bool> io_write_3_valid;
sc_signal<bool> io_whint_0_valid;
sc_signal<bool> io_whint_1_valid;
sc_signal<bool> io_whint_2_valid;
sc_signal<bool> io_whint_3_valid;
sc_signal<bool> io_scalar_0_valid;
sc_signal<bool> io_scalar_1_valid;
sc_signal<sc_bv<7> > io_in_bits_0_bits_op;
sc_signal<sc_bv<3> > io_in_bits_0_bits_f2;
sc_signal<sc_bv<3> > io_in_bits_0_bits_sz;
sc_signal<sc_bv<6> > io_in_bits_0_bits_vd_addr;
sc_signal<sc_bv<6> > io_in_bits_0_bits_ve_addr;
sc_signal<sc_bv<6> > io_in_bits_0_bits_vf_addr;
sc_signal<sc_bv<6> > io_in_bits_0_bits_vg_addr;
sc_signal<sc_bv<6> > io_in_bits_0_bits_vs_addr;
sc_signal<sc_bv<6> > io_in_bits_0_bits_vt_addr;
sc_signal<sc_bv<6> > io_in_bits_0_bits_vu_addr;
sc_signal<sc_bv<6> > io_in_bits_0_bits_vx_addr;
sc_signal<sc_bv<6> > io_in_bits_0_bits_vy_addr;
sc_signal<sc_bv<6> > io_in_bits_0_bits_vz_addr;
sc_signal<sc_bv<4> > io_in_bits_0_bits_vs_tag;
sc_signal<sc_bv<4> > io_in_bits_0_bits_vt_tag;
sc_signal<sc_bv<4> > io_in_bits_0_bits_vu_tag;
sc_signal<sc_bv<4> > io_in_bits_0_bits_vx_tag;
sc_signal<sc_bv<4> > io_in_bits_0_bits_vy_tag;
sc_signal<sc_bv<4> > io_in_bits_0_bits_vz_tag;
sc_signal<sc_bv<32> > io_in_bits_0_bits_sv_addr;
sc_signal<sc_bv<32> > io_in_bits_0_bits_sv_data;
sc_signal<sc_bv<7> > io_in_bits_1_bits_op;
sc_signal<sc_bv<3> > io_in_bits_1_bits_f2;
sc_signal<sc_bv<3> > io_in_bits_1_bits_sz;
sc_signal<sc_bv<6> > io_in_bits_1_bits_vd_addr;
sc_signal<sc_bv<6> > io_in_bits_1_bits_ve_addr;
sc_signal<sc_bv<6> > io_in_bits_1_bits_vf_addr;
sc_signal<sc_bv<6> > io_in_bits_1_bits_vg_addr;
sc_signal<sc_bv<6> > io_in_bits_1_bits_vs_addr;
sc_signal<sc_bv<6> > io_in_bits_1_bits_vt_addr;
sc_signal<sc_bv<6> > io_in_bits_1_bits_vu_addr;
sc_signal<sc_bv<6> > io_in_bits_1_bits_vx_addr;
sc_signal<sc_bv<6> > io_in_bits_1_bits_vy_addr;
sc_signal<sc_bv<6> > io_in_bits_1_bits_vz_addr;
sc_signal<sc_bv<4> > io_in_bits_1_bits_vs_tag;
sc_signal<sc_bv<4> > io_in_bits_1_bits_vt_tag;
sc_signal<sc_bv<4> > io_in_bits_1_bits_vu_tag;
sc_signal<sc_bv<4> > io_in_bits_1_bits_vx_tag;
sc_signal<sc_bv<4> > io_in_bits_1_bits_vy_tag;
sc_signal<sc_bv<4> > io_in_bits_1_bits_vz_tag;
sc_signal<sc_bv<32> > io_in_bits_1_bits_sv_addr;
sc_signal<sc_bv<32> > io_in_bits_1_bits_sv_data;
sc_signal<sc_bv<7> > io_in_bits_2_bits_op;
sc_signal<sc_bv<3> > io_in_bits_2_bits_f2;
sc_signal<sc_bv<3> > io_in_bits_2_bits_sz;
sc_signal<sc_bv<6> > io_in_bits_2_bits_vd_addr;
sc_signal<sc_bv<6> > io_in_bits_2_bits_ve_addr;
sc_signal<sc_bv<6> > io_in_bits_2_bits_vf_addr;
sc_signal<sc_bv<6> > io_in_bits_2_bits_vg_addr;
sc_signal<sc_bv<6> > io_in_bits_2_bits_vs_addr;
sc_signal<sc_bv<6> > io_in_bits_2_bits_vt_addr;
sc_signal<sc_bv<6> > io_in_bits_2_bits_vu_addr;
sc_signal<sc_bv<6> > io_in_bits_2_bits_vx_addr;
sc_signal<sc_bv<6> > io_in_bits_2_bits_vy_addr;
sc_signal<sc_bv<6> > io_in_bits_2_bits_vz_addr;
sc_signal<sc_bv<4> > io_in_bits_2_bits_vs_tag;
sc_signal<sc_bv<4> > io_in_bits_2_bits_vt_tag;
sc_signal<sc_bv<4> > io_in_bits_2_bits_vu_tag;
sc_signal<sc_bv<4> > io_in_bits_2_bits_vx_tag;
sc_signal<sc_bv<4> > io_in_bits_2_bits_vy_tag;
sc_signal<sc_bv<4> > io_in_bits_2_bits_vz_tag;
sc_signal<sc_bv<32> > io_in_bits_2_bits_sv_addr;
sc_signal<sc_bv<32> > io_in_bits_2_bits_sv_data;
sc_signal<sc_bv<7> > io_in_bits_3_bits_op;
sc_signal<sc_bv<3> > io_in_bits_3_bits_f2;
sc_signal<sc_bv<3> > io_in_bits_3_bits_sz;
sc_signal<sc_bv<6> > io_in_bits_3_bits_vd_addr;
sc_signal<sc_bv<6> > io_in_bits_3_bits_ve_addr;
sc_signal<sc_bv<6> > io_in_bits_3_bits_vf_addr;
sc_signal<sc_bv<6> > io_in_bits_3_bits_vg_addr;
sc_signal<sc_bv<6> > io_in_bits_3_bits_vs_addr;
sc_signal<sc_bv<6> > io_in_bits_3_bits_vt_addr;
sc_signal<sc_bv<6> > io_in_bits_3_bits_vu_addr;
sc_signal<sc_bv<6> > io_in_bits_3_bits_vx_addr;
sc_signal<sc_bv<6> > io_in_bits_3_bits_vy_addr;
sc_signal<sc_bv<6> > io_in_bits_3_bits_vz_addr;
sc_signal<sc_bv<4> > io_in_bits_3_bits_vs_tag;
sc_signal<sc_bv<4> > io_in_bits_3_bits_vt_tag;
sc_signal<sc_bv<4> > io_in_bits_3_bits_vu_tag;
sc_signal<sc_bv<4> > io_in_bits_3_bits_vx_tag;
sc_signal<sc_bv<4> > io_in_bits_3_bits_vy_tag;
sc_signal<sc_bv<4> > io_in_bits_3_bits_vz_tag;
sc_signal<sc_bv<32> > io_in_bits_3_bits_sv_addr;
sc_signal<sc_bv<32> > io_in_bits_3_bits_sv_data;
sc_signal<sc_bv<64> > io_active;
sc_signal<sc_bv<128> > io_vrfsb;
sc_signal<sc_bv<6> > io_read_0_addr;
sc_signal<bool> io_read_0_tag;
sc_signal<sc_bv<kVector> > io_read_0_data;
sc_signal<sc_bv<6> > io_read_1_addr;
sc_signal<bool> io_read_1_tag;
sc_signal<sc_bv<kVector> > io_read_1_data;
sc_signal<sc_bv<6> > io_read_2_addr;
sc_signal<bool> io_read_2_tag;
sc_signal<sc_bv<kVector> > io_read_2_data;
sc_signal<sc_bv<6> > io_read_3_addr;
sc_signal<bool> io_read_3_tag;
sc_signal<sc_bv<kVector> > io_read_3_data;
sc_signal<sc_bv<6> > io_read_4_addr;
sc_signal<bool> io_read_4_tag;
sc_signal<sc_bv<kVector> > io_read_4_data;
sc_signal<sc_bv<6> > io_read_5_addr;
sc_signal<bool> io_read_5_tag;
sc_signal<sc_bv<kVector> > io_read_5_data;
sc_signal<sc_bv<6> > io_read_6_addr;
sc_signal<bool> io_read_6_tag;
sc_signal<sc_bv<kVector> > io_read_6_data;
sc_signal<sc_bv<6> > io_write_0_addr;
sc_signal<sc_bv<kVector> > io_write_0_data;
sc_signal<sc_bv<6> > io_write_1_addr;
sc_signal<sc_bv<kVector> > io_write_1_data;
sc_signal<sc_bv<6> > io_write_2_addr;
sc_signal<sc_bv<kVector> > io_write_2_data;
sc_signal<sc_bv<6> > io_write_3_addr;
sc_signal<sc_bv<kVector> > io_write_3_data;
sc_signal<sc_bv<6> > io_whint_0_addr;
sc_signal<sc_bv<6> > io_whint_1_addr;
sc_signal<sc_bv<6> > io_whint_2_addr;
sc_signal<sc_bv<6> > io_whint_3_addr;
sc_signal<sc_bv<32> > io_scalar_0_data;
sc_signal<sc_bv<32> > io_scalar_1_data;
VAlu_tb tb("VAlu_tb", loops);
VVAlu valu(name);
if (trace) {
tb.trace(valu);
}
valu.clock(tb.clock);
valu.reset(tb.reset);
BIND2(tb, valu, io_in_ready);
BIND2(tb, valu, io_in_valid);
BIND2(tb, valu, io_in_bits_0_valid);
BIND2(tb, valu, io_in_bits_0_bits_m);
BIND2(tb, valu, io_in_bits_0_bits_vd_valid);
BIND2(tb, valu, io_in_bits_0_bits_ve_valid);
BIND2(tb, valu, io_in_bits_0_bits_vf_valid);
BIND2(tb, valu, io_in_bits_0_bits_vg_valid);
BIND2(tb, valu, io_in_bits_0_bits_vs_valid);
BIND2(tb, valu, io_in_bits_0_bits_vt_valid);
BIND2(tb, valu, io_in_bits_0_bits_vu_valid);
BIND2(tb, valu, io_in_bits_0_bits_vx_valid);
BIND2(tb, valu, io_in_bits_0_bits_vy_valid);
BIND2(tb, valu, io_in_bits_0_bits_vz_valid);
BIND2(tb, valu, io_in_bits_0_bits_sv_valid);
BIND2(tb, valu, io_in_bits_0_bits_cmdsync);
BIND2(tb, valu, io_in_bits_1_valid);
BIND2(tb, valu, io_in_bits_1_bits_m);
BIND2(tb, valu, io_in_bits_1_bits_vd_valid);
BIND2(tb, valu, io_in_bits_1_bits_ve_valid);
BIND2(tb, valu, io_in_bits_1_bits_vf_valid);
BIND2(tb, valu, io_in_bits_1_bits_vg_valid);
BIND2(tb, valu, io_in_bits_1_bits_vs_valid);
BIND2(tb, valu, io_in_bits_1_bits_vt_valid);
BIND2(tb, valu, io_in_bits_1_bits_vu_valid);
BIND2(tb, valu, io_in_bits_1_bits_vx_valid);
BIND2(tb, valu, io_in_bits_1_bits_vy_valid);
BIND2(tb, valu, io_in_bits_1_bits_vz_valid);
BIND2(tb, valu, io_in_bits_1_bits_sv_valid);
BIND2(tb, valu, io_in_bits_1_bits_cmdsync);
BIND2(tb, valu, io_in_bits_2_valid);
BIND2(tb, valu, io_in_bits_2_bits_m);
BIND2(tb, valu, io_in_bits_2_bits_vd_valid);
BIND2(tb, valu, io_in_bits_2_bits_ve_valid);
BIND2(tb, valu, io_in_bits_2_bits_vf_valid);
BIND2(tb, valu, io_in_bits_2_bits_vg_valid);
BIND2(tb, valu, io_in_bits_2_bits_vs_valid);
BIND2(tb, valu, io_in_bits_2_bits_vt_valid);
BIND2(tb, valu, io_in_bits_2_bits_vu_valid);
BIND2(tb, valu, io_in_bits_2_bits_vx_valid);
BIND2(tb, valu, io_in_bits_2_bits_vy_valid);
BIND2(tb, valu, io_in_bits_2_bits_vz_valid);
BIND2(tb, valu, io_in_bits_2_bits_sv_valid);
BIND2(tb, valu, io_in_bits_2_bits_cmdsync);
BIND2(tb, valu, io_in_bits_3_valid);
BIND2(tb, valu, io_in_bits_3_bits_m);
BIND2(tb, valu, io_in_bits_3_bits_vd_valid);
BIND2(tb, valu, io_in_bits_3_bits_ve_valid);
BIND2(tb, valu, io_in_bits_3_bits_vf_valid);
BIND2(tb, valu, io_in_bits_3_bits_vg_valid);
BIND2(tb, valu, io_in_bits_3_bits_vs_valid);
BIND2(tb, valu, io_in_bits_3_bits_vt_valid);
BIND2(tb, valu, io_in_bits_3_bits_vu_valid);
BIND2(tb, valu, io_in_bits_3_bits_vx_valid);
BIND2(tb, valu, io_in_bits_3_bits_vy_valid);
BIND2(tb, valu, io_in_bits_3_bits_vz_valid);
BIND2(tb, valu, io_in_bits_3_bits_sv_valid);
BIND2(tb, valu, io_in_bits_3_bits_cmdsync);
BIND2(tb, valu, io_read_0_valid);
BIND2(tb, valu, io_read_1_valid);
BIND2(tb, valu, io_read_2_valid);
BIND2(tb, valu, io_read_3_valid);
BIND2(tb, valu, io_read_4_valid);
BIND2(tb, valu, io_read_5_valid);
BIND2(tb, valu, io_read_6_valid);
BIND2(tb, valu, io_read_0_ready);
BIND2(tb, valu, io_read_1_ready);
BIND2(tb, valu, io_read_2_ready);
BIND2(tb, valu, io_read_3_ready);
BIND2(tb, valu, io_read_4_ready);
BIND2(tb, valu, io_read_5_ready);
BIND2(tb, valu, io_read_6_ready);
BIND2(tb, valu, io_write_0_valid);
BIND2(tb, valu, io_write_1_valid);
BIND2(tb, valu, io_write_2_valid);
BIND2(tb, valu, io_write_3_valid);
BIND2(tb, valu, io_whint_0_valid);
BIND2(tb, valu, io_whint_1_valid);
BIND2(tb, valu, io_whint_2_valid);
BIND2(tb, valu, io_whint_3_valid);
BIND2(tb, valu, io_scalar_0_valid);
BIND2(tb, valu, io_scalar_1_valid);
BIND2(tb, valu, io_in_bits_0_bits_op);
BIND2(tb, valu, io_in_bits_0_bits_f2);
BIND2(tb, valu, io_in_bits_0_bits_sz);
BIND2(tb, valu, io_in_bits_0_bits_vd_addr);
BIND2(tb, valu, io_in_bits_0_bits_ve_addr);
BIND2(tb, valu, io_in_bits_0_bits_vf_addr);
BIND2(tb, valu, io_in_bits_0_bits_vg_addr);
BIND2(tb, valu, io_in_bits_0_bits_vs_addr);
BIND2(tb, valu, io_in_bits_0_bits_vt_addr);
BIND2(tb, valu, io_in_bits_0_bits_vu_addr);
BIND2(tb, valu, io_in_bits_0_bits_vx_addr);
BIND2(tb, valu, io_in_bits_0_bits_vy_addr);
BIND2(tb, valu, io_in_bits_0_bits_vz_addr);
BIND2(tb, valu, io_in_bits_0_bits_vs_tag);
BIND2(tb, valu, io_in_bits_0_bits_vt_tag);
BIND2(tb, valu, io_in_bits_0_bits_vu_tag);
BIND2(tb, valu, io_in_bits_0_bits_vx_tag);
BIND2(tb, valu, io_in_bits_0_bits_vy_tag);
BIND2(tb, valu, io_in_bits_0_bits_vz_tag);
BIND2(tb, valu, io_in_bits_0_bits_sv_addr);
BIND2(tb, valu, io_in_bits_0_bits_sv_data);
BIND2(tb, valu, io_in_bits_1_bits_op);
BIND2(tb, valu, io_in_bits_1_bits_f2);
BIND2(tb, valu, io_in_bits_1_bits_sz);
BIND2(tb, valu, io_in_bits_1_bits_vd_addr);
BIND2(tb, valu, io_in_bits_1_bits_ve_addr);
BIND2(tb, valu, io_in_bits_1_bits_vf_addr);
BIND2(tb, valu, io_in_bits_1_bits_vg_addr);
BIND2(tb, valu, io_in_bits_1_bits_vs_addr);
BIND2(tb, valu, io_in_bits_1_bits_vt_addr);
BIND2(tb, valu, io_in_bits_1_bits_vu_addr);
BIND2(tb, valu, io_in_bits_1_bits_vx_addr);
BIND2(tb, valu, io_in_bits_1_bits_vy_addr);
BIND2(tb, valu, io_in_bits_1_bits_vz_addr);
BIND2(tb, valu, io_in_bits_1_bits_vs_tag);
BIND2(tb, valu, io_in_bits_1_bits_vt_tag);
BIND2(tb, valu, io_in_bits_1_bits_vu_tag);
BIND2(tb, valu, io_in_bits_1_bits_vx_tag);
BIND2(tb, valu, io_in_bits_1_bits_vy_tag);
BIND2(tb, valu, io_in_bits_1_bits_vz_tag);
BIND2(tb, valu, io_in_bits_1_bits_sv_addr);
BIND2(tb, valu, io_in_bits_1_bits_sv_data);
BIND2(tb, valu, io_in_bits_2_bits_op);
BIND2(tb, valu, io_in_bits_2_bits_f2);
BIND2(tb, valu, io_in_bits_2_bits_sz);
BIND2(tb, valu, io_in_bits_2_bits_vd_addr);
BIND2(tb, valu, io_in_bits_2_bits_ve_addr);
BIND2(tb, valu, io_in_bits_2_bits_vf_addr);
BIND2(tb, valu, io_in_bits_2_bits_vg_addr);
BIND2(tb, valu, io_in_bits_2_bits_vs_addr);
BIND2(tb, valu, io_in_bits_2_bits_vt_addr);
BIND2(tb, valu, io_in_bits_2_bits_vu_addr);
BIND2(tb, valu, io_in_bits_2_bits_vx_addr);
BIND2(tb, valu, io_in_bits_2_bits_vy_addr);
BIND2(tb, valu, io_in_bits_2_bits_vz_addr);
BIND2(tb, valu, io_in_bits_2_bits_vs_tag);
BIND2(tb, valu, io_in_bits_2_bits_vt_tag);
BIND2(tb, valu, io_in_bits_2_bits_vu_tag);
BIND2(tb, valu, io_in_bits_2_bits_vx_tag);
BIND2(tb, valu, io_in_bits_2_bits_vy_tag);
BIND2(tb, valu, io_in_bits_2_bits_vz_tag);
BIND2(tb, valu, io_in_bits_2_bits_sv_addr);
BIND2(tb, valu, io_in_bits_2_bits_sv_data);
BIND2(tb, valu, io_in_bits_3_bits_op);
BIND2(tb, valu, io_in_bits_3_bits_f2);
BIND2(tb, valu, io_in_bits_3_bits_sz);
BIND2(tb, valu, io_in_bits_3_bits_vd_addr);
BIND2(tb, valu, io_in_bits_3_bits_ve_addr);
BIND2(tb, valu, io_in_bits_3_bits_vf_addr);
BIND2(tb, valu, io_in_bits_3_bits_vg_addr);
BIND2(tb, valu, io_in_bits_3_bits_vs_addr);
BIND2(tb, valu, io_in_bits_3_bits_vt_addr);
BIND2(tb, valu, io_in_bits_3_bits_vu_addr);
BIND2(tb, valu, io_in_bits_3_bits_vx_addr);
BIND2(tb, valu, io_in_bits_3_bits_vy_addr);
BIND2(tb, valu, io_in_bits_3_bits_vz_addr);
BIND2(tb, valu, io_in_bits_3_bits_vs_tag);
BIND2(tb, valu, io_in_bits_3_bits_vt_tag);
BIND2(tb, valu, io_in_bits_3_bits_vu_tag);
BIND2(tb, valu, io_in_bits_3_bits_vx_tag);
BIND2(tb, valu, io_in_bits_3_bits_vy_tag);
BIND2(tb, valu, io_in_bits_3_bits_vz_tag);
BIND2(tb, valu, io_in_bits_3_bits_sv_addr);
BIND2(tb, valu, io_in_bits_3_bits_sv_data);
BIND2(tb, valu, io_active);
BIND2(tb, valu, io_vrfsb);
BIND2(tb, valu, io_read_0_addr);
BIND2(tb, valu, io_read_0_tag);
BIND2(tb, valu, io_read_0_data);
BIND2(tb, valu, io_read_1_addr);
BIND2(tb, valu, io_read_1_tag);
BIND2(tb, valu, io_read_1_data);
BIND2(tb, valu, io_read_2_addr);
BIND2(tb, valu, io_read_2_tag);
BIND2(tb, valu, io_read_2_data);
BIND2(tb, valu, io_read_3_addr);
BIND2(tb, valu, io_read_3_tag);
BIND2(tb, valu, io_read_3_data);
BIND2(tb, valu, io_read_4_addr);
BIND2(tb, valu, io_read_4_tag);
BIND2(tb, valu, io_read_4_data);
BIND2(tb, valu, io_read_5_addr);
BIND2(tb, valu, io_read_5_tag);
BIND2(tb, valu, io_read_5_data);
BIND2(tb, valu, io_read_6_addr);
BIND2(tb, valu, io_read_6_tag);
BIND2(tb, valu, io_read_6_data);
BIND2(tb, valu, io_write_0_addr);
BIND2(tb, valu, io_write_0_data);
BIND2(tb, valu, io_write_1_addr);
BIND2(tb, valu, io_write_1_data);
BIND2(tb, valu, io_write_2_addr);
BIND2(tb, valu, io_write_2_data);
BIND2(tb, valu, io_write_3_addr);
BIND2(tb, valu, io_write_3_data);
BIND2(tb, valu, io_whint_0_addr);
BIND2(tb, valu, io_whint_1_addr);
BIND2(tb, valu, io_whint_2_addr);
BIND2(tb, valu, io_whint_3_addr);
BIND2(tb, valu, io_scalar_0_data);
BIND2(tb, valu, io_scalar_1_data);
tb.start();
}
int sc_main(int argc, char* argv[]) {
VAlu_test(Sysc_tb::get_name(argv[0]), 1000000, false);
return 0;
}