]> granicus.if.org Git - clang/commitdiff
make this more interesting, test the static const array.
authorChris Lattner <sabre@nondot.org>
Thu, 29 Oct 2009 01:20:34 +0000 (01:20 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 29 Oct 2009 01:20:34 +0000 (01:20 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@85464 91177308-0d34-0410-b5e6-96231b3b80d8

test/CodeGen/indirect-goto.c

index b9a60195387711a8ff8d02badf88f0a740736379..4d5923d5679cb3b67b615d25f729ee51e1702ab9 100644 (file)
@@ -1,9 +1,7 @@
-// RUN: clang-cc -triple i386-unknown-unknown -emit-llvm-bc -o - %s | opt -std-compile-opts | llvm-dis > %t &&
-// RUN: grep "ret i32" %t | count 1 &&
-// RUN: grep "ret i32 210" %t | count 1
+// RUN: clang-cc -triple i386-unknown-unknown -emit-llvm-bc -o - %s | opt -std-compile-opts -S | grep "ret i32 2520"
 
 static int foo(unsigned i) {
-  const void *addrs[] = { &&L1, &&L2, &&L3, &&L4, &&L5 };
+  void *addrs[] = { &&L1, &&L2, &&L3, &&L4, &&L5 };
   int res = 1;
 
   goto *addrs[i];
@@ -15,6 +13,19 @@ static int foo(unsigned i) {
   return res;
 }
 
+static int foo2(unsigned i) {
+  static const void *addrs[] = { &&L1, &&L2, &&L3, &&L4, &&L5 };
+  int res = 1;
+  
+  goto *addrs[i];
+L5: res *= 11;
+L4: res *= 7;
+L3: res *= 5;
+L2: res *= 3;
+L1: res *= 2; 
+  return res;
+}
+
 int bar() {
-  return foo(3);
+  return foo(3)+foo2(4);
 }