diff options
author | Chris Lattner <sabre@nondot.org> | 2009-04-22 00:03:30 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-04-22 00:03:30 +0000 |
commit | f8dc07369aa022314461ce15ab2aba51c87c54ad (patch) | |
tree | 1627000a6c1bddcfe58e837a0f15e7ed0f669c8b /clang/test/CodeGen/inline.c | |
parent | c3366a555b382af03e207ce72a0ab14f3a0f6988 (diff) | |
download | bcm5719-llvm-f8dc07369aa022314461ce15ab2aba51c87c54ad.tar.gz bcm5719-llvm-f8dc07369aa022314461ce15ab2aba51c87c54ad.zip |
Fix some mishandling of the attr(gnu_inline) mode when used with
extern. Previously we would warn about it and ignore the attribute.
This is incorrect, it should be handled as a c89 "extern inline"
function. Many thanks to Matthieu Castet for pointing this out and
beating me over the head until I got it.
PR3988: extern inline function are not externally visible
llvm-svn: 69756
Diffstat (limited to 'clang/test/CodeGen/inline.c')
-rw-r--r-- | clang/test/CodeGen/inline.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/clang/test/CodeGen/inline.c b/clang/test/CodeGen/inline.c index 48219887339..eb8ee718d32 100644 --- a/clang/test/CodeGen/inline.c +++ b/clang/test/CodeGen/inline.c @@ -6,6 +6,7 @@ // RUN: grep "define void @unreferenced1()" %t && // RUN: not grep unreferenced2 %t && // RUN: grep "define void @gnu_inline()" %t && +// RUN: grep "define available_externally void @gnu_ei_inline()" %t && // RUN: echo "\nC99 tests:" && // RUN: clang %s -emit-llvm -S -o %t -std=c99 && @@ -15,6 +16,7 @@ // RUN: not grep unreferenced1 %t && // RUN: grep "define void @unreferenced2()" %t && // RUN: grep "define void @gnu_inline()" %t && +// RUN: grep "define available_externally void @gnu_ei_inline()" %t && // RUN: echo "\nC++ tests:" && // RUN: clang %s -emit-llvm -S -o %t -std=c++98 && @@ -22,7 +24,8 @@ // RUN: grep "define linkonce_odr i32 @_Z3foov()" %t && // RUN: grep "define i32 @_Z3barv()" %t && // RUN: not grep unreferenced %t && -// RUN: grep "define void @_Z10gnu_inlinev()" %t +// RUN: grep "define void @_Z10gnu_inlinev()" %t && +// RUN: grep "define available_externally void @_Z13gnu_ei_inlinev()" %t extern inline int ei() { return 123; } @@ -37,3 +40,8 @@ inline void unreferenced1() {} extern inline void unreferenced2() {} __inline __attribute((__gnu_inline__)) void gnu_inline() {} + +// PR3988 +extern inline __attribute__((gnu_inline)) void gnu_ei_inline() {} +void (*P)() = gnu_ei_inline; + |