mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-22 11:39:35 +00:00
847a83dbad
in the 32-bit signed offset field of addresses. Even though this may be intended, some linkers refuse to relocate code where the relocated address computation overflows. Also, fix the sign-extension of constant offsets to use the actual pointer size, rather than the size of the GlobalAddress node, which may be different, for example on x86-64 where MVT::i32 is used when the address is being fit into the 32-bit displacement field. llvm-svn: 57885
15 lines
537 B
LLVM
15 lines
537 B
LLVM
; RUN: llvm-as < %s | llc -march=x86-64 | grep mov | count 2
|
|
|
|
; Fold an offset into an address even if it's not a 32-bit
|
|
; signed integer.
|
|
|
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
|
|
target triple = "x86_64-unknown-linux-gnu"
|
|
@call_used_regs = external global [53 x i8], align 32
|
|
|
|
define fastcc void @foo() nounwind {
|
|
%t = getelementptr [53 x i8]* @call_used_regs, i64 0, i64 4294967295
|
|
store i8 1, i8* %t, align 1
|
|
ret void
|
|
}
|