]> cloudbase.mooo.com Git - ddt180.git/blobdiff - ddt180.z80
Add reloc command: cmd_E
[ddt180.git] / ddt180.z80
index 7c457000dfc9546d07d076080b3a0c61e82ce646..7f0ff31164631e5a4c324d173912a8a4bf746816 100644 (file)
@@ -6,26 +6,6 @@
 ;   - Use Digital Research Link-80 to generate a .PRL file (op switch).\r
 ;   - Cut the .PRL header (first 256 byte) end rename the result to DDTZ.COM.\r
 \r
-;-------------------------------------------------------------------------------\r
-; Relocation loader\r
-;\r
-TPA    equ     0100h\r
-       cseg\r
-       .phase  TPA\r
-\r
-       jp      start\r
-       ds      3\r
-\r
-ldr_end:\r
-ldr_size       equ     $ - TPA\r
-current_phase  defl    $\r
-\r
-       .dephase\r
-current_cseg   defl    $\r
-\r
-;-------------------------------------------------------------------------------\r
-; DDT/Z core\r
-;\r
 \r
 ; Some greneral definitions\r
 \r
@@ -41,147 +21,176 @@ CNTRX             equ     'X'-'@'
 BDOS           equ     5\r
 TPA            equ     0100h\r
 \r
-; BDOS function calls\r
-\r
-BDOS_PSTR      equ     9       ;Print String\r
-\r
 ; ddtz specific definitions\r
 \r
 STACK_SIZE     equ     80      ;ddtz internal stack\r
 CONBUF_SIZE    equ     80      ;Size of console input buffer\r
-EXPR_BUF_SIZE  equ     128     ;expressen buffer for conditional breakpoints\r
 BP_CNT         equ     12      ;Number of breakpoints\r
 BP_SIZE                equ     4       ;Size of a breakpoint record\r
 \r
+bitmap_size    equ     (prog_size+7)/8\r
+\r
 ;-------------------------------------------------------------------------------\r
 \r
-ddtz_base:\r
-       jp ddtz_bdos\r
+       cseg\r
+start::\r
+ddtz_base::\r
+       jr reloc\r
+       nop\r
 l0003h:\r
-       rst 30h\r
-di_or_ei:\r
+       rst 30h                 ;rst used by ddtz\r
+di_or_ei:                      ;ints enabled/disabled while ddtz is running\r
        nop\r
        ret\r
-ddtz_bdos:\r
-       jp      0\r
 \r
-current_cseg   defl    $ - current_cseg\r
-       .phase  current_phase + current_cseg\r
+?const:        jp      0               ; return console input status\r
+?conin:        jp      0               ; return console input character\r
+?cono: jp      0               ; send console output character\r
+\r
+;-------------------------------------------------------------------------------\r
+\r
 signon:\r
        db      'DDTZ/180'\r
        db      ' - Version '\r
        maclib  version.inc\r
        defvers\r
-       db      CR,LF,'$'\r
-msgz80:\r
-       db      'Z80 or better required!',cr,lf,'$'\r
+       dc      '  ('\r
 \r
-current_phase  defl    $\r
-       .dephase\r
-current_cseg   defl    $\r
-       ds      STACK_SIZE - (current_phase - signon)\r
+;-------------------------------------------------------------------------------\r
+; Clear old position\r
 \r
+cmde_clr:\r
+       ld      (hl),0\r
+       inc     hl\r
+       dec     bc\r
+       ld      a,b\r
+       or      c\r
+       jr      nz,cmde_clr\r
 \r
-stack:\r
-reg.l2:        db      000h\r
-reg.h2:        db      000h\r
-reg.e2:        db      000h\r
-reg.d2:        db      000h\r
-reg.c2:        db      000h\r
-reg.b2:        db      000h\r
-reg.f2:        db      000h\r
-reg.a2:        db      000h\r
-       db      000h\r
-reg.i: db      000h\r
-reg.iy:        dw      0000h\r
-reg.ix:        dw      0000h\r
-reg.f: db      000h\r
-reg.a: db      000h\r
-reg.c: db      000h\r
-reg.b: db      000h\r
-reg.e: db      000h\r
-reg.d: db      000h\r
-reg.l: db      000h\r
-reg.h: db      000h\r
-reg_sp:        dw      TPA\r
-reg.iff:\r
-       db      0f3h\r
-       db      0c3h\r
-reg.pc:        dw      TPA\r
+; Determine current position\r
 \r
