mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
bc8114f733
Make the handling of calls to intrinsics in CGSCC consistent: they are not treated like regular function calls because they are never lowered to function calls. Without this patch, we can get dangling pointer asserts from the subsequent loop that processes callsites because it already ignores intrinsics. See http://llvm.org/bugs/show_bug.cgi?id=21403 for more details / discussion. Differential Revision: http://reviews.llvm.org/D6124 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@221802 91177308-0d34-0410-b5e6-96231b3b80d8
20 lines
523 B
LLVM
20 lines
523 B
LLVM
; RUN: opt < %s -inline -instcombine -S | FileCheck %s
|
|
|
|
; PR21403: http://llvm.org/bugs/show_bug.cgi?id=21403
|
|
; When the call to sqrtf is replaced by an intrinsic call to fabs,
|
|
; it should not cause a problem in CGSCC.
|
|
|
|
define float @bar(float %f) #0 {
|
|
%mul = fmul fast float %f, %f
|
|
%call1 = call float @sqrtf(float %mul) #0
|
|
ret float %call1
|
|
|
|
; CHECK-LABEL: @bar(
|
|
; CHECK-NEXT: call float @llvm.fabs.f32
|
|
; CHECK-NEXT: ret float
|
|
}
|
|
|
|
declare float @sqrtf(float) #0
|
|
|
|
attributes #0 = { readnone "unsafe-fp-math"="true" }
|