; REQUIRES: x86
;; malloc+memset references can be combined to a calloc reference.
;; Test that we extract calloc defined in a lazy bitcode file to satisfy
;; possible references from LTO generated object files.
; RUN: rm -rf %t && split-file %s %t && cd %t
; RUN: llvm-as a.ll -o a.bc
; RUN: llvm-as calloc.ll -o calloc.bc
; RUN: llvm-mc -filetype=obj -triple=x86_64 lib.s -o lib.o
; RUN: ld.lld -u foo a.bc --start-lib calloc.bc lib.o --end-lib -o t --save-temps
; RUN: llvm-dis < t.0.4.opt.bc | FileCheck %s
; RUN: llvm-nm t | FileCheck %s --check-prefix=NM
; CHECK: define dso_local void @calloc
; NM-NOT: {{.}}
; NM: {{.*}} T _start
;; TODO: Currently the symbol is lazy, which lowers to a SHN_ABS symbol at address 0.
; NM-NEXT: {{.*}} T calloc
; NM-NEXT: {{.*}} T foo
; NM-NEXT: {{.*}} T malloc
; NM-NEXT: {{.*}} T memset
; NM-NOT: {{.}}
;--- a.ll
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-i128:128-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"
define ptr @foo() noinline {
entry:
%call = tail call noalias ptr @malloc(i64 400)
tail call void @llvm.memset.p0.i64(ptr %call, i8 0, i64 400, i1 false)
ret ptr %call
}
define void @_start(ptr %a, ptr %b) {
entry:
call ptr @foo()
ret void
}
declare ptr @malloc(i64)
declare void @llvm.memset.p0.i64(ptr nocapture writeonly, i8, i64, i1 immarg)
;--- calloc.ll
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-i128:128-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"
define void @calloc(i64, i64) {
entry:
ret void
}
;--- lib.s
.globl malloc, memset
malloc:
memset: