[clang] [CIR] Implement builtin extractf (PR #170427)
Henrich Lauko via cfe-commits
cfe-commits at lists.llvm.org
Tue Dec 2 23:43:24 PST 2025
================
@@ -701,7 +766,31 @@ mlir::Value CIRGenFunction::emitX86BuiltinExpr(unsigned builtinID,
case X86::BI__builtin_ia32_extractf64x2_256_mask:
case X86::BI__builtin_ia32_extracti64x2_256_mask:
case X86::BI__builtin_ia32_extractf64x2_512_mask:
- case X86::BI__builtin_ia32_extracti64x2_512_mask:
+ case X86::BI__builtin_ia32_extracti64x2_512_mask: {
+ mlir::Location loc = getLoc(expr->getExprLoc());
+ cir::VectorType dstTy = cast<cir::VectorType>(convertType(expr->getType()));
+ unsigned numElts = dstTy.getSize();
+ unsigned srcNumElts = cast<cir::VectorType>(ops[0].getType()).getSize();
+ unsigned subVectors = srcNumElts / numElts;
+ unsigned index =
+ ops[1].getDefiningOp<cir::ConstantOp>().getIntValue().getZExtValue();
+
----------------
xlauko wrote:
missing:
```
assert(llvm::isPowerOf2_32(subVectors) && "Expected power of 2 subvectors");
```
https://github.com/llvm/llvm-project/pull/170427
More information about the cfe-commits
mailing list