-cmd_rpt:dw     mainloop\r
+reloc:\r
+       ld      bc,(028h-2)\r
+       ld      de,(028h)\r
+       ld      a,i                     ;get iff2\r
+       ex      af,af'\r
+       di\r
+       ld      sp,028h                 ;rst instr needs a minimal stack\r
+       ld      hl,0e9e1h               ;opcpdes pop hl/jp (hl)\r
+       ld      (028h),hl\r
+       rst     028h\r
+wearehere:\r
+       ld      (028h-2),bc\r
+       ld      (028h),de\r
+       ld      de,-(wearehere-ddtz_base)\r
+       add     hl,de                   ; hl:\r
+\r
+       ld      de,ddtz_base            ; de:\r
+       or      a\r
+       sbc     hl,de\r
+       ex      de,hl                   ; de: reloc offset\r
+       ld      hl,stack\r
+       add     hl,de\r
+       ld      sp,hl\r
+       ex      af,af'\r
+       push    af\r
+       pop     bc\r
+       bit     2,c\r
+       jr      z,$+3\r
+       ei\r
+       ld      hl,ddtz_end             ;start of reloc bitmap\r
+       add     hl,de\r
+\r
+       push    hl\r
+       exx\r
+       pop     hl\r
+       ld      bc,0108h                ;init bit counter b (c==reload val)\r
+       exx\r
+\r
+       LD      HL,ddtz_base\r
+       add     hl,de                   ;--> ddtz_base\r
+       ld      bc,prog_size\r
+reloc_lp:\r
+       EXX\r
+       djnz    reloc_nl\r
+       ld      b,c                     ;reload bit counter\r
+       LD      e,(HL)                  ;get next 8 relocation bits\r
+       INC     HL\r
+reloc_nl:\r
+       sla     e\r
+       EXX\r
+       JR      NC,reloc_next\r
+       DEC     HL\r
+       LD      A,(HL)\r
+       ADD     A,E\r
+       LD      (HL),A\r
+       INC     HL\r
+       LD      A,(HL)\r
+       ADC     A,D\r
+       LD      (HL),A\r
+reloc_next:\r
+       inc     hl\r
+       dec     bc\r
+       ld      a,b\r
+       or      c\r
+       jr      nz,reloc_lp\r
 \r
 ;-------------------------------------------------------------------------------\r
 \r
-conbuf:\r
-       db      CONBUF_SIZE\r
 \r
-       ld sp,stack\r
-       exx\r
-       ld de,ddtz_base\r
-       call cp_hl_de\r
-       jr c,l0079h\r
-       ex de,hl\r
-l0079h:\r
-       ld de,TPA\r
-l007ch:\r
-       dec hl\r
-       ld (hl),000h\r
-       ld a,h\r
-       sub d\r
-       ld b,a\r
-       ld a,l\r
-       sub e\r
-       or b\r
-       jr nz,l007ch\r
-       ld a,i\r
-       ld (reg.i),a\r
-       ld a,0f3h\r
-       jp po,l0093h\r
-       ld a,0fbh\r
-l0093h:\r
-       ld (reg.iff),a\r
-       call di_or_ei\r
-       ld hl,ddtz_base\r
-       ld l,000h\r
-       ld (reg_sp),hl\r
+init::\r
+       LD      SP,stack\r
 \r
-       ld hl,(1)               ;wboot addr\r
-       ld de,?const\r
-       ld b,6\r
-vini_l:\r
-       inc     hl\r
-       inc     hl\r
-       inc     hl\r
+       ld      hl,(1)          ;wboot addr\r
+       ld      de,?const\r
        ex      de,hl\r
+       ld      b,3\r
+vini_l:\r
+       inc     de\r
+       inc     de\r
+       inc     de\r
        inc     hl\r
        ld      (hl),e\r
        inc     hl\r
        ld      (hl),d\r
        inc     hl\r
-       ex      de,hl\r
        djnz    vini_l\r
 \r
-       jr mainloop\r
+       ld      hl,signon\r
+       call    pstr\r
+       ld      hl,ddtz_base\r
+       call    out_hl\r
+       call    pstr_inl\r
+       dc      ' - '\r
+       ld      de,prog_size+bitmap_size-1\r
+       add     hl,de\r
+       call    out_hl\r
+       call    pstr_inl\r
+       dc      ')',CR,LF\r
+\r
+       ld      a,i\r
+       ld      (reg.i),a\r
+       ld      a,0f3h\r
+       jp      po,l0093h\r
+       ld      a,0fbh\r
+l0093h:\r
+       ld      (reg.iff),a\r
+       call    di_or_ei\r
+       ld      hl,ddtz_base\r
+       ld      l,000h\r
+       ld      (reg_sp),hl\r
 \r
