Details
Details
Diff Detail
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
mlir/lib/Conversion/StandardToSPIRV/ConvertStandardToSPIRV.cpp | ||
---|---|---|
870 | I think we need to special treat the case where the src/target bitwidth == SPIRVTypeConverter::getIndexType() by just removing this op? OpSConvert requires the source and target bitwidth to be different. Casting from index to i32 will result in an invalid OpSConvert. |
Comment Actions
Yeah the semantics of std.index_cast requires sign extending : https://mlir.llvm.org/docs/Dialects/Standard/#stdindex_cast-indexcastop
Comment Actions
Add test cases for casting between i32 and index.
mlir/lib/Conversion/StandardToSPIRV/ConvertStandardToSPIRV.cpp | ||
---|---|---|
870 | I think this case is already handled in TypeCastingOpPattern? auto dstType = this->typeConverter.convertType(operation.getResult().getType()); if (dstType == operands.front().getType()) { // Due to type conversion, we are seeing the same source and target type. // Then we can just erase this operation by forwarding its operand. rewriter.replaceOp(operation, operands.front()); } else { rewriter.template replaceOpWithNewOp<SPIRVOp>( operation, dstType, operands, ArrayRef<NamedAttribute>()); } The first condition will replace it with operand. Let me add more tests for this case. |
I think we need to special treat the case where the src/target bitwidth == SPIRVTypeConverter::getIndexType() by just removing this op? OpSConvert requires the source and target bitwidth to be different. Casting from index to i32 will result in an invalid OpSConvert.