\r
; External names for BIOS entry points\r
\r
- public ?boot,?wboot,?const,?conin,?cono,?list,?auxo,?auxi\r
+ public ?boot,?wboot,boot,?const,?conin,?cono,?list,?auxo,?auxi\r
public ?home,?sldsk,?sttrk,?stsec,?stdma,?read,?write\r
public ?lists,?sctrn\r
public ?conos,?auxis,?auxos,?dvtbl,?devin,?drtbl\r
dseg ; this part can be banked\r
\r
boot:\r
+ ld a,SYS$CBR\r
+ out0 (cbr),a\r
+ ld a,USR$CBAR\r
+ out0 (cbar),a\r
ld sp,bs$stack\r
\r
call hwinit ; first time hardware initialisation\r
global mmuinit
- global bnk2log,bnk2phy,hwl2phy
+ global bnk2log,bnk2phy,hwl2phy,phy2log
include config.inc
include z180reg.inc
;----------------------------------------------------------------------
-; Memory Map:
+; Memory Map 1:
;
-; Common CAStart ... 0FFFF
-; Bank 0 00000 ... CAStart-1
-; Bank 1 10000 ...
+; Common CAStart .. 0FFFF
+; Bank 0 00000 .. CAStart-1
+; Bank 1 10000 ..
; Bank 2
;
+; Memory Map 2:
+;
+; Common 18000 .. 1BFFF BANK1
+;
+; Bank 0 00000 .. 0BFFF 0
+; Bank 1 0C000 .. 17FFF 1*BNK_SIZE
+; Bank 2 1C000 .. 27FFF 2*BNK_SIZE + CMN_SIZE
+; Bank 3 28000 .. 33FFF 3*BNK_SIZE + CMN_SIZE
+; Bank n n*BNK_SIZE + (n < 2) ? 0 : CMN_SIZE
+;
;----------------------------------------------------------------------
cseg
; in a: Bank number
; out a: bbr value
+ if 0 ; Memory Map 1
+
bnk2log:
or a ;
ret z ; Bank 0 is at physical address 0
- dec a
+ dec a ;
push bc ;
- ld b,a ;
- ld c,CA ;
+ ld c,a ;
+ ld b,BNK_SIZE ;
mlt bc ; bank size * bank number
ld a,c ;
add a,10h ; add bank0 + common
pop bc ;
ret ;
+ else ; Memory Map 2
+
+bnk2log:
+ or a
+ ret z ; Bank 0 is at physical address 0
+
+ push bc
+ ld c,a ;
+ ld b,BNK_SIZE ;
+ mlt bc ; bank size * bank number
+ cp 2 ;
+ ld a,c ;
+ pop bc
+ ret c
+ add a,CMN_SIZE
+ ret
+
+ endif
+
+ if 0 ; table version
+
+ push hl
+ ld hl,bnk_table ;
+ add a,l ;
+ ld l,a ;
+ jr nc,$+3 ;
+ inc h ;
+ ld a,(hl) ;
+ pop hl
+ ret
+
+ endif
+
;--------------------------------------------------------------
;in hl: Log. Address
cp CA*16
ld a,c
pop bc
-
jr c,b2p_banked
- xor a ; address is in common
- jr b2b_cont ; base is 0
+ ; address is in common
+ if 0 ; Memory Map 1
+ ld a,0 ; base is 0
+ else ; Memory Map 2
+ ld a,1 ; same as bank1
+ endif
+
b2p_banked:
call bnk2log ; get address base
-b2b_cont:
; fall thru
;--------------------------------------------------------------
;
-; de: Log. Address
+; hl: Log. Address
;
;
-; OP: ahl = (bankbase<<12) + (d<<8) + e
+; OP: ahl = (bankbase<<12) + (h<<8) + l
;
;out ahl: Phys. (linear) Address
ret ;
+;--------------------------------------------------------------
+; return logical bank 0 address for given physical address.
+;
+; in: ahl: pyhsical addres (20 bit)
+; out hl: logical address.
+; logical address is in bank 0 or common, no bank number returned
+;
+
+phy2log:
+ or a
+ ret z
+
+ push bc
+ push hl
+ ld l,h
+ ld h,0
+ ld bc,-16*SYS$CBR
+ add hl,bc
+ ld h,l
+ pop bc
+ ld l,c
+ pop bc
+ ret
+
;--------------------------------------------------------------
; Trampoline for routines in banked ram.
; Switch stack pointer to "system" stack in top ram
; global msg.sout\r
global msg.sm,msg.recv\r
\r
- extrn bufinit,hwl2phy\r
+ extrn bufinit,hwl2phy,phy2log\r
extrn fifolst\r
\r
include config.inc\r
mkbuf 0,mtx.fifo,mtx.fifo_len\r
mkbuf 1,mrx.fifo,mrx.fifo_len\r
\r
-;txfifo_addr equ fifolst + (0*2)\r
-;rxfifo_addr equ fifolst + (1*2)\r
-\r
itx equ 0*2\r
irx equ 1*2\r
\r
jr nz,msgi_1\r
\r
ld hl,(040h)\r
-;TODO: physical to logical address translation\r
+ ld a,(040h+2)\r
+ call phy2log\r
+\r
ld a,l\r
or h\r
jr z,msgi_1\r
\r
msgi_1:\r
ld a,(043h)\r
+\r
;TODO: value should be 0\r
+\r
ld ix,mtx.fifo\r
call bufinit\r
-\r
- ld hl,fifolst\r
+ push ix\r
+ pop hl\r
call hwl2phy\r
ld (040h),hl\r
ld (040h+2),a\r