1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-12 02:30:44 +00:00

Read number of total blocks from ProDOS 8 volume directory header - and fall back on the constant 280 only for non-ProDOS 8 disks.

git-svn-id: svn://svn.cc65.org/cc65/trunk@4750 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
ol.sc 2010-07-17 19:16:25 +00:00
parent f15910e5f1
commit 07680d2376
3 changed files with 121 additions and 28 deletions

View File

@ -433,13 +433,6 @@ BASIC.SYSTEM) there are some limitations for DOS 3.3:
</descrip><p> </descrip><p>
<sect1>DIO<p>
Although <htmlurl url="dio.html" name="DIO"> generally works with all ProDOS 8
devices, the function <htmlurl url="dio-3.html" name="dio_query_sectcount()">
simply always return 280 (which is only correct for a 140 KB disk).
<sect1>Direct console I/O<p> <sect1>Direct console I/O<p>
<descrip> <descrip>
@ -493,15 +486,27 @@ name="assembler manual">.
<sect1>DIO<p> <sect1>DIO<p>
The function <htmlurl url="dio-1.html" name="dio_open()"> has the single parameter <descrip>
<tt/drive_id/ to identify the drive to be opened. Therefore an Apple&nbsp;II
slot and drive pair is mapped to that <tt/drive_id/ according to the formula
<verb> <tag/Drive ID/
The function <htmlurl url="dio-1.html" name="dio_open()"> has the single
parameter <tt/drive_id/ to identify the drive to be opened. Therefore an
Apple&nbsp;II slot and drive pair is mapped to that <tt/drive_id/ according
to the formula
<verb>
drive_id = slot * 16 + (drive - 1) * 128 drive_id = slot * 16 + (drive - 1) * 128
</verb> </verb>
so that for example slot 6 drive 2 is mapped to <tt/drive_id/ 224. so that for example slot 6 drive 2 is mapped to <tt/drive_id/ 224.
<tag/Sector count/
The function <htmlurl url="dio-3.html" name="dio_query_sectcount()"> returns
the correct sector count for all ProDOS 8 disks. However for any non-ProDOS 8
disk it simply always return 280 (which is only correct for a 140 KB disk).
This condition is indicated by the _oserror value 82.
</descrip><p>

View File

@ -434,13 +434,6 @@ BASIC.SYSTEM) there are some limitations for DOS 3.3:
</descrip><p> </descrip><p>
<sect1>DIO<p>
Although <htmlurl url="dio.html" name="DIO"> generally works with all ProDOS 8
devices, the function <htmlurl url="dio-3.html" name="dio_query_sectcount()">
simply always return 280 (which is only correct for a 140 KB disk).
<sect1>Direct console I/O<p> <sect1>Direct console I/O<p>
<descrip> <descrip>
@ -499,15 +492,27 @@ name="assembler manual">.
<sect1>DIO<p> <sect1>DIO<p>
The function <htmlurl url="dio-1.html" name="dio_open()"> has the single parameter <descrip>
<tt/drive_id/ to identify the drive to be opened. Therefore an Apple&nbsp;II
slot and drive pair is mapped to that <tt/drive_id/ according to the formula
<verb> <tag/Drive ID/
The function <htmlurl url="dio-1.html" name="dio_open()"> has the single
parameter <tt/drive_id/ to identify the drive to be opened. Therefore an
Apple&nbsp;II slot and drive pair is mapped to that <tt/drive_id/ according
to the formula
<verb>
drive_id = slot * 16 + (drive - 1) * 128 drive_id = slot * 16 + (drive - 1) * 128
</verb> </verb>
so that for example slot 6 drive 2 is mapped to <tt/drive_id/ 224. so that for example slot 6 drive 2 is mapped to <tt/drive_id/ 224.
<tag/Sector count/
The function <htmlurl url="dio-3.html" name="dio_query_sectcount()"> returns
the correct sector count for all ProDOS 8 disks. However for any non-ProDOS 8
disk it simply always return 280 (which is only correct for a 140 KB disk).
This condition is indicated by the _oserror value 82.
</descrip><p>

View File

@ -5,8 +5,91 @@
; ;
.export _dio_query_sectcount .export _dio_query_sectcount
.import _dio_query_sectsize, _malloc, _free
.include "zeropage.inc"
.include "errno.inc"
.include "mli.inc"
_dio_query_sectcount: _dio_query_sectcount:
lda #<280
ldx #>280 ; Set handle
sta mliparam + MLI::ON_LINE::UNIT_NUM
; Get ProDOS 8 block size (clears __oserror)
jsr _dio_query_sectsize
; Alloc buffer
jsr _malloc
sta ptr4
stx ptr4+1
; Set buffer
sta mliparam + MLI::ON_LINE::DATA_BUFFER
stx mliparam + MLI::ON_LINE::DATA_BUFFER+1
; Check buffer (hibyte is enough)
txa
beq nomem
; Get device state
lda #ON_LINE_CALL
ldx #ON_LINE_COUNT
jsr callmli
bcs check
; UNIT_NUM already set
.assert MLI::RW_BLOCK::UNIT_NUM = MLI::ON_LINE::UNIT_NUM, error
; DATA_BUFFER already set
.assert MLI::RW_BLOCK::DATA_BUFFER = MLI::ON_LINE::DATA_BUFFER, error
; Read volume directory key block
tax ; A = 0
lda #$02
sta mliparam + MLI::RW_BLOCK::BLOCK_NUM
stx mliparam + MLI::RW_BLOCK::BLOCK_NUM+1
lda #READ_BLOCK_CALL
ldx #RW_BLOCK_COUNT
jsr callmli
bcs oserr
; Get and save total blocks from volume directory header
ldy #$29
lda (ptr4),y
pha
iny
lda (ptr4),y
pha
; Cleanup buffer
done: lda ptr4
ldx ptr4+1
jsr _free
; Restore total blocks and return
pla
tax
pla
rts rts
nomem: lda #$FF ; Error code for sure not used by MLI
oserr: sta __oserror
; Save total blocks for failure
lda #$00
pha
pha
beq done ; Branch always
; Check for non-ProDOS disk
check: cmp #$52 ; "Not a ProDOS volume"
bne oserr
sta __oserror
; Save total blocks for a 16-sector disk
lda #<280
pha
lda #>280
pha
bne done ; Branch always