mirror of
https://github.com/cc65/cc65.git
synced 2025-01-11 11:30:13 +00:00
6198e10f67
Stefan Dorndorf, author of XDOS, pointed out that retrieving the default device by looking at an undocumented memory location won't work in future XDOS versions. He also showed a way to get the default device in a compatible manner. This change implements his method and adds a version check (XDOS versions below 2.4 don't support this -- for them the behaviour will be the same as, for example, AtariDOS: no notion of a default drive).
114 lines
2.9 KiB
ArmAsm
114 lines
2.9 KiB
ArmAsm
;
|
|
; Freddy Offenga & Christian Groessler, December 2004
|
|
;
|
|
; function to get default device: char *_getdefdev(void);
|
|
;
|
|
; SpartaDOS:
|
|
; the ZCRNAME routine is only used to get the default drive because
|
|
; ZCRNAME has two disadvantages:
|
|
; 1. It will convert D: into D1: instead of Dn: (n = default drive)
|
|
; 2. It will give a 'no arguments' status if it detects something
|
|
; like Dn: (without filename).
|
|
;
|
|
; OS/A+ DOS:
|
|
; ZCRNAME is slightly different from SpartaDOS. It will convert D:
|
|
; into Dn: where n is the default drive.
|
|
|
|
.include "atari.inc"
|
|
.import __dos_type
|
|
.export __getdefdev ; get default device
|
|
.export __defdev ; this is the default device string (e.g. "D1:")
|
|
.ifdef DYNAMIC_DD
|
|
.constructor __getdefdev, 24
|
|
.endif
|
|
|
|
; Get default device (LBUF will be destroyed!!)
|
|
|
|
__getdefdev:
|
|
|
|
lda __dos_type ; which DOS?
|
|
cmp #XDOS
|
|
beq xdos ; only supported on XDOS ...
|
|
; cmp #OSADOS+1 ; (redundant: #OSADOS+1 = #XDOS)
|
|
bcs finish ; ... and on OS/A+ and SpartaDOS
|
|
|
|
ldy #BUFOFF
|
|
lda #0
|
|
sta (DOSVEC),y ; reset buffer offset
|
|
|
|
; Store dummy argument
|
|
|
|
ldy #LBUF
|
|
lda #'X'
|
|
sta (DOSVEC),y
|
|
iny
|
|
lda #ATEOL
|
|
sta (DOSVEC),y
|
|
|
|
; One extra store to avoid the buggy sequence from OS/A+ DOS:
|
|
; <D><RETURN><:> => drive number = <RETURN>
|
|
|
|
iny
|
|
sta (DOSVEC),y
|
|
|
|
; Create crunch vector
|
|
|
|
ldy #ZCRNAME+1
|
|
lda (DOSVEC),y
|
|
sta crvec+1
|
|
iny
|
|
lda (DOSVEC),y
|
|
sta crvec+2
|
|
|
|
jsr crvec
|
|
|
|
; Get default device
|
|
|
|
ldy #COMFNAM ; COMFNAM is always "Dn:"
|
|
lda (DOSVEC),y
|
|
sta __defdev
|
|
iny
|
|
lda (DOSVEC),y
|
|
done: sta __defdev+1
|
|
|
|
; Return pointer to default device
|
|
|
|
finish: lda #<__defdev
|
|
ldx #>__defdev
|
|
rts
|
|
|
|
; XDOS default device retrieval
|
|
|
|
xdos:
|
|
|
|
; check XDOS version (we need >= 2.4)
|
|
|
|
lda XGLIN
|
|
cmp #$4C ; there needs to be a 'JMP' opcode here
|
|
bne finish ; older version, use DEFAULT_DEVICE or D1:
|
|
lda XVER ; get BCD encoded version ($24 for 2.4)
|
|
cmp #$24
|
|
bcc finish ; too old, below 2.4
|
|
|
|
; good XDOS version, get default drive
|
|
|
|
lda #ATEOL
|
|
sta XLINE ; simulate empty command line
|
|
ldy #0
|
|
jsr XMOVE ; create an FMS filename (which in this case only contains the drive)
|
|
lda XFILE+1
|
|
bne done
|
|
|
|
.data
|
|
|
|
crvec: jmp $FFFF ; target address will be set to crunch vector
|
|
|
|
; Default device string
|
|
|
|
__defdev:
|
|
.ifdef DEFAULT_DEVICE
|
|
.byte 'D', '0'+DEFAULT_DEVICE, ':', 0
|
|
.else
|
|
.byte "D1:", 0
|
|
.endif
|