blob: db0bca5d142794457a656be28c57f47d6b305d67 [file] [log] [blame]
Chris Lattner00950542001-06-06 20:29:01 +00001implementation
2
Chris Lattner98af6692001-09-01 01:47:52 +00003declare int "atoi"(sbyte *)
4
Chris Lattner00950542001-06-06 20:29:01 +00005ulong "fib"(ulong %n)
6begin
7 setlt ulong %n, 2 ; {bool}:0
8 br bool %0, label %BaseCase, label %RecurseCase
9
10BaseCase:
11 ret ulong 1
12
13RecurseCase:
14 %n2 = sub ulong %n, 2
15 %n1 = sub ulong %n, 1
Chris Lattnerda257162001-10-03 14:50:12 +000016 %f2 = call ulong(ulong) * %fib(ulong %n2)
17 %f1 = call ulong(ulong) * %fib(ulong %n1)
Chris Lattner00950542001-06-06 20:29:01 +000018 %result = add ulong %f2, %f1
19 ret ulong %result
20end
21
22ulong "main"(int %argc, sbyte ** %argv)
Chris Lattner00950542001-06-06 20:29:01 +000023begin
24 seteq int %argc, 2 ; {bool}:0
25 br bool %0, label %HasArg, label %Continue
26HasArg:
27 ; %n1 = atoi(argv[1])
Chris Lattner98af6692001-09-01 01:47:52 +000028 %n1 = add int 1, 1
Chris Lattner00950542001-06-06 20:29:01 +000029 br label %Continue
30
31Continue:
Chris Lattner98af6692001-09-01 01:47:52 +000032 %n = phi int [%n1, %HasArg], [1, %0]
33 %N = cast int %n to ulong
Chris Lattnerda257162001-10-03 14:50:12 +000034 %F = call ulong(ulong) *%fib(ulong %N)
Chris Lattner00950542001-06-06 20:29:01 +000035 ret ulong %F
36end