mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-17 21:35:07 +00:00
0b18e59336
size by the array amount as an i32 value instead of promoting from i32 to i64 then doing the multiply. Not doing this broke wrap-around assumptions that the optimizers (validly) made. The ultimate real fix for this is to introduce i64 version of alloca and remove mallocinst. This fixes PR3829 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@67093 91177308-0d34-0410-b5e6-96231b3b80d8
11 lines
303 B
LLVM
11 lines
303 B
LLVM
; RUN: llvm-as < %s | llc -march=x86-64 | grep {shll.*3, %edi}
|
|
; PR3829
|
|
; The generated code should multiply by 3 (sizeof i8*) as an i32,
|
|
; not as an i64!
|
|
|
|
define i8** @test(i32 %sz) {
|
|
%sub = add i32 %sz, 536870911 ; <i32> [#uses=1]
|
|
%call = malloc i8*, i32 %sub ; <i8**> [#uses=1]
|
|
ret i8** %call
|
|
}
|