mirror of
https://github.com/YosysHQ/yosys
synced 2026-05-25 03:16:22 +00:00
test_patch total basics
This commit is contained in:
parent
6f0be1b4e9
commit
89e5c4ccca
4 changed files with 62 additions and 3 deletions
|
|
@ -1,4 +1,6 @@
|
|||
#include "kernel/unstable/patch.h"
|
||||
#include "kernel/celltypes.h"
|
||||
#include "kernel/rtlil.h"
|
||||
|
||||
YOSYS_NAMESPACE_BEGIN
|
||||
|
||||
|
|
@ -10,6 +12,24 @@ Cell* Patch::addCell(IdString name, IdString type) {
|
|||
return &cell;
|
||||
}
|
||||
|
||||
void Patch::patch() {
|
||||
for (auto& cell: cells_) {
|
||||
Cell* new_cell = mod->addCell(cell.name, &cell);
|
||||
for (auto [port_name, sig] : new_cell->connections()) {
|
||||
log_assert(yosys_celltypes.cell_known(cell.type));
|
||||
auto dir = cell.port_dir(port_name);
|
||||
if (dir == PD_OUTPUT || dir == PD_INOUT) {
|
||||
for (auto chunk : sig.chunks()) {
|
||||
log_assert(chunk.is_wire());
|
||||
auto* wire = chunk.wire;
|
||||
wire->driverCell_->setPort(wire->driverPort_, SigSpec());
|
||||
wire->driverCell_ = new_cell;
|
||||
wire->driverPort_ = port_name;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
YOSYS_NAMESPACE_END
|
||||
|
|
@ -2,6 +2,7 @@
|
|||
#define PATCH_H
|
||||
|
||||
#include "kernel/rtlil.h"
|
||||
#include "kernel/sigtools.h"
|
||||
|
||||
YOSYS_NAMESPACE_BEGIN
|
||||
|
||||
|
|
@ -16,17 +17,18 @@ protected:
|
|||
void add(RTLIL::Process *process);
|
||||
|
||||
public:
|
||||
// RTLIL::Design *design;
|
||||
Module *mod;
|
||||
SigMap map;
|
||||
vector<Wire> wires_;
|
||||
vector<Cell> cells_;
|
||||
|
||||
vector<RTLIL::SigSig> connections_;
|
||||
vector<RTLIL::SigSig> connections_;
|
||||
|
||||
void connect(const RTLIL::SigSig &conn);
|
||||
void connect(const RTLIL::SigSpec &lhs, const RTLIL::SigSpec &rhs);
|
||||
const std::vector<RTLIL::SigSig> &connections() const;
|
||||
|
||||
void patch(RTLIL::Module *mod);
|
||||
void patch();
|
||||
RTLIL::Wire *addWire(RTLIL::IdString name, int width = 1);
|
||||
RTLIL::Wire *addWire(RTLIL::IdString name, const RTLIL::Wire *other);
|
||||
|
||||
|
|
|
|||
|
|
@ -60,5 +60,6 @@ OBJS += passes/cmds/timeest.o
|
|||
OBJS += passes/cmds/linecoverage.o
|
||||
OBJS += passes/cmds/sort.o
|
||||
OBJS += passes/cmds/icell_liberty.o
|
||||
OBJS += passes/cmds/test_patch.o
|
||||
|
||||
include $(YOSYS_SRC)/passes/cmds/sdc/Makefile.inc
|
||||
|
|
|
|||
36
passes/cmds/test_patch.cc
Normal file
36
passes/cmds/test_patch.cc
Normal file
|
|
@ -0,0 +1,36 @@
|
|||
#include "kernel/rtlil.h"
|
||||
#include "kernel/yosys.h"
|
||||
#include "kernel/unstable/patch.h"
|
||||
|
||||
USING_YOSYS_NAMESPACE
|
||||
PRIVATE_NAMESPACE_BEGIN
|
||||
|
||||
struct TestPatchPass : public Pass {
|
||||
TestPatchPass() : Pass("test_patch", "test patcher") { }
|
||||
void help() override
|
||||
{
|
||||
}
|
||||
void execute(std::vector<std::string> args, RTLIL::Design *design) override
|
||||
{
|
||||
(void) args;
|
||||
RTLIL::Patch patcher;
|
||||
design->bufNormalize();
|
||||
for (auto module : design->selected_modules()) {
|
||||
patcher.mod = module;
|
||||
patcher.map = SigMap(module);
|
||||
for (auto cell : module->selected_cells()) {
|
||||
if (cell->type == ID($add)) {
|
||||
RTLIL::Cell* sub = patcher.addCell(NEW_ID, ID($sub));
|
||||
sub->connections_ = cell->connections();
|
||||
sub->parameters = cell->parameters;
|
||||
sub->setPort(ID::A, cell->getPort(ID::A));
|
||||
sub->setPort(ID::B, cell->getPort(ID::B));
|
||||
sub->setPort(ID::Y, cell->getPort(ID::Y));
|
||||
patcher.patch();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} TestPatchPass;
|
||||
|
||||
PRIVATE_NAMESPACE_END
|
||||
Loading…
Add table
Add a link
Reference in a new issue