hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
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
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
/* SPDX-License-Identifier: GPL-2.0 */
   /* This is trivial with the new code... */
   .globl        do_fpdis
   .type        do_fpdis,#function
do_fpdis:
   sethi        %hi(TSTATE_PEF), %g4
   rdpr        %tstate, %g5
   andcc        %g5, %g4, %g0
   be,pt        %xcc, 1f
    nop
   rd        %fprs, %g5
   andcc        %g5, FPRS_FEF, %g0
   be,pt        %xcc, 1f
    nop
 
   /* Legal state when DCR_IFPOE is set in Cheetah %dcr. */
   sethi        %hi(109f), %g7
   ba,pt        %xcc, etrap
109:     or        %g7, %lo(109b), %g7
   add        %g0, %g0, %g0
   ba,a,pt        %xcc, rtrap
 
1:    TRAP_LOAD_THREAD_REG(%g6, %g1)
   ldub        [%g6 + TI_FPSAVED], %g5
   wr        %g0, FPRS_FEF, %fprs
   andcc        %g5, FPRS_FEF, %g0
   be,a,pt        %icc, 1f
    clr        %g7
   ldx        [%g6 + TI_GSR], %g7
1:    andcc        %g5, FPRS_DL, %g0
   bne,pn        %icc, 2f
    fzero        %f0
   andcc        %g5, FPRS_DU, %g0
   bne,pn        %icc, 1f
    fzero        %f2
   faddd        %f0, %f2, %f4
   fmuld        %f0, %f2, %f6
   faddd        %f0, %f2, %f8
   fmuld        %f0, %f2, %f10
   faddd        %f0, %f2, %f12
   fmuld        %f0, %f2, %f14
   faddd        %f0, %f2, %f16
   fmuld        %f0, %f2, %f18
   faddd        %f0, %f2, %f20
   fmuld        %f0, %f2, %f22
   faddd        %f0, %f2, %f24
   fmuld        %f0, %f2, %f26
   faddd        %f0, %f2, %f28
   fmuld        %f0, %f2, %f30
   faddd        %f0, %f2, %f32
   fmuld        %f0, %f2, %f34
   faddd        %f0, %f2, %f36
   fmuld        %f0, %f2, %f38
   faddd        %f0, %f2, %f40
   fmuld        %f0, %f2, %f42
   faddd        %f0, %f2, %f44
   fmuld        %f0, %f2, %f46
   faddd        %f0, %f2, %f48
   fmuld        %f0, %f2, %f50
   faddd        %f0, %f2, %f52
   fmuld        %f0, %f2, %f54
   faddd        %f0, %f2, %f56
   fmuld        %f0, %f2, %f58
   b,pt        %xcc, fpdis_exit2
    faddd        %f0, %f2, %f60
1:    mov        SECONDARY_CONTEXT, %g3
   add        %g6, TI_FPREGS + 0x80, %g1
   faddd        %f0, %f2, %f4
   fmuld        %f0, %f2, %f6
 
661:    ldxa        [%g3] ASI_DMMU, %g5
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   ldxa        [%g3] ASI_MMU, %g5
   .previous
 
   sethi        %hi(sparc64_kern_sec_context), %g2
   ldx        [%g2 + %lo(sparc64_kern_sec_context)], %g2
 
661:    stxa        %g2, [%g3] ASI_DMMU
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   stxa        %g2, [%g3] ASI_MMU
   .previous
 
   membar        #Sync
   add        %g6, TI_FPREGS + 0xc0, %g2
   faddd        %f0, %f2, %f8
   fmuld        %f0, %f2, %f10
   membar        #Sync
   ldda        [%g1] ASI_BLK_S, %f32
   ldda        [%g2] ASI_BLK_S, %f48
   membar        #Sync
   faddd        %f0, %f2, %f12
   fmuld        %f0, %f2, %f14
   faddd        %f0, %f2, %f16
   fmuld        %f0, %f2, %f18
   faddd        %f0, %f2, %f20
   fmuld        %f0, %f2, %f22
   faddd        %f0, %f2, %f24
   fmuld        %f0, %f2, %f26
   faddd        %f0, %f2, %f28
   fmuld        %f0, %f2, %f30
   ba,a,pt        %xcc, fpdis_exit
 
2:    andcc        %g5, FPRS_DU, %g0
   bne,pt        %icc, 3f
    fzero        %f32
   mov        SECONDARY_CONTEXT, %g3
   fzero        %f34
 
661:    ldxa        [%g3] ASI_DMMU, %g5
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   ldxa        [%g3] ASI_MMU, %g5
   .previous
 
   add        %g6, TI_FPREGS, %g1
   sethi        %hi(sparc64_kern_sec_context), %g2
   ldx        [%g2 + %lo(sparc64_kern_sec_context)], %g2
 
