mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-11 10:31:40 +00:00
e274b476de
Previously we would read-modify-write the target bits when processing relocations for the MCJIT. This had the problem that when relocations were processed multiple times for the same object file (as they can be), the result is not idempotent and the values became corrupted. The solution to this is to take any bits used in the destination from the pristine object file as LLVM emitted it. This should fix PR16013 and remote MCJIT on ARM ELF targets. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@182800 91177308-0d34-0410-b5e6-96231b3b80d8
22 lines
701 B
LLVM
22 lines
701 B
LLVM
; RUN: %lli_mcjit -remote-mcjit %s > /dev/null
|
|
; XFAIL: mips
|
|
|
|
define double @test(double* %DP, double %Arg) {
|
|
%D = load double* %DP ; <double> [#uses=1]
|
|
%V = fadd double %D, 1.000000e+00 ; <double> [#uses=2]
|
|
%W = fsub double %V, %V ; <double> [#uses=3]
|
|
%X = fmul double %W, %W ; <double> [#uses=2]
|
|
%Y = fdiv double %X, %X ; <double> [#uses=2]
|
|
%Q = fadd double %Y, %Arg ; <double> [#uses=1]
|
|
%R = bitcast double %Q to double ; <double> [#uses=1]
|
|
store double %Q, double* %DP
|
|
ret double %Y
|
|
}
|
|
|
|
define i32 @main() {
|
|
%X = alloca double ; <double*> [#uses=2]
|
|
store double 0.000000e+00, double* %X
|
|
call double @test( double* %X, double 2.000000e+00 ) ; <double>:1 [#uses=0]
|
|
ret i32 0
|
|
}
|