From d530ee964176f53ec6400adc8aa271dd2784f1e3 Mon Sep 17 00:00:00 2001 From: Sirui Mu Date: Mon, 30 Dec 2024 21:47:52 +0800 Subject: [PATCH] [CIR] Add integer result type for `#cir.global_view` --- .../CIR/Lowering/DirectToLLVM/LowerToLLVM.cpp | 31 ++++++++++++++----- clang/test/CIR/Lowering/globals.cir | 20 ++++++++++++ 2 files changed, 43 insertions(+), 8 deletions(-) diff --git a/clang/lib/CIR/Lowering/DirectToLLVM/LowerToLLVM.cpp b/clang/lib/CIR/Lowering/DirectToLLVM/LowerToLLVM.cpp index c933035cd850..339d5769a7cf 100644 --- a/clang/lib/CIR/Lowering/DirectToLLVM/LowerToLLVM.cpp +++ b/clang/lib/CIR/Lowering/DirectToLLVM/LowerToLLVM.cpp @@ -620,16 +620,24 @@ lowerCirAttrAsValue(mlir::Operation *parentOp, cir::GlobalViewAttr globalAttr, indices, true); } - auto ptrTy = mlir::dyn_cast(globalAttr.getType()); - assert(ptrTy && "Expecting pointer type in GlobalViewAttr"); - auto llvmEltTy = converter->convertType(ptrTy.getPointee()); + if (auto intTy = mlir::dyn_cast(globalAttr.getType())) { + auto llvmDstTy = converter->convertType(globalAttr.getType()); + return rewriter.create(parentOp->getLoc(), + llvmDstTy, addrOp); + } + + if (auto ptrTy = mlir::dyn_cast(globalAttr.getType())) { + auto llvmEltTy = converter->convertType(ptrTy.getPointee()); - if (llvmEltTy == sourceType) - return addrOp; + if (llvmEltTy == sourceType) + return addrOp; + + auto llvmDstTy = converter->convertType(globalAttr.getType()); + return rewriter.create(parentOp->getLoc(), llvmDstTy, + addrOp); + } - auto llvmDstTy = converter->convertType(globalAttr.getType()); - return rewriter.create(parentOp->getLoc(), llvmDstTy, - addrOp); + llvm_unreachable("Expecting pointer or integer type for GlobalViewAttr"); } /// Switches on the type of attribute and calls the appropriate conversion. @@ -1588,6 +1596,13 @@ mlir::LogicalResult CIRToLLVMConstantOpLowering::matchAndRewrite( attr = rewriter.getIntegerAttr(typeConverter->convertType(op.getType()), value); } else if (mlir::isa(op.getType())) { + // Lower GlobalAddrAttr to llvm.mlir.addressof + llvm.mlir.ptrtoint + if (auto ga = mlir::dyn_cast(op.getValue())) { + auto newOp = lowerCirAttrAsValue(op, ga, rewriter, getTypeConverter()); + rewriter.replaceOp(op, newOp); + return mlir::success(); + } + attr = rewriter.getIntegerAttr( typeConverter->convertType(op.getType()), mlir::cast(op.getValue()).getValue()); diff --git a/clang/test/CIR/Lowering/globals.cir b/clang/test/CIR/Lowering/globals.cir index 765544e8c125..0108b56b8a7b 100644 --- a/clang/test/CIR/Lowering/globals.cir +++ b/clang/test/CIR/Lowering/globals.cir @@ -27,6 +27,7 @@ module { cir.global external @alpha = #cir.const_array<[#cir.int<97> : !s8i, #cir.int<98> : !s8i, #cir.int<99> : !s8i, #cir.int<0> : !s8i]> : !cir.array cir.global "private" constant internal @".str" = #cir.const_array<"example\00" : !cir.array> : !cir.array {alignment = 1 : i64} cir.global external @s = #cir.global_view<@".str"> : !cir.ptr + cir.global external @s_addr = #cir.global_view<@".str"> : !u64i // MLIR: llvm.mlir.global internal constant @".str"("example\00") // MLIR-SAME: {addr_space = 0 : i32, alignment = 1 : i64} // MLIR: llvm.mlir.global external @s() {addr_space = 0 : i32} : !llvm.ptr { @@ -34,8 +35,14 @@ module { // MLIR: %1 = llvm.bitcast %0 : !llvm.ptr to !llvm.ptr // MLIR: llvm.return %1 : !llvm.ptr // MLIR: } + // MLIR: llvm.mlir.global external @s_addr() {addr_space = 0 : i32} : i64 { + // MLIR: %0 = llvm.mlir.addressof @".str" : !llvm.ptr + // MLIR: %1 = llvm.ptrtoint %0 : !llvm.ptr to i64 + // MLIR: llvm.return %1 : i64 + // MLIR: } // LLVM: @.str = internal constant [8 x i8] c"example\00" // LLVM: @s = global ptr @.str + // LLVM: @s_addr = global i64 ptrtoint (ptr @.str to i64) cir.global external @aPtr = #cir.global_view<@a> : !cir.ptr // MLIR: llvm.mlir.global external @aPtr() {addr_space = 0 : i32} : !llvm.ptr { // MLIR: %0 = llvm.mlir.addressof @a : !llvm.ptr @@ -198,4 +205,17 @@ module { } // MLIR: %0 = llvm.mlir.addressof @zero_array + cir.func @global_view_as_integer() -> !u64i { + %0 = cir.const #cir.global_view<@".str"> : !u64i + cir.return %0 : !u64i + } + // MLIR-LABEL: @global_view_as_integer + // MLIR-NEXT: %0 = llvm.mlir.addressof @".str" : !llvm.ptr + // MLIR-NEXT: %1 = llvm.ptrtoint %0 : !llvm.ptr to i64 + // MLIR-NEXT: llvm.return %1 : i64 + // MLIR-NEXT: } + // LLVM-LABEL: @global_view_as_integer + // LLVM-NEXT: ret i64 ptrtoint (ptr @.str to i64) + // LLVM-NEXT: } + }