indirectcall.ll 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. ; RUN: llvm-as < %s | llvm-dis > %t1.ll
  2. ; RUN: llvm-as %t1.ll -o - | llvm-dis > %t2.ll
  3. ; RUN: diff %t1.ll %t2.ll
  4. declare i32 @atoi(i8*)
  5. define i64 @fib(i64 %n) {
  6. icmp ult i64 %n, 2 ; <i1>:1 [#uses=1]
  7. br i1 %1, label %BaseCase, label %RecurseCase
  8. BaseCase: ; preds = %0
  9. ret i64 1
  10. RecurseCase: ; preds = %0
  11. %n2 = sub i64 %n, 2 ; <i64> [#uses=1]
  12. %n1 = sub i64 %n, 1 ; <i64> [#uses=1]
  13. %f2 = call i64 @fib( i64 %n2 ) ; <i64> [#uses=1]
  14. %f1 = call i64 @fib( i64 %n1 ) ; <i64> [#uses=1]
  15. %result = add i64 %f2, %f1 ; <i64> [#uses=1]
  16. ret i64 %result
  17. }
  18. define i64 @realmain(i32 %argc, i8** %argv) {
  19. ; <label>:0
  20. icmp eq i32 %argc, 2 ; <i1>:1 [#uses=1]
  21. br i1 %1, label %HasArg, label %Continue
  22. HasArg: ; preds = %0
  23. %n1 = add i32 1, 1 ; <i32> [#uses=1]
  24. br label %Continue
  25. Continue: ; preds = %HasArg, %0
  26. %n = phi i32 [ %n1, %HasArg ], [ 1, %0 ] ; <i32> [#uses=1]
  27. %N = sext i32 %n to i64 ; <i64> [#uses=1]
  28. %F = call i64 @fib( i64 %N ) ; <i64> [#uses=1]
  29. ret i64 %F
  30. }
  31. define i64 @trampoline(i64 %n, i64 (i64)* %fibfunc) {
  32. %F = call i64 %fibfunc( i64 %n ) ; <i64> [#uses=1]
  33. ret i64 %F
  34. }
  35. define i32 @main() {
  36. %Result = call i64 @trampoline( i64 10, i64 (i64)* @fib ) ; <i64> [#uses=1]
  37. %Result.upgrd.1 = trunc i64 %Result to i32 ; <i32> [#uses=1]
  38. ret i32 %Result.upgrd.1
  39. }