diff options
author | NAKAMURA Takumi <geek4civic@gmail.com> | 2025-01-09 18:49:54 +0900 |
---|---|---|
committer | NAKAMURA Takumi <geek4civic@gmail.com> | 2025-01-09 18:49:54 +0900 |
commit | e2810c9a248f4c7fbfae84bb32b6f7e01027458b (patch) | |
tree | ae0b02a8491b969a1cee94ea16ffe42c559143c5 /flang/lib/Optimizer/Builder/FIRBuilder.cpp | |
parent | fa04eb4af95c1ca7377279728cb004bcd2324d01 (diff) | |
parent | bdcf47e4bcb92889665825654bb80a8bbe30379e (diff) | |
download | llvm-users/chapuni/cov/single/switch.zip llvm-users/chapuni/cov/single/switch.tar.gz llvm-users/chapuni/cov/single/switch.tar.bz2 |
Merge branch 'users/chapuni/cov/single/base' into users/chapuni/cov/single/switchusers/chapuni/cov/single/switch
Diffstat (limited to 'flang/lib/Optimizer/Builder/FIRBuilder.cpp')
-rw-r--r-- | flang/lib/Optimizer/Builder/FIRBuilder.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/flang/lib/Optimizer/Builder/FIRBuilder.cpp b/flang/lib/Optimizer/Builder/FIRBuilder.cpp index 3a39c45..d01becf 100644 --- a/flang/lib/Optimizer/Builder/FIRBuilder.cpp +++ b/flang/lib/Optimizer/Builder/FIRBuilder.cpp @@ -1626,6 +1626,25 @@ mlir::Value fir::factory::genCPtrOrCFunptrAddr(fir::FirOpBuilder &builder, cPtr, addrFieldIndex); } +mlir::Value fir::factory::genCDevPtrAddr(fir::FirOpBuilder &builder, + mlir::Location loc, + mlir::Value cDevPtr, mlir::Type ty) { + auto recTy = mlir::cast<fir::RecordType>(ty); + assert(recTy.getTypeList().size() == 1); + auto cptrFieldName = recTy.getTypeList()[0].first; + mlir::Type cptrFieldTy = recTy.getTypeList()[0].second; + auto fieldIndexType = fir::FieldType::get(ty.getContext()); + mlir::Value cptrFieldIndex = builder.create<fir::FieldIndexOp>( + loc, fieldIndexType, cptrFieldName, recTy, + /*typeParams=*/mlir::ValueRange{}); + auto cptrCoord = builder.create<fir::CoordinateOp>( + loc, builder.getRefType(cptrFieldTy), cDevPtr, cptrFieldIndex); + auto [addrFieldIndex, addrFieldTy] = + genCPtrOrCFunptrFieldIndex(builder, loc, cptrFieldTy); + return builder.create<fir::CoordinateOp>(loc, builder.getRefType(addrFieldTy), + cptrCoord, addrFieldIndex); +} + mlir::Value fir::factory::genCPtrOrCFunptrValue(fir::FirOpBuilder &builder, mlir::Location loc, mlir::Value cPtr) { |