+#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