mirror of
https://github.com/SEPPDROID/Digital-Research-Source-Code.git
synced 2025-10-24 17:04:19 +00:00
Upload
Digital Research
This commit is contained in:
33
CPM OPERATING SYSTEMS/CPM 3.X/CPM 3.0/SOURCE/move.asm
Normal file
33
CPM OPERATING SYSTEMS/CPM 3.X/CPM 3.0/SOURCE/move.asm
Normal file
@@ -0,0 +1,33 @@
|
||||
title 'bank & move module for CP/M3 linked BIOS'
|
||||
|
||||
cseg
|
||||
|
||||
public ?move,?xmove,?bank
|
||||
extrn @cbnk
|
||||
|
||||
maclib z80
|
||||
maclib ports
|
||||
|
||||
?xmove: ; ALTOS can't perform interbank moves
|
||||
ret
|
||||
|
||||
?move:
|
||||
xchg ; we are passed source in DE and dest in HL
|
||||
ldir ; use Z80 block move instruction
|
||||
xchg ; need next addresses in same regs
|
||||
ret
|
||||
|
||||
; by exiting through bank select
|
||||
?bank:
|
||||
push b ; save register b for temp
|
||||
ral ! ral ! ral ! ani 18h ; isolate bank in proper bit position
|
||||
mov b,a ; save in reg B
|
||||
in p$bankselect ; get old memory control byte
|
||||
ani 0E7h ! ora b ; mask out old and merge in new
|
||||
out p$bankselect ; put new memory control byte
|
||||
pop b ; restore register b
|
||||
ret
|
||||
|
||||
; 128 bytes at a time
|
||||
|
||||
end
|
Reference in New Issue
Block a user