From a0359724ffd385da4d8c278dde085d5bd1e71fa2 Mon Sep 17 00:00:00 2001
From: "ol.sc"
Date: Wed, 16 Jun 2010 21:19:47 +0000
Subject: [PATCH] - Use ProDOS 8 unit number as parameter. - Don't access the
drive, just check its presence.
git-svn-id: svn://svn.cc65.org/cc65/trunk@4723 b7a2c559-68d2-44c3-8de9-860c34a00d81
---
libsrc/apple2/dioopen.s | 58 +++++++++++++----------------------------
1 file changed, 18 insertions(+), 40 deletions(-)
diff --git a/libsrc/apple2/dioopen.s b/libsrc/apple2/dioopen.s
index 16269daa2..3c664970d 100644
--- a/libsrc/apple2/dioopen.s
+++ b/libsrc/apple2/dioopen.s
@@ -3,55 +3,33 @@
;
; dhandle_t __fastcall__ dio_open (driveid_t drive_id);
;
-; drive_id = (slot * 2) + (drive - 1)
.export _dio_open
- .import return0
+ .import return0, __dos_type
- .include "zeropage.inc"
.include "errno.inc"
.include "mli.inc"
_dio_open:
- ; Convert drive id into unit number
- lsr
- bcc :+
- ora #%00001000
-: asl
- asl
- asl
- asl
- tay ; Save handle
+ ; Check for ProDOS 8
+ ldx __dos_type
+ bne :+
+ lda #$01 ; "Bad system call number"
+ bne oserr ; Branch always
- ; Set handle
- sta mliparam + MLI::ON_LINE::UNIT_NUM
-
- ; Alloc 16-byte buffer just below stack
- lda sp
- sec
- sbc #16
- sta mliparam + MLI::ON_LINE::DATA_BUFFER
- lda sp+1
- sbc #$00
- sta mliparam + MLI::ON_LINE::DATA_BUFFER+1
-
- ; Get device state
- lda #ON_LINE_CALL
- ldx #ON_LINE_COUNT
- jsr callmli
- bcc :+
-
- ; DIO level access doesn't necessarily need a
- ; ProDOS 8 disk so ignore "high level" errors
- cmp #$40
- bcc oserr
+ ; Walk device list
+: ldx DEVCNT
+: cmp DEVLST,x
+ beq :+ ; Found drive_id in device list
+ dex
+ bpl :-
+ lda #$28 ; "No device connected"
+
+ ; Return oserror
+oserr: sta __oserror
+ jmp return0
; Return success
-: tya ; Restore handle
- ldx #$00
+: ldx #$00
stx __oserror
rts
-
- ; Return oserror
-oserr: sta __oserror
- jmp return0