.import fd_table,fd_index
.import fdt_to_fdi
.export clriocb
- .export fdtoiocb
.export fdtoiocb_down
.export findfreeiocb
.export fddecusage
.endproc
-; gets fd in ax
-; return iocb index in A, fd_table index in X
-; return N bit set for invalid fd
-; all registers destroyed
-.proc fdtoiocb
-
- cpx #0
- bne inval
- cmp #MAX_FD_INDEX
- bcs inval
- tax
- lda fd_index,x
- asl a ; create index into fd table
- asl a
- tax
- lda #$ff
- cmp fd_table+ft_iocb,x ; entry in use?
- beq inval ; no, return error
- lda fd_table+ft_usa,x ; get usage counter
- beq inval ; 0? should not happen
- lda fd_table+ft_iocb,x ; get iocb
- rts
-
-.endproc ; fdtoiocb
-
; find a free iocb
; no entry parameters
; return ZF = 0/1 for not found/found
.endproc ; findfreeiocb
+
; decrements usage counter for fd
; if 0 reached, it's marked as unused
; get fd index in tmp2
.endproc ; fddecusage
+
; newfd
;
; called from open() function
--- /dev/null
+;
+; Christian Groessler, May-2000
+; Moved from fdtable.s to it's own file by Daniel Serpell, 2009.
+;
+; Convert file descriptor to IOCB number
+;
+
+ .include "atari.inc"
+ .include "fd.inc"
+ .import fd_table,fd_index
+ .export fdtoiocb
+
+ .code
+
+; gets fd in ax
+; return iocb index in A, fd_table index in X
+; return N bit set for invalid fd
+; all registers destroyed
+.proc fdtoiocb
+
+ cpx #0
+ bne inval
+ cmp #MAX_FD_INDEX
+ bcs inval
+ tax
+ lda fd_index,x
+ asl a ; create index into fd table
+ asl a
+ tax
+ lda #$ff
+ cmp fd_table+ft_iocb,x ; entry in use?
+ beq inval ; no, return error
+ lda fd_table+ft_usa,x ; get usage counter
+ beq inval ; 0? should not happen
+ lda fd_table+ft_iocb,x ; get iocb
+ rts
+
+inval: ldx #$ff ; sets N
+ rts
+
+.endproc ; fdtoiocb