661:    stxa        %g2, [%g3] ASI_DMMU
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   stxa        %g2, [%g3] ASI_MMU
   .previous
 
   membar        #Sync
   add        %g6, TI_FPREGS + 0x40, %g2
   faddd        %f32, %f34, %f36
   fmuld        %f32, %f34, %f38
   membar        #Sync
   ldda        [%g1] ASI_BLK_S, %f0
   ldda        [%g2] ASI_BLK_S, %f16
   membar        #Sync
   faddd        %f32, %f34, %f40
   fmuld        %f32, %f34, %f42
   faddd        %f32, %f34, %f44
   fmuld        %f32, %f34, %f46
   faddd        %f32, %f34, %f48
   fmuld        %f32, %f34, %f50
   faddd        %f32, %f34, %f52
   fmuld        %f32, %f34, %f54
   faddd        %f32, %f34, %f56
   fmuld        %f32, %f34, %f58
   faddd        %f32, %f34, %f60
   fmuld        %f32, %f34, %f62
   ba,a,pt        %xcc, fpdis_exit
 
3:    mov        SECONDARY_CONTEXT, %g3
   add        %g6, TI_FPREGS, %g1
 
661:    ldxa        [%g3] ASI_DMMU, %g5
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   ldxa        [%g3] ASI_MMU, %g5
   .previous
 
   sethi        %hi(sparc64_kern_sec_context), %g2
   ldx        [%g2 + %lo(sparc64_kern_sec_context)], %g2
 
661:    stxa        %g2, [%g3] ASI_DMMU
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   stxa        %g2, [%g3] ASI_MMU
   .previous
 
   membar        #Sync
   mov        0x40, %g2
   membar        #Sync
   ldda        [%g1] ASI_BLK_S, %f0
   ldda        [%g1 + %g2] ASI_BLK_S, %f16
   add        %g1, 0x80, %g1
   ldda        [%g1] ASI_BLK_S, %f32
   ldda        [%g1 + %g2] ASI_BLK_S, %f48
   membar        #Sync
fpdis_exit:
 
661:    stxa        %g5, [%g3] ASI_DMMU
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   stxa        %g5, [%g3] ASI_MMU
   .previous
 
   membar        #Sync
fpdis_exit2:
   wr        %g7, 0, %gsr
   ldx        [%g6 + TI_XFSR], %fsr
   rdpr        %tstate, %g3
   or        %g3, %g4, %g3        ! anal...
   wrpr        %g3, %tstate
   wr        %g0, FPRS_FEF, %fprs    ! clean DU/DL bits
   retry
   .size        do_fpdis,.-do_fpdis
 
   .align        32
   .type        fp_other_bounce,#function
fp_other_bounce:
   call        do_fpother
    add        %sp, PTREGS_OFF, %o0
   ba,a,pt        %xcc, rtrap
   .size        fp_other_bounce,.-fp_other_bounce
 
   .align        32
   .globl        do_fpother_check_fitos
   .type        do_fpother_check_fitos,#function
do_fpother_check_fitos:
   TRAP_LOAD_THREAD_REG(%g6, %g1)
   sethi        %hi(fp_other_bounce - 4), %g7
   or        %g7, %lo(fp_other_bounce - 4), %g7
 
   /* NOTE: Need to preserve %g7 until we fully commit
    *       to the fitos fixup.
    */
   stx        %fsr, [%g6 + TI_XFSR]
   rdpr        %tstate, %g3
   andcc        %g3, TSTATE_PRIV, %g0
   bne,pn        %xcc, do_fptrap_after_fsr
    nop
   ldx        [%g6 + TI_XFSR], %g3
   srlx        %g3, 14, %g1
   and        %g1, 7, %g1
   cmp        %g1, 2            ! Unfinished FP-OP
   bne,pn        %xcc, do_fptrap_after_fsr
    sethi        %hi(1 << 23), %g1    ! Inexact
   andcc        %g3, %g1, %g0
   bne,pn        %xcc, do_fptrap_after_fsr
    rdpr        %tpc, %g1
   lduwa        [%g1] ASI_AIUP, %g3    ! This cannot ever fail
#define FITOS_MASK    0xc1f83fe0
#define FITOS_COMPARE    0x81a01880
   sethi        %hi(FITOS_MASK), %g1
   or        %g1, %lo(FITOS_MASK), %g1
   and        %g3, %g1, %g1
   sethi        %hi(FITOS_COMPARE), %g2
   or        %g2, %lo(FITOS_COMPARE), %g2
   cmp        %g1, %g2
   bne,pn        %xcc, do_fptrap_after_fsr
    nop
   std        %f62, [%g6 + TI_FPREGS + (62 * 4)]
   sethi        %hi(fitos_table_1), %g1
   and        %g3, 0x1f, %g2
   or        %g1, %lo(fitos_table_1),  %g1
   sllx        %g2, 2, %g2
   jmpl        %g1 + %g2, %g0
    ba,pt        %xcc, fitos_emul_continue
 