-       ds      CONBUF_SIZE + 3 - ($ - conbuf)\r
+       jp      mainloop\r
 \r
 ;-------------------------------------------------------------------------------\r
 \r
-?const:        jp      0               ; return console input status\r
-?conin:        jp      0               ; return console input character\r
-?cono: jp      0               ; send console output character\r
-?list: jp      0               ; send list output character\r
-?auxo: jp      0               ; send auxiliary output character\r
-?auxi: jp      0               ; return auxiliary input character\r
-\r
-CMDTAB:\r
-       dw      ERROR ;cmd_@    ;examine/substitute the displacement register @\r
-       dw      ERROR ;cmd_A    ;Assemble\r
+CMDTAB::\r
+;      dw      ERROR ;cmd_@    ;examine/substitute the displacement register @\r
+;      dw      ERROR ;cmd_A    ;Assemble\r
        dw      cmd_B           ;Breakpoints display/set/clear\r
        dw      ERROR ;cmd_C    ;trace over Calls\r
        dw      cmd_D           ;Display memory in hex and ascii\r
-       dw      ERROR           ;\r
+       dw      cmd_E           ;rElocate debugger\r
        dw      ERROR ;cmd_F    ;specify Filename and command line\r
        dw      cmd_G           ;Go\r
        dw      cmd_H           ;compute Hex and other expressions\r
@@ -208,7 +217,7 @@ ERROR:
        call    pstr_inl\r
        dc      '?',CR,LF\r
        ;fall thru\r
-mainloop:\r
+mainloop::\r
        ld sp,stack\r
        ld hl,(reg.pc)\r
        call bp_clr_temporary\r
@@ -227,7 +236,7 @@ mainloop:
        push hl\r
        ld (cmd_rpt),hl\r
        inc de\r
-       sub '@'\r
+       sub 'B'\r
        jr c,ERROR\r
        cp 'Z'+1-'@'\r
        jr nc,ERROR\r
@@ -255,8 +264,7 @@ crlf:
 sub_01d9h:\r
        call    pstr_inl\r
        dc      '-'\r
-       dec hl\r
-       jp cpl.hl\r
+       jp neg.hl\r
 \r
 out_hl_dec_neg:\r
        push hl\r
@@ -323,9 +331,8 @@ out.bin.b:
 l01c9h:\r
        rlca\r
        push    af\r
-       ld      a,'0'/2\r
-       adc     a,a\r
-       call    outchar\r
+       and     1\r
+       call    out_dgt\r
        pop af\r
        djnz l01c9h\r
        ld a,'"'\r
@@ -430,7 +437,6 @@ DELC:
        call    DELC1\r
        dec     hl\r
        dec     b\r
-       inc     c\r
        ld      a,(hl)\r
        cp      ' '\r
        ret     nc\r
@@ -451,13 +457,10 @@ DELL:
 get_line:\r
        push hl                 ;\r
        ld hl,conbuf            ;\r
-       ld c,(hl)               ;\r
-       inc hl                  ;\r
-       ld b,000h               ;\r
-       inc hl                  ;\r
+       ld b,0                  ;\r
 inlnxtch:\r
-       ld a,c                  ;\r
-       or a                    ;\r
+       ld a,b                  ;\r
+       cp CONBUF_SIZE          ;\r
        jr z,inl_e              ;\r
        call incharw            ;\r
        cp CR                   ;\r
@@ -493,16 +496,12 @@ gl_5:
        call outchar            ;\r
        inc hl                  ;\r
        inc b                   ;\r
-       dec c                   ;\r
        jr inlnxtch             ;\r
 \r
 inl_e:\r
        ld (hl),0\r
-       ld hl,conbuf+1          ;\r
-       ld (hl),b               ;\r
        call CRLF               ;\r
-       inc     hl\r
-       ex      de,hl\r
+       ld de,conbuf            ;\r
        pop hl                  ;\r
        ret                     ;\r
 \r
@@ -657,12 +656,12 @@ l0348h:
        ret m\r
        jr l0348h\r
 \r
-sub_034eh:\r
+get_arg_range_target:\r
        call get_arg_range\r
        push hl\r
        push bc\r
        call next_arg\r
-       call sub_0363h\r
+       call get_arg_final\r
        ex de,hl\r
        pop bc\r
        pop hl\r
@@ -673,7 +672,7 @@ sub_035dh:
        jr c,error0\r
        ret\r
 \r
-sub_0363h:\r
+get_arg_final:\r
        call sub_035dh\r
 l0366h:\r
        jp assert_eol\r
