[llvm] SimplifyLibCalls: Use default globals address space when building new global strings. (PR #118729)

Eli Friedman via llvm-commits llvm-commits at lists.llvm.org
Mon Dec 9 13:27:30 PST 2024


================
@@ -0,0 +1,35 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; Test that the printf library call simplifier works correctly.
+;
+; RUN: opt < %s -passes=instcombine -S | FileCheck %s
+
+target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128-G200"
+
+ at hello_world = addrspace(200) constant [13 x i8] c"hello world\0A\00"
+ at percent_s = addrspace(200) constant [4 x i8] c"%s\0A\00"
+
+declare i32 @printf(ptr addrspace(200) , ...)
+declare i32 @puts(ptr addrspace(200))
----------------
efriedma-quic wrote:

> that was in part due to not having any way to get the right address space for a libcall

Right... like I mentioned before, I think we do want to tie libcalls to a specific address-space.  It's way too easy to make mistakes otherwise in an environment with multiple address-spaces.

> What was universally agreed though was that picking a random one of the fine-grained address spaces was not correct (the initial version of the patch even used the globals address space just like this one here).

Yes, none of the existing address-spaces in the datalayout matches the concept we want here.

https://github.com/llvm/llvm-project/pull/118729


More information about the llvm-commits mailing list