[Contents] [Commodore] [New] [Search] [Home]

Commodore 1571 firmware
Error processing

    .page  
	.subttl 'erproc.src'          
; error processing 

; controller errors
;  0  (1)  no error
; 20  (2)  can't find block header
; 21  (3)  no synch character
; 22  (4)  data block not present
; 23  (5)  checksum error in data
; 24  (16) byte decoding error
; 25  (7)  write-verify error
; 26  (8)  write write protect on
; 27  (9)  checksum error in header
; 28  (10) data extends into next block
; 29  (11) disk i.d. mismatch

; command errors
; 30  general syntax
; 31  invalid command
; 32  long line
; 33  invalid filname
; 34  no file given
; 39  command file not found

; 50  record not present
; 51  overflow in record
; 52  file too large

; 60  file open for write
; 61  file not open
; 62  file not found
; 63  file exists
; 64  file type mismatch
; 65  no block
; 66  illegal track or sector
; 67  illegal system t or s

; 70  no channels available
; 71  directory error
; 72  disk full
; 73  cbm dos v3.0
; 74  drive not ready

;  1  files scratched response

badsyn   =$30    
badcmd   =$31    
longln   =$32    
badfn    =$33    
nofile   =$34    
nocfil   =$39    
norec    =$50    
recovf   =$51    
bigfil   =$52    
filopn   =$60    
filnop   =$61    
flntfd   =$62    
flexst   =$63    
mistyp   =$64    
noblk    =$65    
badts    =$66    
systs    =$67    
nochnl   =$70    
direrr   =$71    
dskful   =$72    
cbmv2    =$73    
nodriv   =$74    
	.page    
