Skip to content

Commit

Permalink
fix(compiler): Handle tensor.empty in the pass that lower tfhe to the…
Browse files Browse the repository at this point in the history
… simulatation code
  • Loading branch information
BourgerieQuentin committed Mar 25, 2024
1 parent 79b72db commit 182c01b
Showing 1 changed file with 8 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -607,18 +607,20 @@ void SimulateTFHEPass::runOnOperation() {
mlir::concretelang::TypeConvertingReinstantiationPattern<
mlir::tensor::CollapseShapeOp>,
mlir::concretelang::TypeConvertingReinstantiationPattern<
mlir::tensor::YieldOp>>(&getContext(), converter);
mlir::tensor::YieldOp>,
mlir::concretelang::TypeConvertingReinstantiationPattern<
mlir::tensor::EmptyOp>>(&getContext(), converter);
// legalize ops only if operand and result types are legal
target.addDynamicallyLegalOp<
mlir::tensor::YieldOp, mlir::scf::YieldOp, mlir::tensor::GenerateOp,
mlir::tensor::ExtractSliceOp, mlir::tensor::ExtractOp,
mlir::tensor::InsertOp, mlir::tensor::InsertSliceOp,
mlir::tensor::FromElementsOp, mlir::tensor::ExpandShapeOp,
mlir::tensor::CollapseShapeOp, mlir::bufferization::AllocTensorOp>(
[&](mlir::Operation *op) {
return converter.isLegal(op->getResultTypes()) &&
converter.isLegal(op->getOperandTypes());
});
mlir::tensor::CollapseShapeOp, mlir::bufferization::AllocTensorOp,
mlir::tensor::EmptyOp>([&](mlir::Operation *op) {
return converter.isLegal(op->getResultTypes()) &&
converter.isLegal(op->getOperandTypes());
});
// Make sure that no ops `linalg.generic` that have illegal types
target
.addDynamicallyLegalOp<mlir::linalg::GenericOp, mlir::tensor::GenerateOp>(
Expand Down

0 comments on commit 182c01b

Please sign in to comment.