| /* 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 |
| b,pt %xcc, fpdis_exit |
| nop |
| 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,pt %xcc, fpdis_exit |
| nop |
| 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,pt %xcc, rtrap |
| nop |
| .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 |