blob: 338a625188af089186532e78459ec796086fae40 [file] [log] [blame]
// RUN: %clang_cc1 -emit-llvm -triple i386-linux-gnu %s -o - | FileCheck %s
// RUN: %clang_cc1 -x c -emit-pch -o %t %s
// RUN: %clang_cc1 -include-pch %t %s -emit-llvm -o - | FileCheck %s
// TODO: for "foo" and "bar", "after" is not added as it appears "after" the first use or definition respectively. There might be a way to allow that.
// CHECK: define{{.*}} void @bar() #0
// CHECK: define{{.*}} void @baz() #1
// CHECK: declare{{.*}} void @foo() #2
// CHECK: attributes #0
// CHECK-SAME: "llvm.assume"="bar:before1,bar:before2,bar:before3,bar:def1,bar:def2"
// CHECK: attributes #1
// CHECK-SAME: "llvm.assume"="baz:before1,baz:before2,baz:before3,baz:def1,baz:def2,baz:after"
// CHECK: attributes #2
// CHECK-SAME: "llvm.assume"="foo:before1,foo:before2,foo:before3"
#ifndef HEADER
#define HEADER
/// foo: declarations only
__attribute__((assume("foo:before1"))) void foo(void);
__attribute__((assume("foo:before2")))
__attribute__((assume("foo:before3"))) void
foo(void);
/// baz: static function declarations and a definition
__attribute__((assume("baz:before1"))) static void baz(void);
__attribute__((assume("baz:before2")))
__attribute__((assume("baz:before3"))) static void
baz(void);
// Definition
__attribute__((assume("baz:def1,baz:def2"))) static void baz(void) { foo(); }
__attribute__((assume("baz:after"))) static void baz(void);
/// bar: external function declarations and a definition
__attribute__((assume("bar:before1"))) void bar(void);
__attribute__((assume("bar:before2")))
__attribute__((assume("bar:before3"))) void
bar(void);
// Definition
__attribute__((assume("bar:def1,bar:def2"))) void bar(void) { baz(); }
__attribute__((assume("bar:after"))) void bar(void);
/// back to foo
__attribute__((assume("foo:after"))) void foo(void);
#endif