serge-sans-paille created this revision. serge-sans-paille added a reviewer: mstorsjo. Herald added a project: All. serge-sans-paille requested review of this revision. Herald added a project: clang. Herald added a subscriber: cfe-commits.
This is a follow-up to https://reviews.llvm.org/D148723 and fixes the bug reported by @mstorsjo. Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D151783 Files: clang/lib/AST/Decl.cpp clang/test/CodeGen/memcpy-inline-builtin-mutliple-decl.c Index: clang/test/CodeGen/memcpy-inline-builtin-mutliple-decl.c =================================================================== --- /dev/null +++ clang/test/CodeGen/memcpy-inline-builtin-mutliple-decl.c @@ -0,0 +1,29 @@ +// RUN: %clang_cc1 -triple i686-w64-mingw32 -S -emit-llvm -disable-llvm-passes -o - %s | FileCheck %s +// +// Verifies that clang detects memcpy inline version and uses it instead of the builtin. +// Checks that clang correctly walks through multiple forward declaration. + +typedef unsigned int size_t; + +void *memcpy(void *_Dst, const void *_Src, size_t _Size); + +extern __inline__ __attribute__((__always_inline__, __gnu_inline__)) __attribute__((__artificial__)) +void *memcpy(void *__dst, const void *__src, size_t __n) +{ + return __builtin___memcpy_chk(__dst, __src, __n, __builtin_object_size((__dst), ((0) > 0) && (2 > 1))); +} + +void *memcpy(void *_Dst, const void *_Src, size_t _Size); + +char *a, *b; +void func(void) { + memcpy(a, b, 42); +} + +// CHECK-LABEL: define {{.*}} @func( +// CHECK: call ptr @memcpy.inline + +// CHECK-LABEL: declare {{.*}} @memcpy( + +// CHECK-LABEL: define {{.*}} @memcpy.inline( +// CHECK: call ptr @__memcpy_chk Index: clang/lib/AST/Decl.cpp =================================================================== --- clang/lib/AST/Decl.cpp +++ clang/lib/AST/Decl.cpp @@ -3322,7 +3322,7 @@ return false; ASTContext &Context = getASTContext(); - switch (Context.GetGVALinkageForFunction(this)) { + switch (Context.GetGVALinkageForFunction(Definition)) { case GVA_Internal: case GVA_DiscardableODR: case GVA_StrongODR:
Index: clang/test/CodeGen/memcpy-inline-builtin-mutliple-decl.c =================================================================== --- /dev/null +++ clang/test/CodeGen/memcpy-inline-builtin-mutliple-decl.c @@ -0,0 +1,29 @@ +// RUN: %clang_cc1 -triple i686-w64-mingw32 -S -emit-llvm -disable-llvm-passes -o - %s | FileCheck %s +// +// Verifies that clang detects memcpy inline version and uses it instead of the builtin. +// Checks that clang correctly walks through multiple forward declaration. + +typedef unsigned int size_t; + +void *memcpy(void *_Dst, const void *_Src, size_t _Size); + +extern __inline__ __attribute__((__always_inline__, __gnu_inline__)) __attribute__((__artificial__)) +void *memcpy(void *__dst, const void *__src, size_t __n) +{ + return __builtin___memcpy_chk(__dst, __src, __n, __builtin_object_size((__dst), ((0) > 0) && (2 > 1))); +} + +void *memcpy(void *_Dst, const void *_Src, size_t _Size); + +char *a, *b; +void func(void) { + memcpy(a, b, 42); +} + +// CHECK-LABEL: define {{.*}} @func( +// CHECK: call ptr @memcpy.inline + +// CHECK-LABEL: declare {{.*}} @memcpy( + +// CHECK-LABEL: define {{.*}} @memcpy.inline( +// CHECK: call ptr @__memcpy_chk Index: clang/lib/AST/Decl.cpp =================================================================== --- clang/lib/AST/Decl.cpp +++ clang/lib/AST/Decl.cpp @@ -3322,7 +3322,7 @@ return false; ASTContext &Context = getASTContext(); - switch (Context.GetGVALinkageForFunction(this)) { + switch (Context.GetGVALinkageForFunction(Definition)) { case GVA_Internal: case GVA_DiscardableODR: case GVA_StrongODR:
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits