Skip to content

Commit

Permalink
Merge pull request #109 from Konamiman/v2.1.1
Browse files Browse the repository at this point in the history
  • Loading branch information
Konamiman authored Aug 31, 2022
2 parents 413810c + fafa398 commit 05fdcef
Show file tree
Hide file tree
Showing 13 changed files with 261 additions and 194 deletions.
Binary file removed docs/img/gsg/Partitions2And4Active.PNG
Binary file not shown.
49 changes: 47 additions & 2 deletions source/kernel/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
# See the "all" main rule for some handy aliases to generate specific ROMs
# (e.g. you can run "make base" or "make ide").

VERSION := 2.1.1-beta2
VERSION := 2.1.1

export X80_COMMAND_LINE=-t -nb
export M80_COMMAND_LINE=-8
Expand All @@ -31,7 +31,7 @@ endef
### MAIN RULE ###
###################

all: base ide ide-emu ascii8 ascii16 mfrsd flashjacks ocm
all: base ide ide-masteronly ide-emu ide-masteronly-emu ascii8 ascii16 mfrsd flashjacks ocm

TOOLS := M80 L80 LIB80 objcopy sdcc mknexrom dd

Expand Down Expand Up @@ -74,6 +74,26 @@ drivers/SunriseIDE/sunride.BIN: \
sjasm -c drivers/SunriseIDE/sunride.asm drivers/SunriseIDE/sunride.BIN


### Sunrise IDE, normal ROM, master device only

ide-masteronly: drivers/SunriseIDE/Nextor-$(VERSION).SunriseIDE.MasterOnly.ROM

drivers/SunriseIDE/Nextor-$(VERSION).SunriseIDE.MasterOnly.ROM: \
nextor_base.dat \
drivers/SunriseIDE/sunride.masteronly.BIN \
drivers/SunriseIDE/CHGBNK.BIN

mknexrom nextor_base.dat $@ /d:drivers/SunriseIDE/sunride.masteronly.BIN /m:drivers/SunriseIDE/CHGBNK.BIN
$(call copy_to_bin,$@)

drivers/SunriseIDE/sunride.masteronly.BIN: \
drivers/SunriseIDE/sunride.asm

sed 's/MASTER_ONLY equ 0/MASTER_ONLY equ 1/g' drivers/SunriseIDE/sunride.asm > drivers/SunriseIDE/sunride.masteronly.asm

sjasm -c drivers/SunriseIDE/sunride.masteronly.asm drivers/SunriseIDE/sunride.masteronly.BIN


### Sunrise IDE, ROM for emulators

ide-emu: drivers/SunriseIDE/Nextor-$(VERSION).SunriseIDE.emulators.ROM
Expand All @@ -96,6 +116,30 @@ drivers/SunriseIDE/DRIVER.BIN: \
$(call hex2bin,$(patsubst %.BIN,%,$@))


### Sunrise IDE, ROM for emulators, master device only

ide-masteronly-emu: drivers/SunriseIDE/Nextor-$(VERSION).SunriseIDE.MasterOnly.emulators.ROM

drivers/SunriseIDE/Nextor-$(VERSION).SunriseIDE.MasterOnly.emulators.ROM: \
nextor_base.dat \
drivers/SunriseIDE/DRVMONLY.BIN \
drivers/SunriseIDE/CHGBNK.BIN \
256.bytes

cat 256.bytes drivers/SunriseIDE/DRVMONLY.BIN > drivers/SunriseIDE/_driver.BIN
mknexrom nextor_base.dat $@ /d:drivers/SunriseIDE/_driver.BIN /m:drivers/SunriseIDE/CHGBNK.BIN
$(call copy_to_bin,$@)

drivers/SunriseIDE/DRVMONLY.BIN: \
drivers/SunriseIDE/driver.mac

sed 's/MASTER_ONLY equ 0/MASTER_ONLY equ 1/g' drivers/SunriseIDE/driver.mac > drivers/SunriseIDE/drvmonly.mac

M80 -w drivers/SunriseIDE -p ../.. =DRVMONLY
L80 -w drivers/SunriseIDE -p ../../ /P:4100,DRVMONLY,DRVMONLY/N/X/Y/E
$(call hex2bin,$(patsubst %.BIN,%,$@))


### Sunrise IDE, common rules

drivers/SunriseIDE/CHGBNK.BIN: \
Expand Down Expand Up @@ -463,6 +507,7 @@ bank6/B6.HEX: \
bank5/fdisk.dat bank5/fdisk2.dat: \
bank5/fdisk_crt0.rel \
bank5/fdisk.h \
bank5/fdisk.c \
$(patsubst %.dat,%.c,$@) \
bank5/drivercall.h \
bank5/drivercall.c \
Expand Down
179 changes: 68 additions & 111 deletions source/kernel/bank0/init.mac
Original file line number Diff line number Diff line change
Expand Up @@ -1041,7 +1041,7 @@ OVERRIDE:
SLAVE:
ld a,(KER250##+3)
or a
ret nz ;Return if four 2.50 kernels initialized already
ret nz ;Return if four Nextor kernels initialized already

call VALTBL ;get number of drives declared so far
ret z ;no room is left
Expand Down Expand Up @@ -1480,42 +1480,10 @@ endif
ld hl,(HIMEM##) ;save HIMEM
ld (HIMSAV##),hl ;
;
ld hl,H.TIMI ;Save the current setting of
push hl ; the timer interrupt hook
ld de,TIMI_SAVE## ; in our data area.
ld bc,5
ldir
;===== start add DOS2.50 (support MegaSCSI)
ld hl,_TIME_IRQ##
ld de,@TIME_IRQ##
call MYHOOK
;===== end add DOS2.50
pop hl ;Now set up an inter-slot call

;This "patch for MegaSCSI" was causing the kanji mode to not work
;(CALL KANJI hanging the computer)
;since the Kanji ROM timer interrupt routine assumes that the
;previous hook is either a RET or a RST 30h (not a CALL!)
if 0
;===== start mod DOS2.50 (support MegaSCSI)
ld de,_TIME_IRQ## ; to our timer interrupt
ld (hl),0;NOP ; routine in this ROM page.
inc hl
ld (hl),0CDh;CALL
inc hl
ld (hl),e
inc hl
ld (hl),d
inc hl
ld (hl),0C9h;RET
else
ld hl,TIMI_SAVE##
ld de,@TIME_IRQ##
call MYHOOK
endif
call SAVE_AND_PATCH_HTIMI

;; ld de,@TIME_IRQ##
;; call MYHOOK
;===== end mod DOS2.50
;
; Establish extended BIOS hook
;
Expand Down Expand Up @@ -2111,36 +2079,46 @@ endif
;
;------------------------------------------------------------------------------
;
; Timer interrupt handler.
;
; Note that both in normal mode and in DOS 1 mode jumping to the previous
; hook will trigger the chain of interrupt routines for the drivers
; attached to MSX-DOS 1 kernels (each will call its "previous hook"
; as configured in HOOKSAV).

TIMINT::
push af ;Save VDP status
ld a,(DOS_VER##)
or a
jr nz,DOS2INT

;Interrupt handler, DOS 1 version

call TIMI_250 ;Call 2.50 kernels driver interrupt routine.
ex af,af'
pop af ;Restore VDP status
ex af,af'
ld a,3
ld ix,PRV1INT##
jp CALBNK##
;Interrupt handler, DOS 1 mode version

call TIMI_NEXTOR_DRV ;Call interrupt routine for Nextor drivers.
pop af ;Restore VDP status.
jp TM1_SAVE## ;Jump to the previous interrupt routine.


;Interrupt handler, DOS 2 version
;Interrupt handler, normal ("DOS 2 mode") version

DOS2INT:
call TIME_IRQ## ;Call the master interrupt routine.
call TIMI_DRV ;Call driver interrupt routine in turn.
call TIMI_250 ;Call 2.50 kernels driver interrupt routine.
pop af ;Restore VDP status
jp TIMI_SAVE##
call TIMI_DOS2_DRV ;Call interrupt routines of drivers attached to DOS 2 kernels.
call TIMI_NEXTOR_DRV ;Call interrupt routine for Nextor drivers.
pop af ;Restore VDP status.
jp TIMI_SAVE## ;Jump to the previous interrupt routine.

TIMI_DRV:

TIMI_DOS2_DRV:
;
; Call all possible disk drivers interrupt which is combined with
; new DOS2 code. This is because the disk drivers entry may not
; be revealed at this point (because of local banking)
; Call the interrupt routines of drivers attached to MSX-DOS 2 kernels.
; These are the ones that have an entry in HOOKSAV whose slot number matches
; the entry with the same index in DRVTBL, thus representing a "my hook" entry
; (if the slot number is different then the HOOKSAV entry has been
; set by a driver attached to a MSX-DOS 1 kernel, and in this case
; it represents a "previous hook" entry and the driver itself will call it
; at the end of its own interrupt routine).
;
ld de,DRVTBL
ld hl,HOOKSAV
Expand All @@ -2151,26 +2129,22 @@ scan_loop:
ret z ; yes, done

inc de
ld a,(de) ;Get slot address
ld a,(de) ;Get slot address from DRVTBL
inc de
cp (hl) ; same?
jr nz,next_cart ; no, this has been set by
; old SETINT
ld a,(MASTER_SLOT##)
cp (hl) ;Is it me?
ld a,(hl) ; assume not
cp (hl) ; same slot number in equivalent HOOKSAV entry?
jr nz,next_cart ; no, HOOKSAV entry has been set by DOS 1 SETINT
ld a,(hl) ; slot number
push bc ; save count
push de ; DRVTBL pointer
push hl ; HOOKSAV pointer
inc hl
ld e,(hl)
inc hl
ld d,(hl)
push af
pop iy
db 0FDh,67h ;LD IYh,A
push de
pop ix
call call_drv
call CALSLT
pop hl
pop de
pop bc
Expand All @@ -2181,21 +2155,18 @@ next_cart:
djnz scan_loop
ret
;
call_drv:
jp nz,CALSLT ;Was slave, call thru inter-slot call
jp (ix) ;Was me, just call my slot.
;
;
TIMI_250:
TIMI_NEXTOR_DRV:
;
; Call the interrupt routine of DOS 2.50 kernels
; Call the interrupt routine of all drivers attached to Nextor kernels.
;
ld hl,KER250
ld b,4
T250_LOOP:
TNEX_LOOP:
ld a,(hl)
bit 6,a ;Zero if empty entry or if no interrupt declared
jr z,T250_DJNZ
jr z,TNEX_DJNZ

push hl
push bc
Expand All @@ -2210,11 +2181,15 @@ T250_LOOP:
pop bc
pop hl

T250_DJNZ:
TNEX_DJNZ:
inc hl
djnz T250_LOOP
djnz TNEX_LOOP
ret

call_drv:
jp nz,CALSLT ;Was slave, call thru inter-slot call
jp (ix) ;Was me, just call my slot.

;
;public PROMPT
PROMPT:
Expand Down Expand Up @@ -2346,35 +2321,6 @@ ADDHLBC:
add hl,bc
ret

;
; Define disk driver's timer interrupt entry
;
; HL = timer interrupt entry address
;
public SETINT
SETINT:
ex de,hl ; de = interrupt entry
call GSLOT1##
push af ; save slot number
call GET_DISKID_HL
ld a,(hl) ;(DISKID) ; make a pointer to HOOKSAV
ld hl,HOOKSAV
call ADDHLBC
add hl,bc
add hl,bc
pop af
ld (hl),a
inc hl
ld (hl),e
inc hl
ld (hl),d
;
; Return from disk driver interrupt (was jump to previous hook in DOS1)
;
public PRVINT
PRVINT:
ret

;
;-----------------------------------------------------------------------
;
Expand Down Expand Up @@ -2943,17 +2889,9 @@ olddos_9:
ld de,@EXTBIO##
call MYHOOK

ld a,3 ;Do a DOS1 style SETINT
ld ix,SET1INT##
ld hl,@TIME_IRQ##
call CALBNK##

;ld a,(FCALSAV##) ;TODO: Investigate why FCALSAV is all zeros
;or a ;at this point (should be all RETs)
;jr nz,FCALSAV_OK
;ld a,0C9h ;Code for RET
;ld (FCALSAV##),a
;FCALSAV_OK:
ld hl,TM1_SAVE##
ld de,@TIME_IRQ##
call SAVE_AND_PATCH_HTIMI

ld a,3
ld (MAIN_BANK##),a
Expand All @@ -2962,6 +2900,25 @@ olddos_9:
push hl ; CLEAN+11h (just after RET P) of
ld a,3 ; INIT.Z80, not INIT.MAC (this code).
jp CHGBNK


; Make a copy of H.TIMI hook and then patch it to point to another address
; of our slot via interslot call.
;
; In: HL = Address for the copy
; DE = New destination address (in main Nextor kernel) for the hook

SAVE_AND_PATCH_HTIMI:
push de
ex de,hl
ld hl,H.TIMI
push hl
ld bc,5
ldir
pop hl
pop de
jp MYHOOK

;
;
;===== start add DOS2.50 (build type)
Expand Down
Loading

0 comments on commit 05fdcef

Please sign in to comment.