Skip to content

Commit

Permalink
AMDGPU: Consider nobuiltin when querying defined libfuncs
Browse files Browse the repository at this point in the history
  • Loading branch information
arsenm committed Aug 14, 2023
1 parent d7fcb5b commit 58fd1de
Show file tree
Hide file tree
Showing 2 changed files with 80 additions and 9 deletions.
24 changes: 15 additions & 9 deletions llvm/lib/Target/AMDGPU/AMDGPULibFunc.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -954,13 +954,16 @@ Function *AMDGPULibFunc::getFunction(Module *M, const AMDGPULibFunc &fInfo) {
std::string FuncName = fInfo.mangle();
Function *F = dyn_cast_or_null<Function>(
M->getValueSymbolTable().lookup(FuncName));
if (!F || F->isDeclaration())
return nullptr;

// check formal with actual types conformance
if (F && !F->isDeclaration() &&
fInfo.isCompatibleSignature(F->getFunctionType()))
return F;
if (F->hasFnAttribute(Attribute::NoBuiltin))
return nullptr;

return nullptr;
if (!fInfo.isCompatibleSignature(F->getFunctionType()))
return nullptr;

return F;
}

FunctionCallee AMDGPULibFunc::getOrInsertFunction(Module *M,
Expand All @@ -969,10 +972,13 @@ FunctionCallee AMDGPULibFunc::getOrInsertFunction(Module *M,
Function *F = dyn_cast_or_null<Function>(
M->getValueSymbolTable().lookup(FuncName));

// check formal with actual types conformance
if (F && !F->isDeclaration() &&
fInfo.isCompatibleSignature(F->getFunctionType()))
return F;
if (F) {
if (F->hasFnAttribute(Attribute::NoBuiltin))
return nullptr;
if (!F->isDeclaration() &&
fInfo.isCompatibleSignature(F->getFunctionType()))
return F;
}

FunctionType *FuncTy = fInfo.getFunctionType(*M);

Expand Down
65 changes: 65 additions & 0 deletions llvm/test/CodeGen/AMDGPU/simplify-libcall-nobuiltin-def.ll
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 2
; RUN: opt -S -mtriple=amdgcn-- -passes=amdgpu-usenative -amdgpu-use-native=all < %s | FileCheck %s

; Verify nobuiltin is respected on a defined function. native_cos is
; marked nobuiltin, but native_sin is not.

define float @_Z10native_sinf(float %x) {
; CHECK-LABEL: define float @_Z10native_sinf
; CHECK-SAME: (float [[X:%.*]]) {
; CHECK-NEXT: [[RESULT:%.*]] = call float asm "
; CHECK-NEXT: ret float [[RESULT]]
;
%result = call float asm "; $0 = native_sin($1)", "=v,v"(float %x)
ret float %result
}

define float @_Z10native_cosf(float %x) nobuiltin {
; CHECK-LABEL: define float @_Z10native_cosf
; CHECK-SAME: (float [[X:%.*]]) #[[ATTR0:[0-9]+]] {
; CHECK-NEXT: [[RESULT:%.*]] = call float asm "
; CHECK-NEXT: ret float [[RESULT]]
;
%result = call float asm "; $0 = native_cos($1)", "=v,v"(float %x)
ret float %result
}

define float @_Z3sinf(float %x) {
; CHECK-LABEL: define float @_Z3sinf
; CHECK-SAME: (float [[X:%.*]]) {
; CHECK-NEXT: [[RESULT:%.*]] = call float asm "
; CHECK-NEXT: ret float [[RESULT]]
;
%result = call float asm "; $0 = sin($1)", "=v,v"(float %x)
ret float %result
}

define float @_Z3cosf(float %x) {
; CHECK-LABEL: define float @_Z3cosf
; CHECK-SAME: (float [[X:%.*]]) {
; CHECK-NEXT: [[RESULT:%.*]] = call float asm "
; CHECK-NEXT: ret float [[RESULT]]
;
%result = call float asm "; $0 = cos($1)", "=v,v"(float %x)
ret float %result
}

define float @call_cos(float %x) {
; CHECK-LABEL: define float @call_cos
; CHECK-SAME: (float [[X:%.*]]) {
; CHECK-NEXT: [[RESULT:%.*]] = call float @_Z3cosf(float [[X]])
; CHECK-NEXT: ret float [[RESULT]]
;
%result = call float @_Z3cosf(float %x)
ret float %result
}

define float @call_sin(float %x) {
; CHECK-LABEL: define float @call_sin
; CHECK-SAME: (float [[X:%.*]]) {
; CHECK-NEXT: [[RESULT:%.*]] = call float @_Z10native_sinf(float [[X]])
; CHECK-NEXT: ret float [[RESULT]]
;
%result = call float @_Z3sinf(float %x)
ret float %result
}

0 comments on commit 58fd1de

Please sign in to comment.