@@ -937,6 +936,9 @@ do_factor:
        ld hl,TPA\r
        cp 'L'\r
        ret z\r
+       ld hl,(reg.pc)\r
+       cp '$'\r
+       ret z\r
        cp '-'\r
        jr z,fact_factneg\r
        cp '~'\r
@@ -995,8 +997,13 @@ fact_reg.CPU:
        ld h,000h\r
        ret\r
 \r
+fact_factinv:\r
+       call fact_factor\r
+       jr cpl.hl\r
+\r
 fact_factneg:\r
        call fact_factor\r
+neg.hl:\r
        dec hl\r
 cpl.hl:\r
        ld a,h\r
@@ -1007,10 +1014,6 @@ cpl.hl:
        ld l,a\r
        ret\r
 \r
-fact_factinv:\r
-       call fact_factor\r
-       jr cpl.hl\r
-\r
 fact_mem:\r
        call expr1\r
        jr c,error1\r
@@ -1288,6 +1291,49 @@ b_0709_start:
        db      000h\r
        db      000h\r
 \r
+;-------------------------------------------------------------------------------\r
+; > E addr\r
+;      relocate debugger to addr\r
+; > ER addr\r
+;      relocate just below addr\r
+;\r
+; Move debugger to given address and restart.\r
+; New location must not overlap with current location.\r
+\r
+\r
+cmd_E:\r
+       call    skipbl\r
+       sub     'R'\r
+       jr      nz,$+3\r
+        inc    de\r
+       push    af\r
+       call    get_arg_final\r
+\r
+       ld      bc,prog_size+bitmap_size\r
+       pop     af\r
+       jr      nz,cmde_bottom\r
+       sbc     hl,bc\r
+cmde_bottom:\r
+       ld      ix,cmde_clr-ddtz_base\r
+       ex      de,hl                   ;de = dst\r
+       add     ix,de\r
+       ld      hl,ddtz_base            ;hl = src\r
+\r
+       push    hl\r
+       or      a\r
+       sbc     hl,de\r
+       call    c,neg.hl                ;abs(distance)\r
+       or      a\r
+       sbc     hl,bc\r
+       jp      c,error\r
+       pop     hl\r
+       push    hl\r
+       push    bc\r
+       ldir\r
+       pop     bc\r
+       pop     hl\r
+       jp      (ix)\r
+\r
 ;-------------------------------------------------------------------------------\r
 ; > G [startaddr] [;breakp..]\r
 ;      Go [to start] [with temporary breakpoints]\r
@@ -1677,7 +1723,7 @@ cmd_X:
        call get_line\r
        call skipbl\r
        jr z,l0c30h\r
-       call sub_0363h\r
+       call get_arg_final\r
        ex de,hl\r
        pop bc\r
        pop hl\r
@@ -1949,11 +1995,11 @@ cmd_O:
        ret\r
 \r
 ;-------------------------------------------------------------------------------\r
-; > Vstartaddr endaddr targetaddr\r
+; > V startaddr endaddr targetaddr\r
 ;      Verify (compare) two memory areas\r
 \r
 cmd_V:\r
-       call sub_034eh\r
+       call get_arg_range_target\r
 l0dedh:\r
        push bc\r
        ld a,(de)\r
@@ -1985,7 +2031,7 @@ l0e10h:
 ;      Move memory\r
 \r
 cmd_M:\r
-       call sub_034eh\r
+       call get_arg_range_target\r
        call cp_hl_de\r
        jr nc,cmdm_up\r
        add hl,bc\r
@@ -1995,7 +2041,7 @@ cmd_M:
        dec hl\r
        dec de\r
        lddr\r
-       db 01h          ;swallow ldir instruction (ld bc,...)\r
+       ret\r
 cmdm_up:\r
        ldir\r
        ret\r
@@ -2094,9 +2140,9 @@ l0ed3h:
        ret\r
 \r
 sub_0ee6h:\r
-       ld hl,conbuf+1\r
+       ld hl,conbuf\r
        call sub_0ef7h\r
-       ld de,conbuf+1\r
+       ld de,conbuf\r
        and a\r
        sbc hl,de\r
        ld b,l\r
@@ -3645,91 +3691,6 @@ bp_tab:
         endm\r
        endm\r
 \r
