2004-11-07 14:08:43 +08:00
|
|
|
; RUN: llvm-as %s -o - | llvm-dis > %t1.ll
|
|
|
|
; RUN: llvm-as %t1.ll -o - | llvm-dis > %t2.ll
|
|
|
|
; RUN: diff %t1.ll %t2.ll
|
|
|
|
|
2001-10-29 05:16:34 +08:00
|
|
|
implementation
|
|
|
|
|
|
|
|
declare int "atoi"(sbyte *)
|
|
|
|
|
|
|
|
ulong "fib"(ulong %n)
|
|
|
|
begin
|
|
|
|
setlt ulong %n, 2 ; {bool}:0
|
|
|
|
br bool %0, label %BaseCase, label %RecurseCase
|
|
|
|
|
|
|
|
BaseCase:
|
|
|
|
ret ulong 1
|
|
|
|
|
|
|
|
RecurseCase:
|
|
|
|
%n2 = sub ulong %n, 2
|
|
|
|
%n1 = sub ulong %n, 1
|
|
|
|
%f2 = call ulong(ulong) * %fib(ulong %n2)
|
|
|
|
%f1 = call ulong(ulong) * %fib(ulong %n1)
|
|
|
|
%result = add ulong %f2, %f1
|
|
|
|
ret ulong %result
|
|
|
|
end
|
|
|
|
|
|
|
|
ulong "realmain"(int %argc, sbyte ** %argv)
|
|
|
|
begin
|
|
|
|
seteq int %argc, 2 ; {bool}:0
|
|
|
|
br bool %0, label %HasArg, label %Continue
|
|
|
|
HasArg:
|
|
|
|
; %n1 = atoi(argv[1])
|
|
|
|
%n1 = add int 1, 1
|
|
|
|
br label %Continue
|
|
|
|
|
|
|
|
Continue:
|
|
|
|
%n = phi int [%n1, %HasArg], [1, %0]
|
|
|
|
%N = cast int %n to ulong
|
|
|
|
%F = call ulong(ulong) *%fib(ulong %N)
|
|
|
|
ret ulong %F
|
|
|
|
end
|
|
|
|
|
|
|
|
ulong "trampoline"(ulong %n, ulong(ulong)* %fibfunc)
|
|
|
|
begin
|
|
|
|
%F = call ulong(ulong) *%fibfunc(ulong %n)
|
|
|
|
ret ulong %F
|
|
|
|
end
|
|
|
|
|
|
|
|
int "main"()
|
|
|
|
begin
|
|
|
|
%Result = call ulong %trampoline(ulong 10, ulong(ulong) *%fib)
|
|
|
|
%Result = cast ulong %Result to int
|
|
|
|
ret int %Result
|
|
|
|
end
|
|
|
|
|