-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathqio.inc
181 lines (155 loc) · 4.42 KB
/
qio.inc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
; QDB structure offsets
Q.FUNC equ 0 ; function code (1 byte)
Q.SUBF equ Q.FUNC + 1 ; subfunction (1 byte)
Q.LUN equ Q.SUBF + 1 ; logical unit number (1 byte)
Q.EFN equ Q.LUN + 1 ; event flag number (1 byte)
Q.WAIT equ Q.EFN + 1 ; wait flag (1 byte)
Q.IOSB equ Q.WAIT + 1 ; I/O Status Block address (2 bytes)
Q.AST equ Q.IOSB + 2 ; AST routine address (2 bytes)
Q.P1 equ Q.AST + 2 ; function-dependent param 1 (2 bytes)
Q.P2 equ Q.P1 + 2 ; function-dependent param 2 (2 bytes)
Q.P3 equ Q.P2 + 2 ; function-dependent param 3 (2 bytes)
Q.P4 equ Q.P3 + 2 ; function-dependent param 4 (2 bytes)
Q.P5 equ Q.P4 + 2 ; function-dependent param 5 (2 bytes)
Q.P6 equ Q.P5 + 2 ; function-dependent param 6 (2 bytes)
QDBSZ equ Q.P6 + 2 ; QDB size
; Standard parameter mapping
Q.BUF equ Q.P1 ; buffer address in user space (2 bytes)
Q.LEN equ Q.P2 ; byte count (2 bytes)
Q.VFC equ Q.P3 ; vertical format control (2 bytes)
Q.TMO equ Q.P3 ; read timeout (2 bytes)
Q.BLK equ Q.P4 ; block number (4 bytes)
Q.OFS equ Q.P6 ; offset within block (2 bytes)
Q.PRB equ Q.P4 ; prompt buffer address (2 bytes)
Q.PRL equ Q.P5 ; prompt length (2 bytes)
Q.PVF equ Q.P6 ; prompt vertical format control (2 bytes)
; QIO function codes
; Standard functions
IO.KIL equ 0 ; cancel I/O requests
IO.ATT equ 1 ; attach device
IO.DET equ 2 ; detach device
IO.RLB equ 3 ; read logical block
IO.WLB equ 4 ; write logical block
IO.SEC equ 5 ; sense characteristics
; Additional disk driver functions
IO.RPB equ 6 ; read physical block
IO.WPB equ 7 ; write physical block
IO.FMT equ 8 ; format track
IO.IDN equ 9 ; read drive identification (IDE)
; Additional terminal functions
IO.RPR equ 9 ; read with prompt
IO.HNG equ 10 ; hangup remote line
SF.GMC equ 11 ; get multiple characteristics
SF.SMC equ 12 ; set multiple characteristics
; Special functions
IO.LOV equ 16 ; load overlay
; Terminal sub-functions (some can be ORed)
TF.AST equ 01h ; attach with AST
TF.RNE equ 01h ; read with no echo
TF.RAL equ 02h ; read all bits (unfiltered)
TF.WAL equ 02h ; write all bits
TF.TMO equ 04h ; read with timeout
TF.WBT equ 08h ; break-through write
TF.CCO equ 10h ; cancel ^O
TF.XOF equ 20h ; send XOFF
; Filesystem requests
IO.CRE equ 20 ; create file
IO.ACC equ 21 ; access (open) file
IO.DEA equ 22 ; deaccess (close) file
IO.RVB equ 23 ; read virtual block
IO.WVB equ 24 ; write virtual block
IO.RAT equ 25 ; read attributes
IO.WAT equ 26 ; write attributes
IO.UNL equ 27 ; unlock file
IO.DEL equ 28 ; delete file
IO.REN equ 29 ; rename file
IO.CLN equ 30 ; cleanup file
IO.EXT equ 31 ; extend file
IO.TRN equ 32 ; truncate file
IO.MNT equ 33 ; mount device
IO.DSM equ 34 ; dismount device
IO.FFS equ 35 ; flush all disk buffers
; File I/O subfunctions (can be ORed)
SF.ACR equ 01h ; access (open) for read
SF.ACW equ 02h ; access (open) for write
SF.SHR equ 08h ; open in shared mode
SF.FID equ 10h ; access (open) by file ID
SF.TMP equ 20h ; create temporary file (delete on close)
SF.DIR equ 40h ; create directory
SF.CTG equ 80h ; create contiguous file
SF.TRU equ 20h ; truncate unused blocks
; RSX-11M style QIO macros
QIO$ macro func,lun,efn,wait,iosb,ast,args
dw func ;; note: 16-bit Q.FUNC + Q.SUBF
db lun,efn ;; Q.LUN, Q.EFN
ifb <wait>
db 0 ;; Q.WAIT = 0
else
db wait ;; Q.WAIT
endif
dw iosb ;; Q.IOSB
ifb <ast>
dw 0 ;; Q.AST = 0
else
dw ast ;; Q.AST
endif
irp arg,<args>
ifb <arg>
dw 0
else
dw arg ;; Q.P1..P6
endif
endm
endm
QIO$S macro func,lun,efn,wait,iosb,ast,args
local n
push ix
ld ix,-QDBSZ
add ix,sp
ld sp,ix
ld (ix+Q.FUNC),low func
ld (ix+Q.SUBF),high func
ld (ix+Q.LUN),lun
ld (ix+Q.EFN),efn
ifb <wait>
ld (ix+Q.WAIT),0
else
ld (ix+Q.WAIT),wait
endif
ld hl,iosb
ld (ix+Q.IOSB),l
ld (ix+Q.IOSB+1),h
ifb <ast>
ld hl,0
else
ld hl,ast
endif
ld (ix+Q.AST),l
ld (ix+Q.AST+1),h
n defl 0
irp arg,<args>
ifb <arg>
ld hl,0
else
ld hl,arg
endif
ld (ix+Q.P1+n),l
ld (ix+Q.P1+n+1),h
n defl n+2
endm
push ix
pop hl
SC .QIO
ld hl,QDBSZ
add hl,sp
ld sp,hl
pop ix
rlca ;; restore carry bit from error code sign
rra ;; (works since all errors are negative)
endm
QIOW$ macro func,lun,efn,iosb,ast,args
QIO$ func,lun,efn,1,iosb,ast,<args>
endm
QIOW$S macro func,lun,efn,iosb,ast,args
QIO$S func,lun,efn,1,iosb,ast,<args>
endm