LLZK 0.1.0
Veridise's ZK Language IR
|
Namespaces | |
namespace | affineMapHelpers |
Group together all implementation related to AffineMap type parameters. | |
namespace | array |
namespace | boolean |
namespace | cast |
namespace | component |
namespace | constrain |
namespace | dataflow |
namespace | debug |
namespace | felt |
namespace | function |
namespace | global |
namespace | impl |
namespace | include |
namespace | polymorphic |
namespace | string |
namespace | undef |
Classes | |
class | BuildShortTypeString |
Note: If any symbol refs in an input Type/Attribute use any of the special characters that this class generates, they are not escaped. More... | |
class | CallGraph |
This is a port of mlir::CallGraph that has been adapted to use the custom symbol lookup helpers (see SymbolHelper.h). More... | |
class | CallGraphAnalysis |
An analysis wrapper to compute the CallGraph for a Module . More... | |
class | CallGraphNode |
This is a simple port of the mlir::CallGraphNode with llzk::CallGraph as a friend class, for mlir::CallGraphNode has a private constructor and can only be constructed by mlir::CallGraph. More... | |
class | CallGraphPrinterPass |
class | CallGraphReachabilityAnalysis |
Lazily-constructed reachability analysis. More... | |
class | CallGraphSCCsPrinterPass |
class | ConstrainRef |
Defines a reference to a llzk object within a constrain function call. More... | |
class | ConstrainRefAnalysis |
The dataflow analysis that computes the set of references that LLZK operations use and produce. More... | |
class | ConstrainRefIndex |
Defines an index into an LLZK object. More... | |
class | ConstrainRefLattice |
A lattice for use in dense analysis. More... | |
class | ConstrainRefLatticeValue |
A value at a given point of the ConstrainRefLattice. More... | |
class | ConstrainRefSet |
class | ConstraintDependencyGraph |
A dependency graph of constraints enforced by an LLZK struct. More... | |
class | ConstraintDependencyGraphModuleAnalysis |
A module-level analysis for constructing ConstraintDependencyGraph objects for all structs in the given LLZK module. More... | |
class | ConstraintDependencyGraphPrinterPass |
class | ConstraintDependencyGraphStructAnalysis |
An analysis wrapper around the ConstraintDependencyGraph for a given struct. More... | |
class | ExpressionValue |
Tracks a solver expression and an interval range for that expression. More... | |
class | Field |
Information about the prime finite field used for the interval analysis. More... | |
class | filtered_raw_ostream |
Wrapper for llvm::raw_ostream that filters out certain characters selected by a function. More... | |
struct | FullPolyLoweringOptions |
class | GlobalSourceMgr |
class | Interval |
Intervals over a finite field. More... | |
struct | IntervalAnalysisContext |
Parameters and shared objects to pass to child analyses. More... | |
class | IntervalAnalysisLattice |
Maps mlir::Values to LatticeValues. More... | |
class | IntervalAnalysisLatticeValue |
class | IntervalAnalysisPrinterPass |
struct | IntervalAnalysisPrinterPassOptions |
class | IntervalDataFlowAnalysis |
class | LLZKDialect |
struct | LLZKDialectBytecodeInterface |
This implements the bytecode interface for the LLZK dialect. More... | |
struct | LLZKDialectVersion |
class | ModuleAnalysis |
An analysis wrapper that runs the given StructAnalysisTy struct analysis over all of the struct contained within the module. More... | |
class | ModuleBuilder |
Builds out a LLZK-compliant module and provides utilities for populating that module. More... | |
class | ModuleIntervalAnalysis |
struct | NamedOpLocationLess |
struct | NoContext |
An empty struct that is used for convenience for analyses that do not require any context. More... | |
struct | OpHash |
struct | OpLocationLess |
struct | PolyLoweringPassOptions |
class | StructAnalysis |
This is the base class for a dataflow analysis designed to run on a single struct (i.e., a single component). More... | |
class | StructIntervalAnalysis |
class | StructIntervals |
class | SymbolLookupResult |
class | SymbolLookupResultUntyped |
class | UnreducedInterval |
An inclusive interval [a, b] where a and b are arbitrary integers not necessarily bound to a given field. More... | |
struct | UnusedDeclarationEliminationPassOptions |
struct | VerifySizesForMultiAffineOps |
Produces errors if there is an inconsistency in the various attributes/values that are used to support affine map instantiation in the Op marked with this Trait. More... | |
class | Within |
Concepts | |
concept | StructAnalysisType |
Any type that is a subclass of StructAnalysis . | |
concept | OpComparable |
concept | NamedOpComparable |
concept | OpHashable |
Typedefs | |
using | TranslationMap |
using | ConstrainRefRemappings = std::vector<std::pair<ConstrainRef, ConstrainRefLatticeValue>> |
using | EmitErrorFn = llvm::function_ref<mlir::InFlightDiagnostic()> |
using | OwningEmitErrorFn = std::function<mlir::InFlightDiagnostic()> |
using | ManagedResources |
using | UnificationMap = mlir::DenseMap<std::pair<mlir::SymbolRefAttr, Side>, mlir::Attribute> |
Optional result from type unifications. | |
Enumerations | |
enum class | Side { EMPTY = 0 , LHS , RHS , TOMB } |
Functions | |
std::unique_ptr< mlir::Pass > | createCallGraphPrinterPass (llvm::raw_ostream &os=llvm::errs()) |
std::unique_ptr< mlir::Pass > | createCallGraphSCCsPrinterPass (llvm::raw_ostream &os=llvm::errs()) |
SymbolLookupResult< StructDefOp > | getStructDef (mlir::SymbolTableCollection &tables, mlir::ModuleOp mod, StructType ty) |
Lookup a StructDefOp from a given StructType . | |
mlir::raw_ostream & | operator<< (mlir::raw_ostream &os, const ConstrainRef &rhs) |
mlir::raw_ostream & | operator<< (mlir::raw_ostream &os, const ConstrainRefSet &rhs) |
mlir::raw_ostream & | operator<< (mlir::raw_ostream &os, const ConstrainRefLatticeValue &v) |
llvm::raw_ostream & | operator<< (llvm::raw_ostream &os, const ConstrainRefLattice &lattice) |
std::unique_ptr< mlir::Pass > | createConstraintDependencyGraphPrinterPass (llvm::raw_ostream &os=llvm::errs()) |
UnreducedInterval | operator+ (const UnreducedInterval &lhs, const UnreducedInterval &rhs) |
UnreducedInterval | operator- (const UnreducedInterval &lhs, const UnreducedInterval &rhs) |
UnreducedInterval | operator* (const UnreducedInterval &lhs, const UnreducedInterval &rhs) |
std::strong_ordering | operator<=> (const UnreducedInterval &lhs, const UnreducedInterval &rhs) |
Interval | operator+ (const Interval &lhs, const Interval &rhs) |
Interval | operator- (const Interval &lhs, const Interval &rhs) |
Interval | operator* (const Interval &lhs, const Interval &rhs) |
FailureOr< Interval > | operator/ (const Interval &lhs, const Interval &rhs) |
Interval | operator% (const Interval &lhs, const Interval &rhs) |
ExpressionValue | intersection (llvm::SMTSolverRef solver, const ExpressionValue &lhs, const ExpressionValue &rhs) |
ExpressionValue | add (llvm::SMTSolverRef solver, const ExpressionValue &lhs, const ExpressionValue &rhs) |
ExpressionValue | sub (llvm::SMTSolverRef solver, const ExpressionValue &lhs, const ExpressionValue &rhs) |
ExpressionValue | mul (llvm::SMTSolverRef solver, const ExpressionValue &lhs, const ExpressionValue &rhs) |
ExpressionValue | div (llvm::SMTSolverRef solver, felt::DivFeltOp op, const ExpressionValue &lhs, const ExpressionValue &rhs) |
ExpressionValue | mod (llvm::SMTSolverRef solver, const ExpressionValue &lhs, const ExpressionValue &rhs) |
ExpressionValue | cmp (llvm::SMTSolverRef solver, boolean::CmpOp op, const ExpressionValue &lhs, const ExpressionValue &rhs) |
ExpressionValue | fallbackBinaryOp (llvm::SMTSolverRef solver, Operation *op, const ExpressionValue &lhs, const ExpressionValue &rhs) |
ExpressionValue | neg (llvm::SMTSolverRef solver, const ExpressionValue &val) |
ExpressionValue | notOp (llvm::SMTSolverRef solver, const ExpressionValue &val) |
ExpressionValue | fallbackUnaryOp (llvm::SMTSolverRef solver, Operation *op, const ExpressionValue &val) |
std::unique_ptr< mlir::Pass > | createIntervalAnalysisPrinterPass (llvm::raw_ostream &os=llvm::errs()) |
void | registerAllDialects (mlir::DialectRegistry ®istry) |
void | printAttrs (AsmPrinter &printer, ArrayRef< Attribute > attrs, const StringRef &separator) |
OwningOpRef< ModuleOp > | createLLZKModule (MLIRContext *context, Location loc) |
void | addLangAttrForLLZKDialect (mlir::ModuleOp mod) |
void | addRemoveUnnecessaryOpsAndDefsPipeline (OpPassManager &pm) |
void | registerTransformationPassPipelines () |
llvm::APSInt | expandingAdd (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
Safely add lhs and rhs, expanding the width of the result as necessary. | |
llvm::APSInt | expandingSub (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
Safely subtract lhs and rhs, expanding the width of the result as necessary. | |
llvm::APSInt | expandingMul (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
Safely multiple lhs and rhs, expanding the width of the result as necessary. | |
std::strong_ordering | safeCmp (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
Compares lhs and rhs, regardless of the bitwidth of lhs and rhs. | |
llvm::SmallVector< StringRef > | getNames (SymbolRefAttr ref) |
llvm::SmallVector< FlatSymbolRefAttr > | getPieces (SymbolRefAttr ref) |
SymbolRefAttr | replaceLeaf (SymbolRefAttr orig, FlatSymbolRefAttr newLeaf) |
SymbolRefAttr | appendLeaf (SymbolRefAttr orig, FlatSymbolRefAttr newLeaf) |
SymbolRefAttr | appendLeafName (SymbolRefAttr orig, const Twine &newLeafSuffix) |
FailureOr< ModuleOp > | getRootModule (Operation *from) |
FailureOr< SymbolRefAttr > | getPathFromRoot (StructDefOp &to) |
FailureOr< SymbolRefAttr > | getPathFromRoot (FuncDefOp &to) |
FailureOr< ModuleOp > | getTopRootModule (Operation *from) |
FailureOr< SymbolRefAttr > | getPathFromTopRoot (StructDefOp &to) |
FailureOr< SymbolRefAttr > | getPathFromTopRoot (FuncDefOp &to) |
bool | hasUsesWithin (Operation *symbol, Operation *from) |
LogicalResult | verifyParamOfType (SymbolTableCollection &tables, SymbolRefAttr param, Type parameterizedType, Operation *origin) |
LogicalResult | verifyParamsOfType (SymbolTableCollection &tables, ArrayRef< Attribute > tyParams, Type parameterizedType, Operation *origin) |
FailureOr< StructDefOp > | verifyStructTypeResolution (SymbolTableCollection &tables, StructType ty, Operation *origin) |
LogicalResult | verifyTypeResolution (SymbolTableCollection &tables, Operation *origin, Type ty) |
bool | isValidType (Type type) |
bool | isValidColumnType (Type type, SymbolTableCollection &symbolTable, Operation *op) |
bool | isValidGlobalType (Type type) |
bool | isValidEmitEqType (Type type) |
bool | isValidConstReadType (Type type) |
bool | isValidArrayElemType (Type type) |
bool | isValidArrayType (Type type) |
bool | isConcreteType (Type type, bool allowStructParams) |
bool | isSignalType (Type type) |
bool | isSignalType (component::StructType sType) |
Return true iff the given StructType is referencing the COMPONENT_NAME_SIGNAL struct. | |
bool | hasAffineMapAttr (Type type) |
bool | isDynamic (IntegerAttr intAttr) |
bool | typeParamsUnify (const ArrayRef< Attribute > &lhsParams, const ArrayRef< Attribute > &rhsParams, UnificationMap *unifications) |
bool | typeParamsUnify (const ArrayAttr &lhsParams, const ArrayAttr &rhsParams, UnificationMap *unifications) |
Return true iff the two ArrayAttr instances containing StructType or ArrayType parameters are equivalent or could be equivalent after full instantiation of struct parameters. | |
bool | arrayTypesUnify (ArrayType lhs, ArrayType rhs, ArrayRef< StringRef > rhsReversePrefix, UnificationMap *unifications) |
bool | structTypesUnify (StructType lhs, StructType rhs, ArrayRef< StringRef > rhsReversePrefix, UnificationMap *unifications) |
bool | typesUnify (Type lhs, Type rhs, ArrayRef< StringRef > rhsReversePrefix, UnificationMap *unifications) |
bool | isMoreConcreteUnification (Type oldTy, Type newTy, llvm::function_ref< bool(Type oldTy, Type newTy)> knownOldToNew) |
IntegerAttr | forceIntType (IntegerAttr attr) |
Attribute | forceIntAttrType (Attribute attr) |
SmallVector< Attribute > | forceIntAttrTypes (ArrayRef< Attribute > attrList) |
LogicalResult | verifyIntAttrType (EmitErrorFn emitError, Attribute in) |
LogicalResult | verifyAffineMapAttrType (EmitErrorFn emitError, Attribute in) |
LogicalResult | verifyStructTypeParams (EmitErrorFn emitError, ArrayAttr params) |
LogicalResult | verifyArrayDimSizes (EmitErrorFn emitError, ArrayRef< Attribute > dimensionSizes) |
LogicalResult | verifyArrayType (EmitErrorFn emitError, Type elementType, ArrayRef< Attribute > dimensionSizes) |
void | assertValidAttrForParamOfType (Attribute attr) |
void | registerCallGraphPrinterPass () |
void | registerCallGraphPrinterPassPass () |
void | registerCallGraphSCCsPrinterPass () |
void | registerCallGraphSCCsPrinterPassPass () |
void | registerConstraintDependencyGraphPrinterPass () |
void | registerConstraintDependencyGraphPrinterPassPass () |
void | registerIntervalAnalysisPrinterPass () |
void | registerIntervalAnalysisPrinterPassPass () |
void | registerAnalysisPasses () |
llvm::APInt | toAPInt (int64_t i) |
int64_t | fromAPInt (llvm::APInt i) |
bool | isNullOrEmpty (mlir::ArrayAttr a) |
bool | isNullOrEmpty (mlir::DenseArrayAttr a) |
bool | isNullOrEmpty (mlir::DictionaryAttr a) |
void | appendWithoutType (mlir::raw_ostream &os, mlir::Attribute a) |
std::string | stringWithoutType (mlir::Attribute a) |
void | printAttrs (mlir::AsmPrinter &printer, mlir::ArrayRef< mlir::Attribute > attrs, const mlir::StringRef &separator) |
mlir::Location | getUnknownLoc (mlir::MLIRContext *context) |
mlir::OwningOpRef< mlir::ModuleOp > | createLLZKModule (mlir::MLIRContext *context, mlir::Location loc) |
mlir::OwningOpRef< mlir::ModuleOp > | createLLZKModule (mlir::MLIRContext *context) |
template<typename OpClass> | |
llvm::StringLiteral | getOperationName () |
Get the operation name, like "constrain.eq" for the given OpClass. | |
template<typename OpClass> | |
mlir::FailureOr< OpClass > | getParentOfType (mlir::Operation *op) |
Return the closest surrounding parent operation that is of type 'OpClass'. | |
template<unsigned N> | |
mlir::ParseResult | parseDimAndSymbolList (mlir::OpAsmParser &parser, mlir::SmallVector< mlir::OpAsmParser::UnresolvedOperand, N > &mapOperands, mlir::IntegerAttr &numDims) |
void | printDimAndSymbolList (mlir::OpAsmPrinter &printer, mlir::Operation *op, mlir::OperandRange mapOperands, mlir::IntegerAttr numDims) |
mlir::ParseResult | parseMultiDimAndSymbolList (mlir::OpAsmParser &parser, mlir::SmallVector< mlir::SmallVector< mlir::OpAsmParser::UnresolvedOperand > > &multiMapOperands, mlir::DenseI32ArrayAttr &numDimsPerMap) |
void | printMultiDimAndSymbolList (mlir::OpAsmPrinter &printer, mlir::Operation *op, mlir::OperandRangeRange multiMapOperands, mlir::DenseI32ArrayAttr numDimsPerMap) |
mlir::ParseResult | parseAttrDictWithWarnings (mlir::OpAsmParser &parser, mlir::NamedAttrList &extraAttrs, mlir::OperationState &state) |
template<typename ConcreteOp> | |
void | printAttrDictWithWarnings (mlir::OpAsmPrinter &printer, ConcreteOp op, mlir::DictionaryAttr extraAttrs, typename mlir::PropertiesSelector< ConcreteOp >::type state) |
std::unique_ptr< mlir::Pass > | createFlatteningPass () |
std::unique_ptr< mlir::Pass > | createRedundantReadAndWriteEliminationPass () |
std::unique_ptr< mlir::Pass > | createRedundantOperationEliminationPass () |
std::unique_ptr< mlir::Pass > | createUnusedDeclarationEliminationPass () |
std::unique_ptr< mlir::Pass > | createArrayToScalarPass () |
std::unique_ptr< mlir::Pass > | createPolyLoweringPass () |
std::unique_ptr< mlir::Pass > | createPolyLoweringPass (unsigned maxDegree) |
void | registerPolyLoweringPass () |
void | registerPolyLoweringPassPass () |
void | registerRedundantOperationEliminationPass () |
void | registerRedundantOperationEliminationPassPass () |
void | registerRedundantReadAndWriteEliminationPass () |
void | registerRedundantReadAndWriteEliminationPassPass () |
void | registerUnusedDeclarationEliminationPass () |
void | registerUnusedDeclarationEliminationPassPass () |
void | registerTransformationPasses () |
bool | safeLt (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
bool | safeLe (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
bool | safeEq (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
bool | safeNe (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
bool | safeGt (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
bool | safeGe (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
llvm::APSInt | safeMin (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
llvm::APSInt | safeMin (std::initializer_list< llvm::APSInt > ilist) |
llvm::APSInt | safeMax (const llvm::APSInt &lhs, const llvm::APSInt &rhs) |
llvm::APSInt | safeMax (std::initializer_list< llvm::APSInt > ilist) |
template<typename OpClass, typename... Args> | |
OpClass | delegate_to_build (mlir::Location location, Args &&...args) |
template<OpComparable Op> | |
mlir::FailureOr< bool > | isLocationLess (const Op &l, const Op &r) |
OwningEmitErrorFn | getEmitOpErrFn (mlir::Operation *op) |
template<typename TypeClass> | |
OwningEmitErrorFn | getEmitOpErrFn (TypeClass *opImpl) |
void | ensure (bool condition, llvm::Twine errMsg) |
template<typename Func, typename... Args> | |
std::string | buildStringViaCallback (Func &&appendFn, Args &&...args) |
Generate a string by calling the given appendFn with an llvm::raw_ostream & as the first argument followed by the additional Args provided (if any). | |
template<typename T> | |
std::string | buildStringViaPrint (const T &base) |
Generate a string by calling base.print(llvm::raw_ostream &) on a stream backed by the returned string. | |
template<typename... Args> | |
std::string | buildStringViaInsertionOp (Args &&...args) |
Generate a string by using the insertion operator (<<) to append all args to a stream backed by the returned string. | |
llvm::SmallVector< mlir::StringRef > | getNames (mlir::SymbolRefAttr ref) |
llvm::SmallVector< mlir::FlatSymbolRefAttr > | getPieces (mlir::SymbolRefAttr ref) |
mlir::FlatSymbolRefAttr | getFlatSymbolRefAttr (mlir::MLIRContext *context, const mlir::Twine &twine) |
Construct a FlatSymbolRefAttr with the given content. | |
mlir::SymbolRefAttr | asSymbolRefAttr (mlir::StringAttr root, mlir::SymbolRefAttr tail) |
Build a SymbolRefAttr that prepends tail with root , i.e. root::tail . | |
mlir::SymbolRefAttr | asSymbolRefAttr (llvm::ArrayRef< mlir::FlatSymbolRefAttr > path) |
Build a SymbolRefAttr from the list of pieces. | |
mlir::SymbolRefAttr | asSymbolRefAttr (std::vector< mlir::FlatSymbolRefAttr > path) |
Build a SymbolRefAttr from the list of pieces. | |
mlir::SymbolRefAttr | getTailAsSymbolRefAttr (mlir::SymbolRefAttr symbol) |
Return SymbolRefAttr like the one given but with the root/head element removed. | |
mlir::SymbolRefAttr | getPrefixAsSymbolRefAttr (mlir::SymbolRefAttr symbol) |
Return SymbolRefAttr like the one given but with the leaf/final element removed. | |
mlir::SymbolRefAttr | replaceLeaf (mlir::SymbolRefAttr orig, mlir::FlatSymbolRefAttr newLeaf) |
Return SymbolRefAttr like the one given but with the leaf (final) element replaced. | |
mlir::SymbolRefAttr | replaceLeaf (mlir::SymbolRefAttr orig, mlir::StringAttr newLeaf) |
mlir::SymbolRefAttr | replaceLeaf (mlir::SymbolRefAttr orig, const mlir::Twine &newLeaf) |
mlir::SymbolRefAttr | appendLeaf (mlir::SymbolRefAttr orig, mlir::FlatSymbolRefAttr newLeaf) |
Return SymbolRefAttr like the one given but with a new leaf (final) element added. | |
mlir::SymbolRefAttr | appendLeaf (mlir::SymbolRefAttr orig, mlir::StringAttr newLeaf) |
mlir::SymbolRefAttr | appendLeaf (mlir::SymbolRefAttr orig, const mlir::Twine &newLeaf) |
mlir::SymbolRefAttr | appendLeafName (mlir::SymbolRefAttr orig, const mlir::Twine &newLeafSuffix) |
Return SymbolRefAttr like the one given but with the leaf (final) element appended with the given suffix. | |
mlir::FailureOr< mlir::ModuleOp > | getRootModule (mlir::Operation *from) |
mlir::FailureOr< mlir::ModuleOp > | getTopRootModule (mlir::Operation *from) |
With include statements, there may be root modules nested within other root modules. | |
template<typename T> | |
mlir::FailureOr< SymbolLookupResult< T > > | resolveCallable (mlir::SymbolTableCollection &symbolTable, mlir::CallOpInterface call) |
Based on mlir::CallOpInterface::resolveCallable, but using LLZK lookup helpers. | |
template<typename T> | |
mlir::FailureOr< SymbolLookupResult< T > > | resolveCallable (mlir::CallOpInterface call) |
bool | hasUsesWithin (mlir::Operation *symbol, mlir::Operation *from) |
Equivalent to SymbolTable::getSymbolUses(...).has_value() but without fully computing uses. | |
mlir::LogicalResult | verifyParamOfType (mlir::SymbolTableCollection &tables, mlir::SymbolRefAttr param, mlir::Type structOrArrayType, mlir::Operation *origin) |
Ensure that the given symbol (that is used as a parameter of the given type) can be resolved. | |
mlir::LogicalResult | verifyParamsOfType (mlir::SymbolTableCollection &tables, mlir::ArrayRef< mlir::Attribute > tyParams, mlir::Type structOrArrayType, mlir::Operation *origin) |
Ensure that any symbols that appear within the given attributes (that are parameters of the given type) can be resolved. | |
mlir::FailureOr< component::StructDefOp > | verifyStructTypeResolution (mlir::SymbolTableCollection &tables, component::StructType ty, mlir::Operation *origin) |
Ensure that all symbols used within the type can be resolved. | |
mlir::LogicalResult | verifyTypeResolution (mlir::SymbolTableCollection &tables, mlir::Operation *origin, mlir::Type type) |
Ensure that all symbols used within the given Type instance can be resolved. | |
template<std::ranges::input_range Range> | |
mlir::LogicalResult | verifyTypeResolution (mlir::SymbolTableCollection &tables, mlir::Operation *origin, const Range &types) |
Ensure that all symbols used within all Type instances can be resolved. | |
mlir::FailureOr< SymbolLookupResultUntyped > | lookupSymbolIn (mlir::SymbolTableCollection &tables, mlir::SymbolRefAttr symbol, Within &&lookupWithin, mlir::Operation *origin, bool reportMissing=true) |
mlir::FailureOr< SymbolLookupResultUntyped > | lookupTopLevelSymbol (mlir::SymbolTableCollection &tables, mlir::SymbolRefAttr symbol, mlir::Operation *origin, bool reportMissing=true) |
template<typename T> | |
mlir::FailureOr< SymbolLookupResult< T > > | lookupSymbolIn (mlir::SymbolTableCollection &tables, mlir::SymbolRefAttr symbol, Within &&lookupWithin, mlir::Operation *origin) |
template<typename T> | |
mlir::FailureOr< SymbolLookupResult< T > > | lookupTopLevelSymbol (mlir::SymbolTableCollection &tables, mlir::SymbolRefAttr symbol, mlir::Operation *origin) |
void | assertValidAttrForParamOfType (mlir::Attribute attr) |
bool | isValidType (mlir::Type type) |
valid types: {I1, Index, String, FeltType, StructType, ArrayType, TypeVarType} | |
bool | isValidColumnType (mlir::Type type, mlir::SymbolTableCollection &symbolTable, mlir::Operation *op) |
valid types: {FeltType, StructType (with columns), ArrayType (that contains a valid column type)} | |
bool | isValidGlobalType (mlir::Type type) |
valid types: isValidType() - {TypeVarType} - {types with variable parameters} | |
bool | isValidEmitEqType (mlir::Type type) |
valid types: isValidType() - {String, StructType} (excluded via any type parameter nesting) | |
bool | isValidConstReadType (mlir::Type type) |
valid types: {I1, Index, FeltType, TypeVarType} | |
bool | isValidArrayElemType (mlir::Type type) |
valid types: isValidType() - {ArrayType} | |
bool | isValidArrayType (mlir::Type type) |
Checks if the type is a LLZK Array and it also contains a valid LLZK type. | |
bool | isConcreteType (mlir::Type type, bool allowStructParams=true) |
Return false iff the type contains any TypeVarType | |
mlir::LogicalResult | checkValidType (EmitErrorFn emitError, mlir::Type type) |
bool | isSignalType (mlir::Type type) |
Return true iff the given type is a StructType referencing the COMPONENT_NAME_SIGNAL struct. | |
bool | hasAffineMapAttr (mlir::Type type) |
Return true iff the given type contains an AffineMapAttr. | |
Side | reverse (Side in) |
bool | isDynamic (mlir::IntegerAttr intAttr) |
bool | typeParamsUnify (const mlir::ArrayRef< mlir::Attribute > &lhsParams, const mlir::ArrayRef< mlir::Attribute > &rhsParams, UnificationMap *unifications=nullptr) |
Return true iff the two ArrayRef instances containing StructType or ArrayType parameters are equivalent or could be equivalent after full instantiation of struct parameters. | |
bool | typeParamsUnify (const mlir::ArrayAttr &lhsParams, const mlir::ArrayAttr &rhsParams, UnificationMap *unifications=nullptr) |
Return true iff the two ArrayAttr instances containing StructType or ArrayType parameters are equivalent or could be equivalent after full instantiation of struct parameters. | |
bool | arrayTypesUnify (array::ArrayType lhs, array::ArrayType rhs, mlir::ArrayRef< llvm::StringRef > rhsReversePrefix={}, UnificationMap *unifications=nullptr) |
Return true iff the two ArrayType instances are equivalent or could be equivalent after full instantiation of struct parameters. | |
bool | structTypesUnify (component::StructType lhs, component::StructType rhs, mlir::ArrayRef< llvm::StringRef > rhsReversePrefix={}, UnificationMap *unifications=nullptr) |
Return true iff the two StructType instances are equivalent or could be equivalent after full instantiation of struct parameters. | |
bool | typesUnify (mlir::Type lhs, mlir::Type rhs, mlir::ArrayRef< llvm::StringRef > rhsReversePrefix={}, UnificationMap *unifications=nullptr) |
Return true iff the two Type instances are equivalent or could be equivalent after full instantiation of struct parameters (if applicable within the given types). | |
template<typename Iter1, typename Iter2> | |
bool | typeListsUnify (Iter1 lhs, Iter2 rhs, mlir::ArrayRef< llvm::StringRef > rhsReversePrefix={}, UnificationMap *unifications=nullptr) |
Return true iff the two lists of Type instances are equivalent or could be equivalent after full instantiation of struct parameters (if applicable within the given types). | |
template<typename Iter1, typename Iter2> | |
bool | singletonTypeListsUnify (Iter1 lhs, Iter2 rhs, mlir::ArrayRef< llvm::StringRef > rhsReversePrefix={}, UnificationMap *unifications=nullptr) |
bool | isMoreConcreteUnification (mlir::Type oldTy, mlir::Type newTy, llvm::function_ref< bool(mlir::Type oldTy, mlir::Type newTy)> knownOldToNew=nullptr) |
Return true iff the types unify and newTy is "more concrete" than oldTy . | |
template<typename TypeClass> | |
TypeClass | getIfSingleton (mlir::TypeRange types) |
template<typename TypeClass> | |
TypeClass | getAtIndex (mlir::TypeRange types, size_t index) |
mlir::IntegerAttr | forceIntType (mlir::IntegerAttr attr) |
Convert an IntegerAttr with a type other than IndexType to use IndexType. | |
mlir::Attribute | forceIntAttrType (mlir::Attribute attr) |
Convert any IntegerAttr with a type other than IndexType to use IndexType. | |
llvm::SmallVector< mlir::Attribute > | forceIntAttrTypes (llvm::ArrayRef< mlir::Attribute > attrList) |
Convert any IntegerAttr with a type other than IndexType to use IndexType. | |
mlir::LogicalResult | verifyIntAttrType (EmitErrorFn emitError, mlir::Attribute in) |
Verify that all IntegerAttr have type IndexType. | |
mlir::LogicalResult | verifyAffineMapAttrType (EmitErrorFn emitError, mlir::Attribute in) |
Verify that all AffineMapAttr only have a single result. | |
mlir::LogicalResult | verifyStructTypeParams (EmitErrorFn emitError, mlir::ArrayAttr params) |
Verify that the StructType parameters are valid. | |
mlir::LogicalResult | verifyArrayDimSizes (EmitErrorFn emitError, mlir::ArrayRef< mlir::Attribute > dimensionSizes) |
Verify that the array dimensions are valid. | |
mlir::LogicalResult | verifyArrayType (EmitErrorFn emitError, mlir::Type elementType, mlir::ArrayRef< mlir::Attribute > dimensionSizes) |
Verify that the ArrayType is valid. | |
std::unique_ptr< mlir::Pass > | createFieldWriteValidatorPass () |
void | registerFieldWriteValidatorPass () |
void | registerFieldWriteValidatorPassPass () |
void | registerValidationPasses () |
Variables | |
constexpr char | COMPONENT_NAME_SIGNAL [] = "Signal" |
Symbol name for the struct/component representing a signal. | |
constexpr char | COMPONENT_NAME_MAIN [] = "Main" |
Symbol name for the main entry point struct/component (if any). | |
constexpr char | FUNC_NAME_COMPUTE [] = "compute" |
Symbol name for the witness generation (and resp. | |
constexpr char | FUNC_NAME_CONSTRAIN [] = "constrain" |
constexpr char | LANG_ATTR_NAME [] = "veridise.lang" |
Name of the attribute on the top-level ModuleOp that specifies the IR language name. | |
using llzk::ConstrainRefRemappings = std::vector<std::pair<ConstrainRef, ConstrainRefLatticeValue>> |
Definition at line 28 of file ConstraintDependencyGraph.h.
using llzk::EmitErrorFn = llvm::function_ref<mlir::InFlightDiagnostic()> |
Definition at line 18 of file ErrorHelper.h.
using llzk::ManagedResources |
Definition at line 29 of file SymbolLookup.h.
using llzk::OwningEmitErrorFn = std::function<mlir::InFlightDiagnostic()> |
Definition at line 22 of file ErrorHelper.h.
using llzk::TranslationMap |
Definition at line 20 of file ConstrainRefLattice.h.
using llzk::UnificationMap = mlir::DenseMap<std::pair<mlir::SymbolRefAttr, Side>, mlir::Attribute> |
Optional result from type unifications.
Maps SymbolRefAttr
appearing in one type to the associated Attribute
from the other type at the same nested position. The Side
enum in the key indicates which input expression the SymbolRefAttr
is from. Additionally, if a conflict is found (i.e. multiple Occurrences of a specific SymbolRefAttr
on the same side map to different Attributes from the other side). The mapped value will be nullptr
.
This map is used by the llzk-flatten
pass to replace struct parameter SymbolRefAttr
with static concrete values to produce the flattened versions of structs.
Definition at line 181 of file TypeHelper.h.
|
strong |
Enumerator | |
---|---|
EMPTY | |
LHS | |
RHS | |
TOMB |
Definition at line 124 of file TypeHelper.h.
ExpressionValue llzk::add | ( | llvm::SMTSolverRef | solver, |
const ExpressionValue & | lhs, | ||
const ExpressionValue & | rhs ) |
Definition at line 486 of file IntervalAnalysis.cpp.
void llzk::addLangAttrForLLZKDialect | ( | mlir::ModuleOp | mod | ) |
Definition at line 28 of file Builders.cpp.
void llzk::addRemoveUnnecessaryOpsAndDefsPipeline | ( | OpPassManager & | pm | ) |
Definition at line 32 of file TransformationPassPipelines.cpp.
|
inline |
Definition at line 79 of file SymbolHelper.h.
mlir::SymbolRefAttr llzk::appendLeaf | ( | mlir::SymbolRefAttr | orig, |
mlir::FlatSymbolRefAttr | newLeaf ) |
Return SymbolRefAttr like the one given but with a new leaf (final) element added.
|
inline |
Definition at line 76 of file SymbolHelper.h.
SymbolRefAttr llzk::appendLeaf | ( | SymbolRefAttr | orig, |
FlatSymbolRefAttr | newLeaf ) |
Definition at line 180 of file SymbolHelper.cpp.
mlir::SymbolRefAttr llzk::appendLeafName | ( | mlir::SymbolRefAttr | orig, |
const mlir::Twine & | newLeafSuffix ) |
Return SymbolRefAttr like the one given but with the leaf (final) element appended with the given suffix.
SymbolRefAttr llzk::appendLeafName | ( | SymbolRefAttr | orig, |
const Twine & | newLeafSuffix ) |
Definition at line 184 of file SymbolHelper.cpp.
|
inline |
Definition at line 40 of file AttributeHelper.h.
bool llzk::arrayTypesUnify | ( | array::ArrayType | lhs, |
array::ArrayType | rhs, | ||
mlir::ArrayRef< llvm::StringRef > | rhsReversePrefix = {}, | ||
UnificationMap * | unifications = nullptr ) |
Return true
iff the two ArrayType instances are equivalent or could be equivalent after full instantiation of struct parameters.
bool llzk::arrayTypesUnify | ( | ArrayType | lhs, |
ArrayType | rhs, | ||
ArrayRef< StringRef > | rhsReversePrefix, | ||
UnificationMap * | unifications ) |
Definition at line 752 of file TypeHelper.cpp.
void llzk::assertValidAttrForParamOfType | ( | Attribute | attr | ) |
Definition at line 857 of file TypeHelper.cpp.
void llzk::assertValidAttrForParamOfType | ( | mlir::Attribute | attr | ) |
|
inline |
Build a SymbolRefAttr from the list of pieces.
Definition at line 44 of file SymbolHelper.h.
|
inline |
Build a SymbolRefAttr that prepends tail
with root
, i.e. root::tail
.
Definition at line 39 of file SymbolHelper.h.
|
inline |
Build a SymbolRefAttr from the list of pieces.
Definition at line 49 of file SymbolHelper.h.
|
inline |
Generate a string by calling the given appendFn
with an llvm::raw_ostream &
as the first argument followed by the additional Args
provided (if any).
Definition at line 41 of file StreamHelper.h.
|
inline |
Generate a string by using the insertion operator (<<) to append all args to a stream backed by the returned string.
Definition at line 56 of file StreamHelper.h.
|
inline |
Generate a string by calling base.print(llvm::raw_ostream &)
on a stream backed by the returned string.
Definition at line 50 of file StreamHelper.h.
|
inline |
Definition at line 107 of file TypeHelper.h.
ExpressionValue llzk::cmp | ( | llvm::SMTSolverRef | solver, |
boolean::CmpOp | op, | ||
const ExpressionValue & | lhs, | ||
const ExpressionValue & | rhs ) |
Definition at line 536 of file IntervalAnalysis.cpp.
std::unique_ptr< mlir::Pass > llzk::createArrayToScalarPass | ( | ) |
std::unique_ptr< mlir::Pass > llzk::createCallGraphPrinterPass | ( | llvm::raw_ostream & | os = llvm::errs() | ) |
Definition at line 50 of file CallGraphPasses.cpp.
std::unique_ptr< mlir::Pass > llzk::createCallGraphSCCsPrinterPass | ( | llvm::raw_ostream & | os = llvm::errs() | ) |
Definition at line 95 of file CallGraphPasses.cpp.
std::unique_ptr< mlir::Pass > llzk::createConstraintDependencyGraphPrinterPass | ( | llvm::raw_ostream & | os = llvm::errs() | ) |
Definition at line 65 of file ConstraintDependencyGraphPass.cpp.
std::unique_ptr< mlir::Pass > llzk::createFieldWriteValidatorPass | ( | ) |
Definition at line 82 of file LLZKValidationPasses.cpp.
std::unique_ptr< mlir::Pass > llzk::createFlatteningPass | ( | ) |
std::unique_ptr< mlir::Pass > llzk::createIntervalAnalysisPrinterPass | ( | llvm::raw_ostream & | os = llvm::errs() | ) |
Definition at line 73 of file IntervalAnalysisPass.cpp.
|
inline |
Definition at line 31 of file Builders.h.
mlir::OwningOpRef< mlir::ModuleOp > llzk::createLLZKModule | ( | mlir::MLIRContext * | context, |
mlir::Location | loc ) |
OwningOpRef< ModuleOp > llzk::createLLZKModule | ( | MLIRContext * | context, |
Location | loc ) |
Definition at line 22 of file Builders.cpp.
std::unique_ptr< mlir::Pass > llzk::createPolyLoweringPass | ( | ) |
Definition at line 488 of file LLZKPolyLoweringPass.cpp.
std::unique_ptr< mlir::Pass > llzk::createPolyLoweringPass | ( | unsigned | maxDegree | ) |
Definition at line 492 of file LLZKPolyLoweringPass.cpp.
std::unique_ptr< mlir::Pass > llzk::createRedundantOperationEliminationPass | ( | ) |
Definition at line 285 of file LLZKRedundantOperationEliminationPass.cpp.
std::unique_ptr< mlir::Pass > llzk::createRedundantReadAndWriteEliminationPass | ( | ) |
Definition at line 679 of file LLZKRedundantReadAndWriteEliminationPass.cpp.
std::unique_ptr< mlir::Pass > llzk::createUnusedDeclarationEliminationPass | ( | ) |
Definition at line 233 of file LLZKUnusedDeclarationEliminationPass.cpp.
|
inline |
Definition at line 18 of file BuilderHelper.h.
ExpressionValue llzk::div | ( | llvm::SMTSolverRef | solver, |
felt::DivFeltOp | op, | ||
const ExpressionValue & | lhs, | ||
const ExpressionValue & | rhs ) |
Definition at line 510 of file IntervalAnalysis.cpp.
|
inline |
Definition at line 32 of file ErrorHelper.h.
llvm::APSInt llzk::expandingAdd | ( | const llvm::APSInt & | lhs, |
const llvm::APSInt & | rhs ) |
Safely add lhs and rhs, expanding the width of the result as necessary.
Numbers are never truncated here, as this assumes that truncation will occur with the reduction to the prime field.
lhs | an N bit number with an allocated width of X |
rhs | an M bit number with an allocated width of Y |
Definition at line 14 of file APIntHelper.cpp.
llvm::APSInt llzk::expandingMul | ( | const llvm::APSInt & | lhs, |
const llvm::APSInt & | rhs ) |
Safely multiple lhs and rhs, expanding the width of the result as necessary.
Numbers are never truncated here, as this assumes that truncation will occur with the reduction to the prime field.
lhs | an N bit number with an allocated width of X |
rhs | an M bit number with an allocated width of Y |
Definition at line 26 of file APIntHelper.cpp.
llvm::APSInt llzk::expandingSub | ( | const llvm::APSInt & | lhs, |
const llvm::APSInt & | rhs ) |
Safely subtract lhs and rhs, expanding the width of the result as necessary.
Numbers are never truncated here, as this assumes that truncation will occur with the reduction to the prime field.
lhs | an N bit number with an allocated width of X |
rhs | an M bit number with an allocated width of Y |
Definition at line 20 of file APIntHelper.cpp.
ExpressionValue llzk::fallbackBinaryOp | ( | llvm::SMTSolverRef | solver, |
Operation * | op, | ||
const ExpressionValue & | lhs, | ||
const ExpressionValue & | rhs ) |
Definition at line 563 of file IntervalAnalysis.cpp.
ExpressionValue llzk::fallbackUnaryOp | ( | llvm::SMTSolverRef | solver, |
Operation * | op, | ||
const ExpressionValue & | val ) |
Definition at line 608 of file IntervalAnalysis.cpp.
Attribute llzk::forceIntAttrType | ( | Attribute | attr | ) |
Definition at line 800 of file TypeHelper.cpp.
mlir::Attribute llzk::forceIntAttrType | ( | mlir::Attribute | attr | ) |
Convert any IntegerAttr with a type other than IndexType to use IndexType.
SmallVector< Attribute > llzk::forceIntAttrTypes | ( | ArrayRef< Attribute > | attrList | ) |
Definition at line 807 of file TypeHelper.cpp.
llvm::SmallVector< mlir::Attribute > llzk::forceIntAttrTypes | ( | llvm::ArrayRef< mlir::Attribute > | attrList | ) |
Convert any IntegerAttr with a type other than IndexType to use IndexType.
IntegerAttr llzk::forceIntType | ( | IntegerAttr | attr | ) |
Definition at line 793 of file TypeHelper.cpp.
mlir::IntegerAttr llzk::forceIntType | ( | mlir::IntegerAttr | attr | ) |
Convert an IntegerAttr with a type other than IndexType to use IndexType.
|
inline |
Definition at line 34 of file AttributeHelper.h.
|
inline |
Definition at line 255 of file TypeHelper.h.
|
inline |
Definition at line 24 of file ErrorHelper.h.
|
inline |
Definition at line 28 of file ErrorHelper.h.
|
inline |
Construct a FlatSymbolRefAttr with the given content.
Definition at line 34 of file SymbolHelper.h.
|
inline |
Definition at line 251 of file TypeHelper.h.
llvm::SmallVector< mlir::StringRef > llzk::getNames | ( | mlir::SymbolRefAttr | ref | ) |
llvm::SmallVector< StringRef > llzk::getNames | ( | SymbolRefAttr | ref | ) |
Definition at line 138 of file SymbolHelper.cpp.
|
inline |
Get the operation name, like "constrain.eq" for the given OpClass.
This function can be used when the compiler would complain about incomplete types if OpClass::getOperationName()
were called directly.
Definition at line 27 of file OpHelpers.h.
|
inline |
Return the closest surrounding parent operation that is of type 'OpClass'.
Definition at line 32 of file OpHelpers.h.
mlir::FailureOr< mlir::SymbolRefAttr > llzk::getPathFromRoot | ( | FuncDefOp & | to | ) |
Definition at line 208 of file SymbolHelper.cpp.
mlir::FailureOr< mlir::SymbolRefAttr > llzk::getPathFromRoot | ( | StructDefOp & | to | ) |
Definition at line 204 of file SymbolHelper.cpp.
mlir::FailureOr< mlir::SymbolRefAttr > llzk::getPathFromTopRoot | ( | FuncDefOp & | to | ) |
Definition at line 221 of file SymbolHelper.cpp.
mlir::FailureOr< mlir::SymbolRefAttr > llzk::getPathFromTopRoot | ( | StructDefOp & | to | ) |
Definition at line 217 of file SymbolHelper.cpp.
llvm::SmallVector< mlir::FlatSymbolRefAttr > llzk::getPieces | ( | mlir::SymbolRefAttr | ref | ) |
llvm::SmallVector< FlatSymbolRefAttr > llzk::getPieces | ( | SymbolRefAttr | ref | ) |
Definition at line 147 of file SymbolHelper.cpp.
|
inline |
Return SymbolRefAttr like the one given but with the leaf/final element removed.
Definition at line 59 of file SymbolHelper.h.
mlir::FailureOr< mlir::ModuleOp > llzk::getRootModule | ( | mlir::Operation * | from | ) |
FailureOr< ModuleOp > llzk::getRootModule | ( | Operation * | from | ) |
Definition at line 199 of file SymbolHelper.cpp.
SymbolLookupResult< StructDefOp > llzk::getStructDef | ( | mlir::SymbolTableCollection & | tables, |
mlir::ModuleOp | mod, | ||
StructType | ty ) |
Lookup a StructDefOp
from a given StructType
.
tables | |
mod | |
ty |
SymbolLookupResult
for the StructDefOp
found. Note that returning the lookup result is important, as it may manage a ModuleOp if the struct is found via an include. Definition at line 76 of file ConstrainRef.cpp.
|
inline |
Return SymbolRefAttr like the one given but with the root/head element removed.
Definition at line 54 of file SymbolHelper.h.
mlir::FailureOr< mlir::ModuleOp > llzk::getTopRootModule | ( | mlir::Operation * | from | ) |
With include statements, there may be root modules nested within other root modules.
This function resolves the topmost root module.
FailureOr< ModuleOp > llzk::getTopRootModule | ( | Operation * | from | ) |
Definition at line 212 of file SymbolHelper.cpp.
|
inline |
Definition at line 25 of file Builders.h.
bool llzk::hasAffineMapAttr | ( | mlir::Type | type | ) |
Return true
iff the given type contains an AffineMapAttr.
bool llzk::hasAffineMapAttr | ( | Type | type | ) |
Definition at line 494 of file TypeHelper.cpp.
bool llzk::hasUsesWithin | ( | mlir::Operation * | symbol, |
mlir::Operation * | from ) |
Equivalent to SymbolTable::getSymbolUses(...).has_value()
but without fully computing uses.
bool llzk::hasUsesWithin | ( | Operation * | symbol, |
Operation * | from ) |
Definition at line 225 of file SymbolHelper.cpp.
ExpressionValue llzk::intersection | ( | llvm::SMTSolverRef | solver, |
const ExpressionValue & | lhs, | ||
const ExpressionValue & | rhs ) |
bool llzk::isConcreteType | ( | mlir::Type | type, |
bool | allowStructParams = true ) |
Return false
iff the type contains any TypeVarType
bool llzk::isConcreteType | ( | Type | type, |
bool | allowStructParams ) |
Definition at line 476 of file TypeHelper.cpp.
bool llzk::isDynamic | ( | IntegerAttr | intAttr | ) |
Definition at line 503 of file TypeHelper.cpp.
bool llzk::isDynamic | ( | mlir::IntegerAttr | intAttr | ) |
mlir::FailureOr< bool > llzk::isLocationLess | ( | const Op & | l, |
const Op & | r ) |
bool llzk::isMoreConcreteUnification | ( | mlir::Type | oldTy, |
mlir::Type | newTy, | ||
llvm::function_ref< bool(mlir::Type oldTy, mlir::Type newTy)> | knownOldToNew = nullptr ) |
Return true
iff the types unify and newTy
is "more concrete" than oldTy
.
The types i1
, index
, felt.type
, and string.type
are concrete whereas poly.tvar
is not (because it may be substituted with any type during struct instantiation). When considering the attributes with array.type
and struct.type
types, we define IntegerAttr and TypeAttr as concrete, AffineMapAttr as less concrete than those, and SymbolRefAttr as least concrete.
bool llzk::isMoreConcreteUnification | ( | Type | oldTy, |
Type | newTy, | ||
llvm::function_ref< bool(Type oldTy, Type newTy)> | knownOldToNew ) |
Definition at line 771 of file TypeHelper.cpp.
|
inline |
Definition at line 36 of file AttributeHelper.h.
|
inline |
Definition at line 37 of file AttributeHelper.h.
|
inline |
Definition at line 38 of file AttributeHelper.h.
bool llzk::isSignalType | ( | StructType | sType | ) |
Return true
iff the given StructType is referencing the COMPONENT_NAME_SIGNAL
struct.
Definition at line 487 of file TypeHelper.cpp.
bool llzk::isSignalType | ( | mlir::Type | type | ) |
Return true
iff the given type is a StructType referencing the COMPONENT_NAME_SIGNAL
struct.
bool llzk::isSignalType | ( | Type | type | ) |
Definition at line 480 of file TypeHelper.cpp.
bool llzk::isValidArrayElemType | ( | mlir::Type | type | ) |
valid types: isValidType() - {ArrayType}
bool llzk::isValidArrayElemType | ( | Type | type | ) |
Definition at line 472 of file TypeHelper.cpp.
bool llzk::isValidArrayType | ( | mlir::Type | type | ) |
Checks if the type is a LLZK Array and it also contains a valid LLZK type.
bool llzk::isValidArrayType | ( | Type | type | ) |
Definition at line 474 of file TypeHelper.cpp.
bool llzk::isValidColumnType | ( | mlir::Type | type, |
mlir::SymbolTableCollection & | symbolTable, | ||
mlir::Operation * | op ) |
valid types: {FeltType, StructType (with columns), ArrayType (that contains a valid column type)}
bool llzk::isValidColumnType | ( | Type | type, |
SymbolTableCollection & | symbolTable, | ||
Operation * | op ) |
Definition at line 457 of file TypeHelper.cpp.
bool llzk::isValidConstReadType | ( | mlir::Type | type | ) |
valid types: {I1, Index, FeltType, TypeVarType}
bool llzk::isValidConstReadType | ( | Type | type | ) |
Definition at line 468 of file TypeHelper.cpp.
bool llzk::isValidEmitEqType | ( | mlir::Type | type | ) |
valid types: isValidType() - {String, StructType} (excluded via any type parameter nesting)
bool llzk::isValidEmitEqType | ( | Type | type | ) |
Definition at line 463 of file TypeHelper.cpp.
bool llzk::isValidGlobalType | ( | mlir::Type | type | ) |
valid types: isValidType() - {TypeVarType} - {types with variable parameters}
bool llzk::isValidGlobalType | ( | Type | type | ) |
Definition at line 461 of file TypeHelper.cpp.
bool llzk::isValidType | ( | mlir::Type | type | ) |
valid types: {I1, Index, String, FeltType, StructType, ArrayType, TypeVarType}
bool llzk::isValidType | ( | Type | type | ) |
Definition at line 455 of file TypeHelper.cpp.
|
inline |
Definition at line 142 of file SymbolLookup.h.
|
inline |
Definition at line 127 of file SymbolLookup.h.
|
inline |
Definition at line 162 of file SymbolLookup.h.
|
inline |
Definition at line 134 of file SymbolLookup.h.
ExpressionValue llzk::mod | ( | llvm::SMTSolverRef | solver, |
const ExpressionValue & | lhs, | ||
const ExpressionValue & | rhs ) |
Definition at line 528 of file IntervalAnalysis.cpp.
ExpressionValue llzk::mul | ( | llvm::SMTSolverRef | solver, |
const ExpressionValue & | lhs, | ||
const ExpressionValue & | rhs ) |
Definition at line 502 of file IntervalAnalysis.cpp.
ExpressionValue llzk::neg | ( | llvm::SMTSolverRef | solver, |
const ExpressionValue & | val ) |
Definition at line 585 of file IntervalAnalysis.cpp.
ExpressionValue llzk::notOp | ( | llvm::SMTSolverRef | solver, |
const ExpressionValue & | val ) |
Definition at line 592 of file IntervalAnalysis.cpp.
Definition at line 449 of file IntervalAnalysis.cpp.
Definition at line 417 of file IntervalAnalysis.cpp.
UnreducedInterval llzk::operator* | ( | const UnreducedInterval & | lhs, |
const UnreducedInterval & | rhs ) |
Definition at line 160 of file IntervalAnalysis.cpp.
Definition at line 410 of file IntervalAnalysis.cpp.
UnreducedInterval llzk::operator+ | ( | const UnreducedInterval & | lhs, |
const UnreducedInterval & | rhs ) |
Definition at line 151 of file IntervalAnalysis.cpp.
Definition at line 415 of file IntervalAnalysis.cpp.
UnreducedInterval llzk::operator- | ( | const UnreducedInterval & | lhs, |
const UnreducedInterval & | rhs ) |
Definition at line 156 of file IntervalAnalysis.cpp.
Definition at line 437 of file IntervalAnalysis.cpp.
llvm::raw_ostream & llzk::operator<< | ( | llvm::raw_ostream & | os, |
const ConstrainRefLattice & | lattice ) |
Definition at line 236 of file ConstrainRefLattice.cpp.
mlir::raw_ostream & llzk::operator<< | ( | mlir::raw_ostream & | os, |
const ConstrainRef & | rhs ) |
Definition at line 371 of file ConstrainRef.cpp.
mlir::raw_ostream & llzk::operator<< | ( | mlir::raw_ostream & | os, |
const ConstrainRefLatticeValue & | v ) |
Definition at line 167 of file ConstrainRefLattice.cpp.
mlir::raw_ostream & llzk::operator<< | ( | mlir::raw_ostream & | os, |
const ConstrainRefSet & | rhs ) |
Definition at line 383 of file ConstrainRef.cpp.
std::strong_ordering llzk::operator<=> | ( | const UnreducedInterval & | lhs, |
const UnreducedInterval & | rhs ) |
Definition at line 176 of file IntervalAnalysis.cpp.
|
inline |
Definition at line 109 of file OpHelpers.h.
|
inline |
Definition at line 79 of file OpHelpers.h.
|
inline |
Definition at line 94 of file OpHelpers.h.
|
inline |
Definition at line 116 of file OpHelpers.h.
void llzk::printAttrs | ( | AsmPrinter & | printer, |
ArrayRef< Attribute > | attrs, | ||
const StringRef & | separator ) |
Definition at line 18 of file AttributeHelper.cpp.
void llzk::printAttrs | ( | mlir::AsmPrinter & | printer, |
mlir::ArrayRef< mlir::Attribute > | attrs, | ||
const mlir::StringRef & | separator ) |
|
inline |
Definition at line 87 of file OpHelpers.h.
|
inline |
Definition at line 102 of file OpHelpers.h.
void llzk::registerAllDialects | ( | mlir::DialectRegistry & | registry | ) |
Definition at line 30 of file InitDialects.cpp.
|
inline |
Definition at line 380 of file AnalysisPasses.h.
|
inline |
Definition at line 312 of file AnalysisPasses.h.
|
inline |
Definition at line 319 of file AnalysisPasses.h.
|
inline |
Definition at line 329 of file AnalysisPasses.h.
|
inline |
Definition at line 336 of file AnalysisPasses.h.
|
inline |
Definition at line 346 of file AnalysisPasses.h.
|
inline |
Definition at line 353 of file AnalysisPasses.h.
|
inline |
Definition at line 86 of file LLZKValidationPasses.h.
|
inline |
Definition at line 93 of file LLZKValidationPasses.h.
|
inline |
Definition at line 363 of file AnalysisPasses.h.
|
inline |
Definition at line 370 of file AnalysisPasses.h.
|
inline |
Definition at line 316 of file LLZKTransformationPasses.h.
|
inline |
Definition at line 323 of file LLZKTransformationPasses.h.
|
inline |
Definition at line 333 of file LLZKTransformationPasses.h.
|
inline |
Definition at line 340 of file LLZKTransformationPasses.h.
|
inline |
Definition at line 350 of file LLZKTransformationPasses.h.
|
inline |
Definition at line 357 of file LLZKTransformationPasses.h.
|
inline |
Definition at line 384 of file LLZKTransformationPasses.h.
void llzk::registerTransformationPassPipelines | ( | ) |
Definition at line 38 of file TransformationPassPipelines.cpp.
|
inline |
Definition at line 367 of file LLZKTransformationPasses.h.
|
inline |
Definition at line 374 of file LLZKTransformationPasses.h.
|
inline |
Definition at line 103 of file LLZKValidationPasses.h.
|
inline |
Definition at line 70 of file SymbolHelper.h.
mlir::SymbolRefAttr llzk::replaceLeaf | ( | mlir::SymbolRefAttr | orig, |
mlir::FlatSymbolRefAttr | newLeaf ) |
Return SymbolRefAttr like the one given but with the leaf (final) element replaced.
|
inline |
Definition at line 67 of file SymbolHelper.h.
SymbolRefAttr llzk::replaceLeaf | ( | SymbolRefAttr | orig, |
FlatSymbolRefAttr | newLeaf ) |
Definition at line 170 of file SymbolHelper.cpp.
|
inline |
Definition at line 125 of file SymbolHelper.h.
|
inline |
Based on mlir::CallOpInterface::resolveCallable, but using LLZK lookup helpers.
T | the type of symbol being resolved (e.g., function::FuncDefOp) |
symbolTable | |
call |
Definition at line 104 of file SymbolHelper.h.
Definition at line 143 of file TypeHelper.h.
std::strong_ordering llzk::safeCmp | ( | const llvm::APSInt & | lhs, |
const llvm::APSInt & | rhs ) |
Compares lhs and rhs, regardless of the bitwidth of lhs and rhs.
Definition at line 32 of file APIntHelper.cpp.
|
inline |
Definition at line 66 of file APIntHelper.h.
|
inline |
Definition at line 78 of file APIntHelper.h.
|
inline |
Definition at line 74 of file APIntHelper.h.
|
inline |
Definition at line 62 of file APIntHelper.h.
|
inline |
Definition at line 58 of file APIntHelper.h.
|
inline |
Definition at line 90 of file APIntHelper.h.
|
inline |
Definition at line 94 of file APIntHelper.h.
|
inline |
Definition at line 82 of file APIntHelper.h.
|
inline |
Definition at line 86 of file APIntHelper.h.
|
inline |
Definition at line 70 of file APIntHelper.h.
|
inline |
Definition at line 232 of file TypeHelper.h.
|
inline |
Definition at line 41 of file AttributeHelper.h.
bool llzk::structTypesUnify | ( | component::StructType | lhs, |
component::StructType | rhs, | ||
mlir::ArrayRef< llvm::StringRef > | rhsReversePrefix = {}, | ||
UnificationMap * | unifications = nullptr ) |
Return true
iff the two StructType instances are equivalent or could be equivalent after full instantiation of struct parameters.
bool llzk::structTypesUnify | ( | StructType | lhs, |
StructType | rhs, | ||
ArrayRef< StringRef > | rhsReversePrefix, | ||
UnificationMap * | unifications ) |
Definition at line 758 of file TypeHelper.cpp.
ExpressionValue llzk::sub | ( | llvm::SMTSolverRef | solver, |
const ExpressionValue & | lhs, | ||
const ExpressionValue & | rhs ) |
Definition at line 494 of file IntervalAnalysis.cpp.
|
inline |
Definition at line 33 of file AttributeHelper.h.
|
inline |
Return true
iff the two lists of Type instances are equivalent or could be equivalent after full instantiation of struct parameters (if applicable within the given types).
Definition at line 221 of file TypeHelper.h.
bool llzk::typeParamsUnify | ( | const ArrayAttr & | lhsParams, |
const ArrayAttr & | rhsParams, | ||
UnificationMap * | unifications ) |
Return true
iff the two ArrayAttr instances containing StructType or ArrayType parameters are equivalent or could be equivalent after full instantiation of struct parameters.
Definition at line 746 of file TypeHelper.cpp.
bool llzk::typeParamsUnify | ( | const ArrayRef< Attribute > & | lhsParams, |
const ArrayRef< Attribute > & | rhsParams, | ||
UnificationMap * | unifications ) |
Definition at line 737 of file TypeHelper.cpp.
bool llzk::typeParamsUnify | ( | const mlir::ArrayAttr & | lhsParams, |
const mlir::ArrayAttr & | rhsParams, | ||
UnificationMap * | unifications = nullptr ) |
Return true
iff the two ArrayAttr instances containing StructType or ArrayType parameters are equivalent or could be equivalent after full instantiation of struct parameters.
bool llzk::typeParamsUnify | ( | const mlir::ArrayRef< mlir::Attribute > & | lhsParams, |
const mlir::ArrayRef< mlir::Attribute > & | rhsParams, | ||
UnificationMap * | unifications = nullptr ) |
Return true
iff the two ArrayRef instances containing StructType or ArrayType parameters are equivalent or could be equivalent after full instantiation of struct parameters.
bool llzk::typesUnify | ( | mlir::Type | lhs, |
mlir::Type | rhs, | ||
mlir::ArrayRef< llvm::StringRef > | rhsReversePrefix = {}, | ||
UnificationMap * | unifications = nullptr ) |
Return true
iff the two Type instances are equivalent or could be equivalent after full instantiation of struct parameters (if applicable within the given types).
bool llzk::typesUnify | ( | Type | lhs, |
Type | rhs, | ||
ArrayRef< StringRef > | rhsReversePrefix, | ||
UnificationMap * | unifications ) |
Definition at line 765 of file TypeHelper.cpp.
LogicalResult llzk::verifyAffineMapAttrType | ( | EmitErrorFn | emitError, |
Attribute | in ) |
Definition at line 826 of file TypeHelper.cpp.
mlir::LogicalResult llzk::verifyAffineMapAttrType | ( | EmitErrorFn | emitError, |
mlir::Attribute | in ) |
Verify that all AffineMapAttr only have a single result.
LogicalResult llzk::verifyArrayDimSizes | ( | EmitErrorFn | emitError, |
ArrayRef< Attribute > | dimensionSizes ) |
Definition at line 848 of file TypeHelper.cpp.
mlir::LogicalResult llzk::verifyArrayDimSizes | ( | EmitErrorFn | emitError, |
mlir::ArrayRef< mlir::Attribute > | dimensionSizes ) |
Verify that the array dimensions are valid.
mlir::LogicalResult llzk::verifyArrayType | ( | EmitErrorFn | emitError, |
mlir::Type | elementType, | ||
mlir::ArrayRef< mlir::Attribute > | dimensionSizes ) |
Verify that the ArrayType is valid.
LogicalResult llzk::verifyArrayType | ( | EmitErrorFn | emitError, |
Type | elementType, | ||
ArrayRef< Attribute > | dimensionSizes ) |
Definition at line 853 of file TypeHelper.cpp.
LogicalResult llzk::verifyIntAttrType | ( | EmitErrorFn | emitError, |
Attribute | in ) |
Definition at line 811 of file TypeHelper.cpp.
mlir::LogicalResult llzk::verifyIntAttrType | ( | EmitErrorFn | emitError, |
mlir::Attribute | in ) |
Verify that all IntegerAttr have type IndexType.
mlir::LogicalResult llzk::verifyParamOfType | ( | mlir::SymbolTableCollection & | tables, |
mlir::SymbolRefAttr | param, | ||
mlir::Type | structOrArrayType, | ||
mlir::Operation * | origin ) |
Ensure that the given symbol (that is used as a parameter of the given type) can be resolved.
LogicalResult llzk::verifyParamOfType | ( | SymbolTableCollection & | tables, |
SymbolRefAttr | param, | ||
Type | parameterizedType, | ||
Operation * | origin ) |
Definition at line 248 of file SymbolHelper.cpp.
mlir::LogicalResult llzk::verifyParamsOfType | ( | mlir::SymbolTableCollection & | tables, |
mlir::ArrayRef< mlir::Attribute > | tyParams, | ||
mlir::Type | structOrArrayType, | ||
mlir::Operation * | origin ) |
Ensure that any symbols that appear within the given attributes (that are parameters of the given type) can be resolved.
LogicalResult llzk::verifyParamsOfType | ( | SymbolTableCollection & | tables, |
ArrayRef< Attribute > | tyParams, | ||
Type | parameterizedType, | ||
Operation * | origin ) |
Definition at line 276 of file SymbolHelper.cpp.
LogicalResult llzk::verifyStructTypeParams | ( | EmitErrorFn | emitError, |
ArrayAttr | params ) |
Definition at line 844 of file TypeHelper.cpp.
mlir::LogicalResult llzk::verifyStructTypeParams | ( | EmitErrorFn | emitError, |
mlir::ArrayAttr | params ) |
Verify that the StructType parameters are valid.
mlir::FailureOr< component::StructDefOp > llzk::verifyStructTypeResolution | ( | mlir::SymbolTableCollection & | tables, |
component::StructType | ty, | ||
mlir::Operation * | origin ) |
Ensure that all symbols used within the type can be resolved.
FailureOr< StructDefOp > llzk::verifyStructTypeResolution | ( | SymbolTableCollection & | tables, |
StructType | ty, | ||
Operation * | origin ) |
Definition at line 300 of file SymbolHelper.cpp.
mlir::LogicalResult llzk::verifyTypeResolution | ( | mlir::SymbolTableCollection & | tables, |
mlir::Operation * | origin, | ||
const Range & | types ) |
Ensure that all symbols used within all Type instances can be resolved.
Definition at line 157 of file SymbolHelper.h.
mlir::LogicalResult llzk::verifyTypeResolution | ( | mlir::SymbolTableCollection & | tables, |
mlir::Operation * | origin, | ||
mlir::Type | type ) |
Ensure that all symbols used within the given Type instance can be resolved.
LogicalResult llzk::verifyTypeResolution | ( | SymbolTableCollection & | tables, |
Operation * | origin, | ||
Type | ty ) |
Definition at line 324 of file SymbolHelper.cpp.
|
constexpr |
Symbol name for the main entry point struct/component (if any).
There are additional restrictions on the struct with this name:
struct<Signal>
or array<.. x struct<Signal>>
. Definition at line 23 of file Constants.h.
|
constexpr |
Symbol name for the struct/component representing a signal.
A "signal" has direct correspondence to a circom signal or AIR/PLONK column, opposed to intermediate values or other expressions.
Definition at line 16 of file Constants.h.
|
constexpr |
Symbol name for the witness generation (and resp.
constraint generation) functions within a component.
Definition at line 27 of file Constants.h.
|
constexpr |
Definition at line 28 of file Constants.h.
|
constexpr |
Name of the attribute on the top-level ModuleOp that specifies the IR language name.
Definition at line 31 of file Constants.h.