summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFangrui Song <maskray@google.com>2019-08-22 01:48:34 +0000
committerFangrui Song <maskray@google.com>2019-08-22 01:48:34 +0000
commit246750c2a91951fc4b77ebe43d568f47843e6399 (patch)
tree6f7b6233086711c7234d45ac41405910912cc5f7
parent22dc44ff896a34a94c7ed6d3bf7b577b98e34fbd (diff)
downloadbcm5719-llvm-246750c2a91951fc4b77ebe43d568f47843e6399.tar.gz
bcm5719-llvm-246750c2a91951fc4b77ebe43d568f47843e6399.zip
[COFF] Fix section name for constants larger than 64 bits on Windows
APIntToHexString returns wrong value ("0000000000000000ffffffffffffffff") for integer larger than 64 bits, and thus TargetLoweringObjectFileCOFF::getSectionForConstant returns same section name for all numbers larger than 64 bits. This patch tries to fix it. Differential Revision: https://reviews.llvm.org/D66458 Patch by Senran Zhang llvm-svn: 369610
-rw-r--r--llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp3
-rw-r--r--llvm/test/CodeGen/X86/coff-fp-section-name.ll97
2 files changed, 99 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
index 7abc86dfde7..ae323606f8a 100644
--- a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
+++ b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
@@ -1597,7 +1597,8 @@ const MCExpr *TargetLoweringObjectFileCOFF::lowerRelativeReference(
static std::string APIntToHexString(const APInt &AI) {
unsigned Width = (AI.getBitWidth() / 8) * 2;
- std::string HexString = utohexstr(AI.getLimitedValue(), /*LowerCase=*/true);
+ std::string HexString = AI.toString(16, /*Signed=*/false);
+ transform(HexString.begin(), HexString.end(), HexString.begin(), tolower);
unsigned Size = HexString.size();
assert(Width >= Size && "hex string is too large!");
HexString.insert(HexString.begin(), Width - Size, '0');
diff --git a/llvm/test/CodeGen/X86/coff-fp-section-name.ll b/llvm/test/CodeGen/X86/coff-fp-section-name.ll
new file mode 100644
index 00000000000..5228596efd6
--- /dev/null
+++ b/llvm/test/CodeGen/X86/coff-fp-section-name.ll
@@ -0,0 +1,97 @@
+; RUN: llc -O0 < %s | FileCheck %s
+
+target datalayout = "e-m:w-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-pc-windows-msvc"
+
+define dso_local i32 @main() #0 {
+entry:
+ %retval = alloca i32, align 4
+ %a = alloca fp128, align 16
+ %b = alloca fp128, align 16
+ %c = alloca fp128, align 16
+ %d = alloca fp128, align 16
+ %e = alloca fp128, align 16
+ %f = alloca fp128, align 16
+ %g = alloca fp128, align 16
+ %h = alloca float, align 4
+ %i = alloca float, align 4
+ %j = alloca float, align 4
+ %k = alloca float, align 4
+ %l = alloca double, align 8
+ %m = alloca double, align 8
+ %n = alloca double, align 8
+ %o = alloca double, align 8
+ store i32 0, i32* %retval, align 4
+
+ store fp128 0xLBB2C11D0AE2E087D73E717A35985531C, fp128* %a, align 16
+ store fp128 0xLBB2C11D0AE2E087D73E717A35985531C, fp128* %b, align 16
+ store fp128 0xL00000000000000004002000000000000, fp128* %c, align 16
+ store fp128 0xL00000000000000007FFF800000000000, fp128* %d, align 16
+ store fp128 0xL00000000000000007FFF000000000000, fp128* %e, align 16
+ store fp128 0xL00000000000000007FFF000000000000, fp128* %f, align 16
+ store fp128 0xL10000000000000003F66244CE242C556, fp128* %g, align 16
+ store float 0x3E212E0BE0000000, float* %h, align 4
+ store float 8.000000e+00, float* %i, align 4
+ store float 0x7FF8000000000000, float* %j, align 4
+ store float 0x7FF0000000000000, float* %k, align 4
+ store double 1.000000e+00, double* %l, align 8
+ store double 8.000000e+00, double* %m, align 8
+ store double 0x7FF8000000000000, double* %n, align 8
+ store double 0x7FF0000000000000, double* %o, align 8
+
+ ret i32 0
+}
+
+attributes #0 = { "target-features"="+mmx" }
+
+; %o
+; CHECK: .globl __real@7ff0000000000000
+; CHECK: .section .rdata,"dr",discard,__real@7ff0000000000000
+
+; %n
+; CHECK: .globl __real@7ff8000000000000
+; CHECK: .section .rdata,"dr",discard,__real@7ff8000000000000
+
+; %m
+; CHECK: .globl __real@4020000000000000
+; CHECK: .section .rdata,"dr",discard,__real@4020000000000000
+
+; %l
+; CHECK: .globl __real@3ff0000000000000
+; CHECK: .section .rdata,"dr",discard,__real@3ff0000000000000
+
+; %j
+; CHECK: .globl __real@7f800000
+; CHECK: .section .rdata,"dr",discard,__real@7f800000
+
+; %k
+; CHECK: .globl __real@7fc00000
+; CHECK: .section .rdata,"dr",discard,__real@7fc00000
+
+; %i
+; CHECK: .globl __real@41000000
+; CHECK: .section .rdata,"dr",discard,__real@41000000
+
+; %h
+; CHECK: .globl __real@3109705f
+; CHECK: .section .rdata,"dr",discard,__real@3109705f
+
+; %a, %b
+; CHECK: .globl __xmm@73e717a35985531cbb2c11d0ae2e087d
+; CHECK: .section .rdata,"dr",discard,__xmm@73e717a35985531cbb2c11d0ae2e087d
+
+; %c
+; CHECK: .globl __xmm@40020000000000000000000000000000
+; CHECK: .section .rdata,"dr",discard,__xmm@40020000000000000000000000000000
+
+; %d
+; CHECK: .globl __xmm@7fff8000000000000000000000000000
+; CHECK: .section .rdata,"dr",discard,__xmm@7fff8000000000000000000000000000
+
+; %e, %f
+; CHECK: .globl __xmm@7fff0000000000000000000000000000
+; CHECK: .section .rdata,"dr",discard,__xmm@7fff0000000000000000000000000000
+
+; %g
+; CHECK: .globl __xmm@3f66244ce242c5561000000000000000
+; CHECK: .section .rdata,"dr",discard,__xmm@3f66244ce242c5561000000000000000
OpenPOWER on IntegriCloud