diff options
Diffstat (limited to 'gcc-4.4.3/gcc/testsuite/gcc.dg/mversn2.c')
-rw-r--r-- | gcc-4.4.3/gcc/testsuite/gcc.dg/mversn2.c | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/gcc-4.4.3/gcc/testsuite/gcc.dg/mversn2.c b/gcc-4.4.3/gcc/testsuite/gcc.dg/mversn2.c new file mode 100644 index 000000000..7cfb0718b --- /dev/null +++ b/gcc-4.4.3/gcc/testsuite/gcc.dg/mversn2.c @@ -0,0 +1,47 @@ +/* This checks if cloning works correctly. Since dispatch and fn1 are hot, they + should be cloned. main should not be cloned.*/ + +/* { dg-do run } */ +/* { dg-options "-O2 -fclone-hot-version-paths -fdump-tree-final_cleanup" } */ + +int __attribute__ ((version_selector)) +featureTest () +{ + return 1; +} + +int __attribute__ ((cold)) +foo () +{ + return 0; +} + +int __attribute__ ((cold)) +bar () +{ + return 1; +} + +int __attribute__ ((hot)) +dispatch () +{ + return __builtin_dispatch (featureTest, (void *)foo, (void *) bar); +} +int __attribute__ ((hot)) +fn1 () +{ + return dispatch (); +} + +int __attribute__ ((cold)) +main () +{ + return fn1 (); +} + +/* { dg-final { scan-tree-dump "fn1_clone_1" "final_cleanup" } } */ +/* { dg-final { scan-tree-dump "dispatch_clone_0" "final_cleanup" } } */ +/* { dg-final { scan-tree-dump "dispatch_clone_1" "final_cleanup" } } */ +/* { dg-final { scan-tree-dump-not "main_clone_0" "final_cleanup" } } */ +/* { dg-final { scan-tree-dump-not "main_clone_1" "final_cleanup" } } */ +/* { dg-final { cleanup-tree-dump "final_cleanup" } } */ |