51 OpBuilder builder(mod);
54 uint64_t currentWidth = 0;
55 auto ui64Type = builder.getIntegerType(64,
false);
56 mod.walk([&](Operation *op) {
57 if (!isa<RegOp, RegResetOp>(op))
62 auto regType = type_cast<FIRRTLBaseType>(op->getResult(0).getType());
63 std::optional<int64_t> regWidth =
getBitWidth(regType);
64 assert(regWidth.has_value() &&
"register must have a valid FIRRTL width");
66 auto start = builder.getIntegerAttr(ui64Type, currentWidth);
67 op->setAttr(
"firrtl.random_init_start", start);
69 currentWidth += *regWidth;