Skip to content

Commit

Permalink
[HW] Fix more bugs related to input/output specific functions.
Browse files Browse the repository at this point in the history
Fix more hold-overs from when input and output were split.

See #6707
  • Loading branch information
darthscsi committed Feb 16, 2024
1 parent cef977a commit 9e0c169
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 28 deletions.
36 changes: 21 additions & 15 deletions include/circt/Dialect/HW/HWOpInterfaces.td
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ def HWModuleLike : OpInterface<"HWModuleLike", [
"SmallVector<Location>", "getAllPortLocs", (ins)>,

InterfaceMethod<"Set the port Locations",
"void", "setAllPortLocs", (ins "ArrayRef<Location>":$locs)>,
"void", "setAllPortLocsAttrs", (ins "ArrayRef<Attribute>":$locs)>,

InterfaceMethod<"Set the module type (and port names)",
"void", "setHWModuleType", (ins "::circt::hw::ModuleType":$type)>,
Expand Down Expand Up @@ -259,6 +259,11 @@ def HWModuleLike : OpInterface<"HWModuleLike", [
$_op.setAllPortAttrs(attrs);
}

void setAllPortLocs(ArrayRef<Location> locs) {
std::vector<Attribute> nLocs(locs.begin(), locs.end());
$_op.setAllPortLocsAttrs(nLocs);
}

Location getPortLoc(size_t idx) {
return $_op.getAllPortLocs()[idx];
}
Expand Down Expand Up @@ -293,13 +298,14 @@ def HWModuleLike : OpInterface<"HWModuleLike", [
return ArrayAttr::get($_op->getContext(), retval);
}

void setInputLocs(ArrayRef<Location> inAttrs) {
assert(inAttrs.size() == $_op.getNumInputPorts());
auto outAttrs = getOutputLocs();
SmallVector<Location> attrs;
attrs.append(inAttrs.begin(), inAttrs.end());
attrs.append(outAttrs.begin(), outAttrs.end());
$_op.setAllPortLocs(attrs);
void setInputLocs(ArrayRef<Location> inLocs) {
assert(inLocs.size() == $_op.getNumInputPorts());
auto type = $_op.getHWModuleType();
SmallVector<Location> newLocs($_op.getAllPortLocs());
for (size_t idx = 0, e = inLocs.size(); idx != e; ++idx)
newLocs[type.getPortIdForInputId(idx)] = inLocs[idx];
$_op.setAllPortLocs(newLocs);

}

SmallVector<Location> getOutputLocs() {
Expand All @@ -318,13 +324,13 @@ def HWModuleLike : OpInterface<"HWModuleLike", [
return ArrayAttr::get($_op->getContext(), retval);
}

void setOutputLocs(ArrayRef<Location> outAttrs) {
assert(outAttrs.size() == $_op.getNumOutputPorts());
auto inAttrs = getInputLocs();
SmallVector<Location> attrs;
attrs.append(inAttrs.begin(), inAttrs.end());
attrs.append(outAttrs.begin(), outAttrs.end());
$_op.setAllPortLocs(attrs);
void setOutputLocs(ArrayRef<Location> outLocs) {
assert(outLocs.size() == $_op.getNumOutputPorts());
auto type = $_op.getHWModuleType();
SmallVector<Location> newLocs($_op.getAllPortLocs());
for (size_t idx = 0, e = outLocs.size(); idx != e; ++idx)
newLocs[type.getPortIdForOutputId(idx)] = outLocs[idx];
$_op.setAllPortLocs(newLocs);
}
}];

Expand Down
2 changes: 1 addition & 1 deletion lib/Dialect/ESI/ESIOps.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -598,7 +598,7 @@ SmallVector<Location> ESIPureModuleOp::getAllPortLocs() {
return retval;
}

void ESIPureModuleOp::setAllPortLocs(ArrayRef<Location> locs) {
void ESIPureModuleOp::setAllPortLocsAttrs(ArrayRef<Attribute> locs) {
emitError("No ports for port locations");
}

Expand Down
18 changes: 6 additions & 12 deletions lib/Dialect/HW/HWOps.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1246,13 +1246,7 @@ SmallVector<Location> HWModuleGeneratedOp::getAllPortLocs() {
return ::getAllPortLocs(*this);
}

template <typename ModTy>
static void setAllPortLocs(ArrayRef<Location> locs, ModTy module) {
std::vector<Attribute> nLocs(locs.begin(), locs.end());
module.setPortLocsAttr(ArrayAttr::get(module.getContext(), nLocs));
}

void HWModuleOp::setAllPortLocs(ArrayRef<Location> locs) {
void HWModuleOp::setAllPortLocsAttrs(ArrayRef<Attribute> locs) {
SmallVector<Attribute> resultLocs;
unsigned inputCount = 0;
auto modType = getModuleType();
Expand All @@ -1261,17 +1255,17 @@ void HWModuleOp::setAllPortLocs(ArrayRef<Location> locs) {
if (modType.isOutput(i))
resultLocs.push_back(locs[i]);
else
body->getArgument(inputCount++).setLoc(locs[i]);
body->getArgument(inputCount++).setLoc(cast<Location>(locs[i]));
}
setResultLocsAttr(ArrayAttr::get(getContext(), resultLocs));
}

void HWModuleExternOp::setAllPortLocs(ArrayRef<Location> locs) {
::setAllPortLocs(locs, *this);
void HWModuleExternOp::setAllPortLocsAttrs(ArrayRef<Attribute> locs) {
setPortLocsAttr(ArrayAttr::get(getContext(), locs));
}

void HWModuleGeneratedOp::setAllPortLocs(ArrayRef<Location> locs) {
::setAllPortLocs(locs, *this);
void HWModuleGeneratedOp::setAllPortLocsAttrs(ArrayRef<Attribute> locs) {
setPortLocsAttr(ArrayAttr::get(getContext(), locs));
}

template <typename ModTy>
Expand Down

0 comments on commit 9e0c169

Please sign in to comment.