-
Notifications
You must be signed in to change notification settings - Fork 85
/
Copy pathssutil.src
189 lines (168 loc) · 4.41 KB
/
ssutil.src
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
182
183
184
185
186
187
188
189
.page
.subttl 'ssutil.src'
;*********************************
;* b0tob0: transfer bytes from *
;* one buf to other. *
;* reg: in: .a= # bytes *
;* .y= source buf # *
;* .x= destin buf # *
;*********************************
b0tob0
pha
lda #0
sta temp
sta temp+2
lda bufind,y
sta temp+1
lda bufind,x
sta temp+3
pla
tay
dey
b02
lda (temp),y
sta (temp+2),y
dey
bpl b02
rts
;*********************************
;* clrbuf: clear buffer given *
;* reg: in: .a= buffer # *
;* out: .y,.a =0 *
;*********************************
clrbuf
tay
lda bufind,y
sta temp+1
lda #0
sta temp
tay
cb10
sta (temp),y
iny
bne cb10
rts
;*********************************
;* ssset: set ss pntr to 0 *
;* reg: out: .a= ss number *
;*********************************
ssset
lda #0
jsr ssdir
ldy #2
lda (dirbuf),y
rts
;*********************************
;* ssdir: set dirbuf with current*
;* ss pointer. *
;* regs: in: .a= low byte *
;*********************************
ssdir
sta dirbuf
ldx lindx
lda ss,x
tax
lda bufind,x
sta dirbuf+1
rts
;*********************************
;* setssp: set dirbuf & buftab *
;* with current ss ptr. *
;* regs: in: .a= low byte *
;*********************************
setssp
pha
jsr ssdir
pha
txa
asl a
tax
pla
sta buftab+1,x
pla
sta buftab,x
rts
;*********************************
;* sspos: position ss & buftab *
;* to ssnum ssind. *
;* flag: .v=0: ok *
;* .v=1: out of range *
;*********************************
sspos
jsr sstest
bmi ssp10 ; out of range
bvc ssp20 ; er0:ok, in range
ldx lindx ; er1: possibly in range
lda ss,x
jsr ibrd ; read ss in
jsr sstest ; test again
bpl ssp20
ssp10
jsr ssend ; not in range,set end
bit er1
rts
ssp20
lda ssind ; ok, set ptr w/ index
jsr setssp
bit er0
rts
;*********************************
;* ibrd: indirect block read & *
;* ibwt: write. *
;* regs: in: .a= buf # for r/w *
;* .x= lindx *
;* (dirbuf),y points to *
;* t&s to be r/w. *
;*********************************
ibrd
sta jobnum
lda #read
bne ibop
ibwt
sta jobnum
lda #write
ibop
pha
lda filtyp,x
and #1
sta drvnum
pla
ora drvnum
sta cmd
lda (dirbuf),y
sta track
iny
lda (dirbuf),y
sta sector
lda jobnum
jsr seth
ldx jobnum
jmp doit2
;*
;*****************************
;*
;* gsspnt
;*
;*****************************
;*
gsspnt ldx lindx
lda ss,x
jmp gp1
scal1
lda #nssp
jsr addt12 ; add (#ss needed)*120
sscalc
dex
bpl scal1
lda t3 ; add (# ss indices needed)
lsr a
jsr addt12
lda t4 ; add (# ss blocks needed)
addt12
clc ; add .a to t1,t2
adc t1
sta t1
bcc addrts
inc t2
addrts
rts