Vortex 2.0 changes:
+ Microarchitecture optimizations + 64-bit support + Xilinx FPGA support + LLVM-16 support + Refactoring and quality control fixes
This commit is contained in:
@@ -1,3 +1,16 @@
|
||||
// Copyright © 2019-2023
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
|
||||
#pragma once
|
||||
|
||||
@@ -5,14 +18,38 @@
|
||||
#include <iostream>
|
||||
#include <util.h>
|
||||
#include "types.h"
|
||||
#include "archdef.h"
|
||||
#include "arch.h"
|
||||
#include "debug.h"
|
||||
|
||||
namespace vortex {
|
||||
|
||||
class ITraceData {
|
||||
public:
|
||||
using Ptr = std::shared_ptr<ITraceData>;
|
||||
ITraceData() {}
|
||||
virtual ~ITraceData() {}
|
||||
};
|
||||
|
||||
struct LsuTraceData : public ITraceData {
|
||||
using Ptr = std::shared_ptr<LsuTraceData>;
|
||||
std::vector<mem_addr_size_t> mem_addrs;
|
||||
LsuTraceData(uint32_t num_threads) : mem_addrs(num_threads) {}
|
||||
};
|
||||
|
||||
struct SFUTraceData : public ITraceData {
|
||||
using Ptr = std::shared_ptr<SFUTraceData>;
|
||||
struct {
|
||||
uint32_t id;
|
||||
uint32_t count;
|
||||
} bar;
|
||||
SFUTraceData(uint32_t bar_id, uint32_t bar_count) : bar{bar_id, bar_count} {}
|
||||
};
|
||||
|
||||
struct pipeline_trace_t {
|
||||
public:
|
||||
//--
|
||||
uint64_t uuid;
|
||||
const uint64_t uuid;
|
||||
const Arch& arch;
|
||||
|
||||
//--
|
||||
uint32_t cid;
|
||||
@@ -21,12 +58,9 @@ struct pipeline_trace_t {
|
||||
Word PC;
|
||||
|
||||
//--
|
||||
bool fetch_stall;
|
||||
|
||||
//--
|
||||
bool wb;
|
||||
RegType rdest_type;
|
||||
uint32_t rdest;
|
||||
RegType rdest_type;
|
||||
bool wb;
|
||||
|
||||
//--
|
||||
RegMask used_iregs;
|
||||
@@ -36,73 +70,104 @@ struct pipeline_trace_t {
|
||||
//-
|
||||
ExeType exe_type;
|
||||
|
||||
//--
|
||||
std::vector<std::vector<mem_addr_size_t>> mem_addrs;
|
||||
|
||||
//--
|
||||
union {
|
||||
struct {
|
||||
LsuType type;
|
||||
} lsu;
|
||||
struct {
|
||||
AluType type;
|
||||
} alu;
|
||||
struct {
|
||||
FpuType type;
|
||||
} fpu;
|
||||
struct {
|
||||
GpuType type;
|
||||
WarpMask active_warps;
|
||||
} gpu;
|
||||
uint32_t unit_type;
|
||||
LsuType lsu_type;
|
||||
AluType alu_type;
|
||||
FpuType fpu_type;
|
||||
SfuType sfu_type;
|
||||
};
|
||||
|
||||
bool stalled;
|
||||
ITraceData::Ptr data;
|
||||
|
||||
pipeline_trace_t(uint64_t uuid_, const ArchDef& arch) {
|
||||
uuid = uuid_;
|
||||
cid = 0;
|
||||
wid = 0;
|
||||
tmask.reset();
|
||||
PC = 0;
|
||||
fetch_stall = false;
|
||||
wb = false;
|
||||
rdest = 0;
|
||||
rdest_type = RegType::None;
|
||||
used_iregs.reset();
|
||||
used_fregs.reset();
|
||||
used_vregs.reset();
|
||||
exe_type = ExeType::NOP;
|
||||
mem_addrs.resize(arch.num_threads());
|
||||
stalled = false;
|
||||
}
|
||||
int pid;
|
||||
bool sop;
|
||||
bool eop;
|
||||
|
||||
bool suspend() {
|
||||
bool old = stalled;
|
||||
stalled = true;
|
||||
bool fetch_stall;
|
||||
|
||||
pipeline_trace_t(uint64_t uuid, const Arch& arch)
|
||||
: uuid(uuid)
|
||||
, arch(arch)
|
||||
, cid(0)
|
||||
, wid(0)
|
||||
, tmask(0)
|
||||
, PC(0)
|
||||
, rdest(0)
|
||||
, rdest_type(RegType::None)
|
||||
, wb(false)
|
||||
, used_iregs(0)
|
||||
, used_fregs(0)
|
||||
, used_vregs(0)
|
||||
, exe_type(ExeType::ALU)
|
||||
, unit_type(0)
|
||||
, data(nullptr)
|
||||
, pid(-1)
|
||||
, sop(true)
|
||||
, eop(true)
|
||||
, fetch_stall(false)
|
||||
, log_once_(false)
|
||||
{}
|
||||
|
||||
pipeline_trace_t(const pipeline_trace_t& rhs)
|
||||
: uuid(rhs.uuid)
|
||||
, arch(rhs.arch)
|
||||
, cid(rhs.cid)
|
||||
, wid(rhs.wid)
|
||||
, tmask(rhs.tmask)
|
||||
, PC(rhs.PC)
|
||||
, rdest(rhs.rdest)
|
||||
, rdest_type(rhs.rdest_type)
|
||||
, wb(rhs.wb)
|
||||
, used_iregs(rhs.used_iregs)
|
||||
, used_fregs(rhs.used_fregs)
|
||||
, used_vregs(rhs.used_vregs)
|
||||
, exe_type(rhs.exe_type)
|
||||
, unit_type(rhs.unit_type)
|
||||
, data(rhs.data)
|
||||
, pid(rhs.pid)
|
||||
, sop(rhs.sop)
|
||||
, eop(rhs.eop)
|
||||
, fetch_stall(rhs.fetch_stall)
|
||||
, log_once_(false)
|
||||
{}
|
||||
|
||||
~pipeline_trace_t() {}
|
||||
|
||||
bool log_once(bool enable) {
|
||||
bool old = log_once_;
|
||||
log_once_ = enable;
|
||||
return old;
|
||||
}
|
||||
|
||||
void resume() {
|
||||
stalled = false;
|
||||
}
|
||||
private:
|
||||
bool log_once_;
|
||||
};
|
||||
|
||||
inline std::ostream &operator<<(std::ostream &os, const pipeline_trace_t& state) {
|
||||
os << "coreid=" << state.cid << ", wid=" << state.wid << ", PC=" << std::hex << state.PC;
|
||||
os << "cid=" << state.cid;
|
||||
os << ", wid=" << state.wid;
|
||||
os << ", tmask=";
|
||||
for (uint32_t i = 0, n = state.arch.num_threads(); i < n; ++i) {
|
||||
os << state.tmask.test(i);
|
||||
}
|
||||
os << ", PC=0x" << std::hex << state.PC;
|
||||
os << ", wb=" << state.wb;
|
||||
if (state.wb) {
|
||||
os << ", rd=" << state.rdest_type << std::dec << state.rdest;
|
||||
}
|
||||
os << ", ex=" << state.exe_type;
|
||||
if (state.pid != -1) {
|
||||
os << ", pid=" << state.pid;
|
||||
os << ", sop=" << state.sop;
|
||||
os << ", eop=" << state.eop;
|
||||
}
|
||||
os << " (#" << std::dec << state.uuid << ")";
|
||||
return os;
|
||||
}
|
||||
|
||||
class PipelineLatch {
|
||||
protected:
|
||||
const char* name_;
|
||||
std::queue<pipeline_trace_t*> queue_;
|
||||
|
||||
public:
|
||||
PipelineLatch(const char* name = nullptr)
|
||||
: name_(name)
|
||||
@@ -132,6 +197,10 @@ public:
|
||||
std::queue<pipeline_trace_t*> empty;
|
||||
std::swap(queue_, empty );
|
||||
}
|
||||
|
||||
protected:
|
||||
const char* name_;
|
||||
std::queue<pipeline_trace_t*> queue_;
|
||||
};
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user