sum.ssa 608 B

1234567891011121314151617181920212223242526272829303132
  1. # Simple test for addressing modes.
  2. export
  3. function w $sum(l %arr, w %num) {
  4. @start
  5. @loop
  6. %n1 =w phi @start %num, @loop1 %n2
  7. %s0 =w phi @start 0, @loop1 %s1
  8. %n2 =w sub %n1, 1
  9. %c =w cslew %n1, 0
  10. jnz %c, @end, @loop1
  11. @loop1
  12. %idx0 =l extsw %n2
  13. %idx1 =l mul 4, %idx0
  14. %idx2 =l add %idx1, %arr
  15. %w =w loadw %idx2
  16. %s1 =w add %w, %s0
  17. jmp @loop
  18. @end
  19. ret %s0
  20. }
  21. # >>> driver
  22. # extern int sum(int *, int);
  23. # int arr[] = { 1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21 };
  24. # #define N sizeof arr / sizeof arr[0]
  25. # int main() {
  26. # int i, s;
  27. # for (s=i=0; i<N; i++) s+=arr[i];
  28. # return !(sum(arr, N) == s);
  29. # }
  30. # <<<