; error message table
;   leading errror numbers,
;   text with 1st & last chars 
;   or'ed with $80,
;   tokens for key words are
;   less than $10 (and'ed $80)

errtab          ; " OK"
	.byte    0,$a0,'O',$cb   
;"read error"
	.byte    $20,$21,$22,$23,$24,$27         
	.byte    $d2,'EAD',$89   
;" file too large"
	.byte    $52,$83,' TOO LARG',$c5       
;" record not present"
	.byte    $50,$8b,6,' PRESEN',$d4        
;"overflow in record"
	.byte    $51,$cf,'VERFLOW '     
	.byte    'IN',$8b        
;" write error"
	.byte    $25,$28,$8a,$89         
;" write protect on"
	.byte    $26,$8a,' PROTECT O',$ce      
;" disk id mismatch"
	.byte    $29,$88,' ID',$85      
;"syntax error"
	.byte    $30,$31,$32,$33,$34     
	.byte    $d3,'YNTAX',$89         
;" write file open"
	.byte    $60,$8a,3,$84   
;" file exists"
	.byte    $63,$83,' EXIST',$d3   
;" file type mismatch"
	.byte    $64,$83,' TYPE',$85    
;"no block"
	.byte    $65,$ce,'O BLOC',$cb   
;"illegal track or sector"
	.byte   $66,$67,$c9,'LLEGAL TRACK'     
	.byte   ' OR SECTO',$d2       
;" file not open"
	.byte    $61,$83,6,$84   
;" file not found"
	.byte    $39,$62,$83,6,$87       
;" files scratched"
	.byte    1,$83,'S SCRATCHE',$c4         
;"no channel"
	.byte    $70,$ce,'O CHANNE',$cc         
;"dir error"
	.byte    $71,$c4,'IR',$89        
;" disk full"
	.byte    $72,$88,' FUL',$cc     
;"cbm dos v3.0 1571"
	.byte   $73,$c3,'BM DOS V3.0 157',$b1        
;"drive not ready"
	.byte   $74,$c4,'RIVE',6,' READ',$d9   

; error token key words
;   words used more than once
;"error"
	.byte    9,$c5,'RRO',$d2         
;"write"
	.byte    $a,$d7,'RIT',$c5        
;"file"
	.byte    3,$c6,'IL',$c5          
;"open"
	.byte    4,$cf,'PE',$ce          
;"mismatch"
	.byte    5,$cd,'ISMATC',$c8      
;"not"
	.byte    6,$ce,'O',$d4   
;"found"
	.byte    7,$c6,'OUN',$c4         
;"disk"
	.byte    8,$c4,'IS',$cb          
;"record"
	.byte   $b,$d2,'ECOR',$c4       
etend    =*      
	.page    
; controller error entry
;   .a= error #
;   .x= job #
error   
;<><><><><><><><><><><><><><><><><><><><><><><><><><><><>

	jmp  ptch46	; *** rom ds 85 ***
;	pha      
;       stx  jobnum      

;<><><><><><><><><><><><><><><><><><><><><><><><><><><><>

rtch46  txa      
	asl  a   
	tax      
	lda  hdrs,x     ;12********* track,sector
	sta  track       
	lda  hdrs+1,x   ;12*********
	sta  sector      

	pla      
	and  #$f        ; convert controller...
	beq  err1       ; ...errors to dos errors
	cmp  #$f        ; check nodrive error
	bne  err2        

	lda  #nodriv     
	bne  err3       ; bra
err1             
	lda  #6         ; code=16-->14
err2    ora  #$20        
	tax      
	dex      
	dex      
	txa      
err3             
	pha      
	lda  cmdnum      
	cmp  #val        
	bne  err4        
	lda  #$ff        
	sta  cmdnum      
	pla      
	jsr  errmsg      
	jsr  initdr     ; init for validate
	jmp  cmder3      
err4             
	pla      
cmder2           
	jsr  errmsg      
cmder3           
	jsr  clrcb      ; clear cmdbuf
	lda  #0          
	sta  wbam       ; clear after error
	jsr  erron      ; set error led
	jsr  freich     ; free internal channel
	lda  #0         ; clear pointers
	sta  buftab+cbptr        
	ldx  #topwrt     
	txs     	;  purge stack
	lda  orgsa       
	and  #$f         
	sta  sa          
	cmp  #$f         
	beq  err10       
	sei      
	lda  lsnact      
	bne  lsnerr      
	lda  tlkact      
	bne  tlkerr      

	ldx  sa          
	lda  lintab,x    
	cmp  #$ff        
	beq  err10       
	and  #$f         
	sta  lindx       
	jmp  tlerr       


; talker error recovery
;  if command channel, release dav
;  if data channel, force not ready
;   and release channel
tlkerr           
	jsr  fndrch      
;       jsr iterr 		; *** rom - 05 fix83 ***
	.byte  $ea,$ea,$ea      ; fill in 'jsr'
	bne  tlerr      	; finish

; listener error recovery
;  if command channel, release rfd
;  if data channel, force not ready
;  and release channel
lsnerr           
	jsr  fndwch      
;       jsr ilerr 		; *** rom - 05 fix83 ***
	.byte  $ea,$ea,$ea      ; fill in 'jsr'
tlerr            
	jsr  typfil      
	cmp  #reltyp     
	bcs  err10       
	jsr  frechn      
err10            

;<><><><><><><><><><><><><><><><><><><><><><><><><><><><>

	jmp  xidle		; *** rom ds 84 ***
;       jmp  idle        

;<><><><><><><><><><><><><><><><><><><><><><><><><><><><>

	.page    
; convert hex to bcd
hexdec  tax      
;<><><><><><><><><><><><><><><><><><><><><><><><><><><><>

	jmp  ptch67	; *** rom ds 86 ***
;       lda  #0          
;       sed      

hex0    cpx  #0          
	beq  hex5        
	clc      
	adc  #1          
	dex      
	jmp  hex0        

;<><><><><><><><><><><><><><><><><><><><><><><><><><><><>

hex5    cld      

; convert bcd to ascii dec
;  return bcd in .x
;  store ascii in (temp),y
bcddec  tax      
	lsr  a   
	lsr  a   
	lsr  a   
	lsr  a   
	jsr  bcd2        
	txa      
bcd2             
	and  #$f         
	ora  #$30        
	sta  (cb+2),y    
	iny      
	rts      

; transfer error message to
;  error buffer

okerr            
	jsr  erroff      
	lda  #0          
errts0           
	ldy  #0          
	sty  track       
	sty  sector      

errmsg           
	ldy  #0          
	ldx  #<errbuf    
	stx  cb+2        
        ldx  #>errbuf
	stx  cb+3        
	jsr  bcddec     ; convert error #
	lda  #',         
	sta  (cb+2),y    
	iny      
	lda  errbuf      
	sta  chndat+errchn       
	txa     	; error # in .x
	jsr  ermove     ; move message

ermsg2  lda  #',         
	sta  (cb+2),y    
	iny      
	lda  track       
	jsr  hexdec     ; convert track #
	lda  #',         
	sta  (cb+2),y    
	iny      
	lda  sector     ; convert sector #
	jsr  hexdec      
	dey      
	tya      
	clc      
        adc  #<errbuf   ; set last char
	sta  lstchr+errchn      
	inc  cb+2        
	lda  #rdytlk     
	sta  chnrdy+errchn       
	rts      

;**********************************;
;*    ermove - move error message *;
;*      from errtab to errbuf.    *;
;*      fully recursive for token *;
;*      word prosessing.          *;
;*   input: .a= bcd error number  *;
;**********************************;

ermove           
	tax     	; save .a
	lda  r0         ; save r0,r0+1
	pha      
	lda  r0+1        
	pha      
        lda  #<errtab   ; set pointer to table
	sta  r0          
        lda  #>errtab
	sta  r0+1        
	txa     	; restore .a
	ldx  #0         ; .x=0 for indirect
e10              
	cmp  (r0,x)     ; ?error # = table entry?
	beq  e50        ; yes, send message

	pha     	; save error #
	jsr  eadv2      ; check & advance ptr
	bcc  e30        ; more #'s to check
e20              
	jsr  eadv2      ; advance past this message
	bcc  e20         
e30              
	lda  r0+1       ; check ptr
	cmp  #>etend     
	bcc  e40        ; <, continue
	bne  e45        ; >, quit

        lda  #<etend
        cmp  r0
	bcc  e45        ; past end of table
e40              
	pla     	; restore error #
	jmp  e10        ; check next entry
e45              
	pla     	; pop error #
	jmp  e90        ; go quit

e50             	; the number has been located
	jsr  eadv1       
	bcc  e50        ; advance past other #'s
e55              
	jsr  e60         
	jsr  eadv1       
	bcc  e55         

	jsr  e60        ; check for token or last word
e90              
	pla     	; all finished
	sta  r0+1       ; restore r0
	pla      
	sta  r0          
	rts      

e60              
	cmp  #$20       ; (max token #)+1
	bcs  e70        ; not a token
	tax      
	lda  #$20       ; implied leading space
	sta  (cb+2),y    
	iny      
	txa     	; restore token #
	jsr  ermove     ; add token word to message
	rts      
e70              
	sta  (cb+2),y   ; put char in message
	iny      
	rts      

;error advance & check

eadv1           	; pre-increment
	inc  r0         ; advance ptr
	bne  ea10        
	inc  r0+1        
ea10             
	lda  (r0,x)     ; get current entry
	asl  a          ; .c=1 is end or beginning
	lda  (r0,x)      
	and  #$7f       ; mask off bit7
	rts      

eadv2           	; post-increment
	jsr  ea10       ; check table entry
	inc  r0          
	bne  ea20        
	inc  r0+1        
ea20             
    rts

[Contents] [Commodore] [New] [Search] [Home]
This page has been created by Sami Rautiainen.
Read the small print. Last updated August 27, 1998.