deepjit_reg: args bei sub vertauscht (loest das problem aber ned)
[calu.git] / progs / dt_inc.s
index 39b8c31923fd901765a411d721951faf74683d63..d680464490e414bc3f52f77425306556bd034287 100644 (file)
@@ -1,7 +1,6 @@
 .data
 
-; TODO
-.org 0x300
+.org 0xA00
 int2hex:
        ;3210
        .fill 0x33323130 
@@ -12,8 +11,7 @@ int2hex:
        ;fedc
        .fill 0x66656463
 .text
-; TODO
-.org 0x300
+.org 0x400
        .define UART_BASE, 0x2000
        .define UART_STATUS, 0x0
        .define UART_RECV, 0xc
@@ -22,6 +20,21 @@ int2hex:
        .define UART_TRANS_EMPTY, 0x1
        .define UART_RECV_NEW, 0x2
 
+       .define PBASE, 0x2030
+       .define PADDR, 0x4
+       .define PDATA, 0x8
+
+       .define SSEG_BASE, 0x2010
+
+       .define INT_BASE, 0x2020
+       .define INT_CONF, 0x04
+       .define INT_GLOBAL_BIT, 0x01
+       .define INT_UART_REC_BIT, 0x02
+
+       .define TIMER_BASE, 0x2040
+       .define TIMER_STCFG, 0x0
+       .define TIMER_VAL, 0x4
+
 u_recv_byte:
        ldw r3, UART_STATUS(r10)
        andx r3, UART_RECV_NEW
@@ -40,15 +53,12 @@ u_send_byte:
 u_send_uint:
        addi r8, r1, 0
        ;usb_sendbuffersafe ("0x", 2);
-       xor r1, r1, r1
        ldi r1, 0x30
        call u_send_byte
-       xor r1, r1, r1
        ldi r1, 0x78
        call u_send_byte
        ;j = 0
        xor r7, r7, r7
-       xor r6, r6, r6
        ldi r6, int2hex@lo
        ldih r6, int2hex@hi
 u_send_uint_loop:
@@ -80,7 +90,6 @@ u_send_string_int:
        br u_send_string_int
 
 u_send_newline:
-       xor r1, r1, r1
        ldi r1, 0x0a
        call u_send_byte
        ldi r1, 0x0d
@@ -88,7 +97,37 @@ u_send_newline:
        ret
 
 u_init:
-       xor r10, r10, r10
        ldi r10, UART_BASE@lo
        ldih r10, UART_BASE@hi
        ret
+
+sseg_displ:
+       ldi r2, SSEG_BASE
+       stw r1, 0(r2)
+       ret
+
+t_init:
+       ldis r11, TIMER_BASE@lo
+       ldih r11, TIMER_BASE@hi
+       ret
+
+t_start:
+       ldis r1, 0x1
+       stw r1, TIMER_STCFG(r11)
+       ret
+
+t_stop:
+       ldis r1, 0x0
+       stw r1, TIMER_STCFG(r11)
+       ret
+
+t_valget:
+       ldw r0, TIMER_VAL(r11)
+       ret
+
+t_valset:
+       stw r1, TIMER_VAL(r11)
+       ret
+
+;for deepjit: start for programarea
+prog_start: