progs: added remaining benchmarks and offset correction for timer
[calu.git] / progs / sum.s
diff --git a/progs/sum.s b/progs/sum.s
new file mode 100644 (file)
index 0000000..d762c60
--- /dev/null
@@ -0,0 +1,92 @@
+#include "dt_inc.s"
+.data
+.org 0x0
+arr:
+       .fill 2
+       .fill 3
+       .fill 5
+       .fill 7
+       .fill 11
+       .fill 13
+       .fill 17
+       .fill 19
+       .fill 23
+       .fill 29
+       .fill 31
+       .fill 37
+       .fill 41
+       .fill 43
+       .fill 47
+       .fill 53
+str:
+       .ascii "hier das ergebnis: "
+.text
+.org 0x0
+start:
+       br+ main
+       br+ main
+       ret
+main:
+       call+ u_init
+       call+ u_recv_byte
+       call u_send_newline
+
+       ; benchprolog
+       call t_init
+       call t_stop
+       ldis r1, 0
+       call t_valset
+       call t_start
+       ; /benchprolog
+
+       ; sum start
+       ldis r1, 16
+       ldis r2, arr@lo
+       ldih r2, arr@hi
+       call+ sum
+       ; sum ende
+
+       ; benchepilog
+       push r0
+       call+ t_init
+       call+ t_stop
+       call+ t_valget
+       subi r0, r0, 0xc ; offset abziehen
+       pop r3
+       push r0
+       push r3
+       ; /benchepilog
+
+       call u_init ; weil r10 ueberschrieben wird
+       ldis r1, str@lo
+       ldih r1, str@hi
+       ldis r2, 19
+       call u_send_string
+
+       pop r1
+       call+ u_send_uint
+       call u_send_newline
+       pop r1
+       call+ u_send_uint
+       call u_send_newline
+
+       br+ main
+
+sum:
+       ;r1 = len
+       ;r2 = arr
+       ;r3 = i
+       ;r0 = sum
+       ;r4 arr data
+       ldis r0, 0
+       addi r3, r1, 0
+       retzs- ; check len != 0
+loop:
+       ;load arr data
+       ldw r4, 0(r2)
+       ;sum += arr[i];
+       add r0, r0, r4
+       addi r2, r2, 4
+       subi r3, r3, 1
+       brnz+ loop
+       ret