-expr_buf:\r
-current_cseg   defl    $ - current_cseg\r
-       .phase  current_phase + current_cseg\r
-\r
-start:\r
-       LD      SP,ldr_end+(stack-ddtz_base)\r
-       LD      DE,signon               ;ldr_end+(expr_buf-ddtz_base)\r
-       LD      C,BDOS_PSTR\r
-       CALL    BDOS\r
-\r
-       xor     a\r
-       dec     a\r
-       jp      po,reloc\r
-       ld      de,msgz80\r
-       LD      C,BDOS_PSTR\r
-       CALL    BDOS\r
-       jp      0\r
-\r
-reloc:\r
-       LD      HL,ldr_end+ddtz_size    ;start of reloc bitmap\r
-       ld      bc,0108h                ;init bit counter\r
-\r
-       EXX\r
-       LD      HL,(BDOS+1)\r
-       LD      (ldr_end+(ddtz_bdos+1-ddtz_base)),HL\r
-       LD      BC,ddtz_size-1\r
-       LD      D,B\r
-       LD      E,0FFH\r
-       INC     DE                      ;size rounded up to next page boundary\r
-       INC     BC                      ;ddtz_size\r
-       OR      A\r
-       SBC     HL,DE                   ;BDOS - size\r
-       LD      (BDOS+1),HL             ;-> new BDOS entry\r
-\r
-       push    hl\r
-       PUSH    BC\r
-       ld      de,ldr_end\r
-       sbc     hl,de\r
-       EX      DE,HL                   ;-> DE\r
-       LD      HL,ldr_size\r
-       add     hl,bc\r
-       ld      b,h\r
-       ld      c,l\r
-       LD      HL,TPA\r
-reloc_lp:\r
-       EXX\r
-       djnz    reloc_nl\r
-       ld      b,c                     ;reload bit counter\r
-       LD      e,(HL)                  ;get next 8 relocation bits\r
-       INC     HL\r
-reloc_nl:\r
-       sla     e\r
-       EXX\r
-       JR      NC,reloc_next\r
-       DEC     HL\r
-       LD      A,(HL)\r
-       ADD     A,E\r
-       LD      (HL),A\r
-       INC     HL\r
-       LD      A,(HL)\r
-       ADC     A,D\r
-       LD      (HL),A\r
-reloc_next:\r
-       cpi\r
-       jp      pe,reloc_lp\r
-       dec     hl\r
-\r
-       POP     BC\r
-       pop     de\r
-       EX      DE,HL\r
-       ADD     HL,BC\r
-       EX      DE,HL\r
-       DEC     DE\r
-       LDDR\r
-       LD      HL,conbuf+2-ddtz_base\r
-       ADD     HL,DE\r
-       JP      (HL)\r
-\r
-current_phase  defl    $\r
-       .dephase\r
-current_cseg   defl    $\r
-\r
-       ds      EXPR_BUF_SIZE - ($ - expr_buf)\r
-expr_bufe:\r
-\r
 ;-------------------------------------------------------------------------------\r
 \r
 last_S:\r
@@ -3757,10 +3718,52 @@ last_L:
        dw      TPA\r
 \r
 pbl_loop_adr:\r
-       dw      0\r
+       dw      0addeh\r
+\r
+;-------------------------------------------------------------------------------\r
+\r
+conbuf::\r
+       ds      CONBUF_SIZE+1\r
+\r
+;-------------------------------------------------------------------------------\r
+\r
+       rept    (STACK_SIZE+3)/4\r
+       db      0deh,0adh,0beh,0efh\r
+       endm\r
+stack::\r
+reg.l2:        db      000h\r
+reg.h2:        db      000h\r
+reg.e2:        db      000h\r
+reg.d2:        db      000h\r
+reg.c2:        db      000h\r
+reg.b2:        db      000h\r
+reg.f2:        db      000h\r
+reg.a2:        db      000h\r
+       db      000h\r
+reg.i: db      000h\r
+reg.iy:        dw      0000h\r
+reg.ix:        dw      0000h\r
+reg.f: db      000h\r
+reg.a: db      000h\r
+reg.c: db      000h\r
+reg.b: db      000h\r
+reg.e: db      000h\r
+reg.d: db      000h\r
+reg.l: db      000h\r
+reg.h: db      000h\r
+reg_sp:        dw      TPA\r
+reg.iff:\r
+       db      0f3h\r
+       db      0c3h\r
+reg.pc:        dw      TPA\r
+\r
+cmd_rpt:dw     mainloop\r
+\r
+;-------------------------------------------------------------------------------\r
 \r
 ddtz_size      equ     $-ddtz_base\r
-ddtz_end:\r
+prog_size      equ     $-start\r
+ddtz_end::\r
 \r
 ;-------------------------------------------------------------------------------\r
 \r