1 %FmtString1 = constant [ubyte] c"fib = \00"
2 %FmtString2 = constant [ubyte] c"\0A\00"
4 declare int "atoi"(sbyte *)
5 declare void "printInt"(int)
6 declare void "printString"([ubyte]*)
12 setlt ulong %n, 2 ; {bool}:0
13 br bool %0, label %BaseCase, label %RecurseCase
21 %f2 = call ulong(ulong) * %fib(ulong %n2)
22 %f1 = call ulong(ulong) * %fib(ulong %n1)
23 %result = add ulong %f2, %f1
27 ulong "realmain"(int %argc, sbyte ** %argv)
29 seteq int %argc, 2 ; {bool}:0
30 br bool %0, label %HasArg, label %Continue
37 %n = phi int [%n1, %HasArg], [1, %0]
38 %N = cast int %n to ulong
39 %F = call ulong(ulong) *%fib(ulong %N)
45 %Result = call ulong %fib(ulong 10)
46 %Result = cast ulong %Result to int
47 call void %printString([ubyte]* %FmtString1)
48 call void %printInt(int %Result)
49 call void %printString([ubyte]* %FmtString2)