fitos_table_1:
   fitod        %f0, %f62
   fitod        %f1, %f62
   fitod        %f2, %f62
   fitod        %f3, %f62
   fitod        %f4, %f62
   fitod        %f5, %f62
   fitod        %f6, %f62
   fitod        %f7, %f62
   fitod        %f8, %f62
   fitod        %f9, %f62
   fitod        %f10, %f62
   fitod        %f11, %f62
   fitod        %f12, %f62
   fitod        %f13, %f62
   fitod        %f14, %f62
   fitod        %f15, %f62
   fitod        %f16, %f62
   fitod        %f17, %f62
   fitod        %f18, %f62
   fitod        %f19, %f62
   fitod        %f20, %f62
   fitod        %f21, %f62
   fitod        %f22, %f62
   fitod        %f23, %f62
   fitod        %f24, %f62
   fitod        %f25, %f62
   fitod        %f26, %f62
   fitod        %f27, %f62
   fitod        %f28, %f62
   fitod        %f29, %f62
   fitod        %f30, %f62
   fitod        %f31, %f62
 
fitos_emul_continue:
   sethi        %hi(fitos_table_2), %g1
   srl        %g3, 25, %g2
   or        %g1, %lo(fitos_table_2), %g1
   and        %g2, 0x1f, %g2
   sllx        %g2, 2, %g2
   jmpl        %g1 + %g2, %g0
    ba,pt        %xcc, fitos_emul_fini
 
fitos_table_2:
   fdtos        %f62, %f0
   fdtos        %f62, %f1
   fdtos        %f62, %f2
   fdtos        %f62, %f3
   fdtos        %f62, %f4
   fdtos        %f62, %f5
   fdtos        %f62, %f6
   fdtos        %f62, %f7
   fdtos        %f62, %f8
   fdtos        %f62, %f9
   fdtos        %f62, %f10
   fdtos        %f62, %f11
   fdtos        %f62, %f12
   fdtos        %f62, %f13
   fdtos        %f62, %f14
   fdtos        %f62, %f15
   fdtos        %f62, %f16
   fdtos        %f62, %f17
   fdtos        %f62, %f18
   fdtos        %f62, %f19
   fdtos        %f62, %f20
   fdtos        %f62, %f21
   fdtos        %f62, %f22
   fdtos        %f62, %f23
   fdtos        %f62, %f24
   fdtos        %f62, %f25
   fdtos        %f62, %f26
   fdtos        %f62, %f27
   fdtos        %f62, %f28
   fdtos        %f62, %f29
   fdtos        %f62, %f30
   fdtos        %f62, %f31
 
fitos_emul_fini:
   ldd        [%g6 + TI_FPREGS + (62 * 4)], %f62
   done
   .size        do_fpother_check_fitos,.-do_fpother_check_fitos
 
   .align        32
   .globl        do_fptrap
   .type        do_fptrap,#function
do_fptrap:
   TRAP_LOAD_THREAD_REG(%g6, %g1)
   stx        %fsr, [%g6 + TI_XFSR]
do_fptrap_after_fsr:
   ldub        [%g6 + TI_FPSAVED], %g3
   rd        %fprs, %g1
   or        %g3, %g1, %g3
   stb        %g3, [%g6 + TI_FPSAVED]
   rd        %gsr, %g3
   stx        %g3, [%g6 + TI_GSR]
   mov        SECONDARY_CONTEXT, %g3
 
661:    ldxa        [%g3] ASI_DMMU, %g5
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   ldxa        [%g3] ASI_MMU, %g5
   .previous
 
   sethi        %hi(sparc64_kern_sec_context), %g2
   ldx        [%g2 + %lo(sparc64_kern_sec_context)], %g2
 
661:    stxa        %g2, [%g3] ASI_DMMU
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   stxa        %g2, [%g3] ASI_MMU
   .previous
 
   membar        #Sync
   add        %g6, TI_FPREGS, %g2
   andcc        %g1, FPRS_DL, %g0
   be,pn        %icc, 4f
    mov        0x40, %g3
   stda        %f0, [%g2] ASI_BLK_S
   stda        %f16, [%g2 + %g3] ASI_BLK_S
   andcc        %g1, FPRS_DU, %g0
   be,pn        %icc, 5f
4:       add        %g2, 128, %g2
   stda        %f32, [%g2] ASI_BLK_S
   stda        %f48, [%g2 + %g3] ASI_BLK_S
5:    mov        SECONDARY_CONTEXT, %g1
   membar        #Sync
 
661:    stxa        %g5, [%g1] ASI_DMMU
   .section    .sun4v_1insn_patch, "ax"
   .word        661b
   stxa        %g5, [%g1] ASI_MMU
   .previous
 
   membar        #Sync
   ba,pt        %xcc, etrap
    wr        %g0, 0, %fprs
   .size        do_fptrap,.-do_fptrap