16#include "mlir/IR/Builders.h"
17#include "mlir/IR/BuiltinTypes.h"
18#include "mlir/IR/Diagnostics.h"
19#include "mlir/IR/DialectImplementation.h"
20#include "mlir/IR/StorageUniquerSupport.h"
21#include "mlir/IR/Types.h"
22#include "llvm/ADT/StringExtras.h"
23#include "llvm/ADT/TypeSwitch.h"
33#define GET_TYPEDEF_CLASSES
34#include "circt/Dialect/Seq/SeqTypes.cpp.inc"
36void SeqDialect::registerTypes() {
38#define GET_TYPEDEF_LIST
39#include "circt/Dialect/Seq/SeqTypes.cpp.inc"
48 if (hw::type_isa<seq::ClockType>(ty))
50 if (hw::isHWIntegerType(ty) && hw::getBitWidth(ty) == 1)
59HLMemType HLMemType::cloneWith(std::optional<ArrayRef<int64_t>> shape,
61 return HLMemType::get(
elementType.getContext(), shape.value_or(getShape()),
65llvm::SmallVector<Type> HLMemType::getAddressTypes()
const {
66 auto *ctx = getContext();
67 llvm::SmallVector<Type> addressTypes;
68 for (
auto dim : getShape())
69 addressTypes.push_back(IntegerType::get(ctx,
llvm::Log2_64_Ceil(dim)));
73Type HLMemType::parse(mlir::AsmParser &odsParser) {
74 llvm::SmallVector<int64_t> shape;
76 if (odsParser.parseLess() ||
77 odsParser.parseDimensionList(shape,
false,
79 odsParser.parseType(
elementType) || odsParser.parseGreater())
82 return HLMemType::get(odsParser.getContext(), shape,
elementType);
85void HLMemType::print(AsmPrinter &odsPrinter)
const {
87 for (
auto dim : getShape())
88 odsPrinter << dim <<
'x';
89 odsPrinter << getElementType();
94HLMemType::verify(llvm::function_ref<::mlir::InFlightDiagnostic()> emitError,
97 return emitError() <<
"shape must have at least one dimension.";
bool isClockOrI1Type(Type ty)
Returns true if the type is i1 or seq.clock
The InstanceGraph op interface, see InstanceGraphInterface.td for more details.