mirror of
				https://github.com/SEPPDROID/Digital-Research-Source-Code.git
				synced 2025-10-25 01:14:21 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			154 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			154 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ;************ biosif.z8k **************************
 | |
| ;*
 | |
| ;* Assembly language interface for P-CP/M (tm) BIOS
 | |
| ;*       ----- System-Independent -----
 | |
| ;*
 | |
| ;* 821013 S. Savitzky (Zilog) -- split into modules
 | |
| ;* 820913 S. Savitzky (Zilog) -- created.
 | |
| ;*
 | |
| 
 | |
| __text:	.sect
 | |
| 
 | |
| ;****************************************************
 | |
| ;*
 | |
| ;* NOTE	
 | |
| ;*	The C portion of the BIOS is non-segmented.
 | |
| ;*
 | |
| ;*	This assembly-language module is assembled
 | |
| ;*	non-segmented, and serves as the interface.
 | |
| ;*
 | |
| ;*	Segmented operations are well-isolated, and
 | |
| ;*	are either the same as their non-segmented
 | |
| ;*	counterparts, or constructed using macros.
 | |
| ;*	The resulting code looks a little odd.
 | |
| ;*
 | |
| ;****************************************************
 | |
| 
 | |
| 	.input	"biosdefs.z8k"
 | |
| 
 | |
| 
 | |
| ;****************************************************
 | |
| ;*
 | |
| ;* Externals 
 | |
| ;*
 | |
| ;****************************************************
 | |
| 
 | |
| 	.global _biosinit	;C portion init
 | |
| 	.global _flush		;Flush buffers
 | |
| 
 | |
| 	.global ccp		;Command Processor
 | |
| 
 | |
| 	.global	_trapinit	;trap startup
 | |
| 
 | |
| 	.global _psap, _sysseg, _sysstk
 | |
| 
 | |
| ;****************************************************
 | |
| ;*
 | |
| ;* Global declarations
 | |
| ;*
 | |
| ;****************************************************
 | |
| 
 | |
| 	.global	bios		; initialization
 | |
| 	.global _wboot		; warm boot
 | |
| 	.global _input		; input a byte
 | |
| 	.global _output		; output a byte
 | |
| 
 | |
| ;****************************************************
 | |
| ;*
 | |
| ;* Bios Initialization and Entry Point
 | |
| ;*
 | |
| ;*	This is where control comes after boot.
 | |
| ;*	Control is transferred to the CCP.
 | |
| ;*
 | |
| ;*	We get here from bootstrap with:
 | |
| ;*		segmented mode
 | |
| ;*		valid stack pointer
 | |
| ;*		valid PSA in RAM
 | |
| ;*
 | |
| ;****************************************************
 | |
| 
 | |
| bios:
 | |
| 
 | |
| ; enter in segmented mode.  
 | |
| ; Get system (PC) segment into r4
 | |
| 
 | |
| 	DI	VI,NVI
 | |
| 	calr	kludge	; get PC segment on stack
 | |
| kludge:	popl	rr4, @r14
 | |
| 
 | |
| ; get PSAP into rr2.
 | |
| 
 | |
| 	ldctl	r2, PSAPSEG
 | |
| 	ldctl	r3, PSAPOFF
 | |
| 
 | |
| ; go non-segmented.  save PSAP, system segment,
 | |
| ; system stack pointer (in system segment, please)
 | |
| 
 | |
| 	NONSEG
 | |
| 
 | |
| 	ldl	_psap, rr2
 | |
| 	ld	_sysseg, r4
 | |
| 	ld	r14,_sysseg
 | |
| 	ldl	_sysstk, rr14
 | |
| 
 | |
| ; set up system stack so that a return will warm boot
 | |
| 
 | |
| 	push	@r15,#_wboot
 | |
| 
 | |
| ; set up traps, then enable interrupts
 | |
| 
 | |
| 	call	_trapinit
 | |
| 	EI	VI,NVI
 | |
| 
 | |
| ; set up C part of Bios
 | |
| 
 | |
| 	call	_biosinit
 | |
| 
 | |
| ; Turn control over to command processor
 | |
| 
 | |
| 	jp	ccp
 | |
| 
 | |
| ;*****************************************************
 | |
| ;*
 | |
| ;* Warm Boot
 | |
| ;*
 | |
| ;*	flush buffers and initialize Bios
 | |
| ;*	then transfer to CCP
 | |
| ;*
 | |
| ;*****************************************************
 | |
| 
 | |
| _wboot:
 | |
| 	call	_flush
 | |
| 	call	_biosinit
 | |
| 	ldl	rr14,_sysstk
 | |
| 	jp	ccp
 | |
| 
 | |
| 
 | |
| ;****************************************************
 | |
| ;*
 | |
| ;* I/O port operations
 | |
| ;*
 | |
| ;* int = input(port: int)
 | |
| ;* output (port, data: int)
 | |
| ;*
 | |
| ;****************************************************
 | |
| 
 | |
| _input:
 | |
| 	ld	r2,ARG1(r15)
 | |
| 	subl	rr6,rr6
 | |
| 	inb	rl7,@r2
 | |
| 	ldb	rl6,rl7
 | |
| 	ret
 | |
| 
 | |
| 
 | |
| _output:
 | |
| 	ld	r2,ARG1(r15)
 | |
| 	ld	r3,ARG2(r15)
 | |
| 	outb	@r2,rl3
 | |
| 	ret
 | |
| 
 | |
| 
 | |
| ;*****************************************************
 | |
| ;*****************************************************
 | |
| 
 |