Date: Wed, 1 Mar 2006 08:02:56 GMT From: Kip Macy <kmacy@FreeBSD.org> To: Perforce Change Reviews <perforce@freebsd.org> Subject: PERFORCE change 92585 for review Message-ID: <200603010802.k2182uVL008354@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=92585 Change 92585 by kmacy@kmacy_storage:sun4v_work on 2006/03/01 08:02:53 fix spill / fill handlers fix trap table so that handlers are all at the right offsets add magic trap on to all unimplement trap handlers add magic trap on at beginning of spill /fill - off at the end Affected files ... .. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/exception.S#11 edit Differences ... ==== //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/exception.S#11 (text+ko) ==== @@ -69,7 +69,15 @@ #include "assym.s" - +#if 1 +#define MAGIC_TRAP_ON ta 0x77 +#define MAGIC_TRAP_OFF ta 0x78 +/*#define MAGIC_TRAP_OFF nop */ +#else +#define MAGIC_TRAP_ON nop +#define MAGIC_TRAP_OFF nop +#endif + #define TSB_KERNEL_MASK 0x0 #define TSB_KERNEL 0x0 @@ -112,6 +120,7 @@ */ #define SPILL(storer, bias, size, asi) \ + MAGIC_TRAP_ON ;\ mov 0 + bias, %g1 ;\ storer %l0, [%sp + %g1]asi ;\ mov size + bias, %g2 ;\ @@ -125,18 +134,19 @@ storer %l5, [%g5 + %g2]asi ;\ storer %l6, [%g5 + %g3]asi ;\ storer %l7, [%g5 + %g4]asi ;\ - add %sp, (4 * size), %g5 ;\ + add %g5, (4 * size), %g5 ;\ storer %i0, [%g5 + %g1]asi ;\ storer %i1, [%g5 + %g2]asi ;\ storer %i2, [%g5 + %g3]asi ;\ storer %i3, [%g5 + %g4]asi ;\ - add %sp, (4 * size), %g5 ;\ + add %g5, (4 * size), %g5 ;\ storer %i4, [%g5 + %g1]asi ;\ storer %i5, [%g5 + %g2]asi ;\ storer %i6, [%g5 + %g3]asi ;\ storer %i7, [%g5 + %g4]asi #define FILL(loader, bias, size, asi) \ + MAGIC_TRAP_ON ;\ mov 0 + bias, %g1 ;\ loader [%sp + %g1]asi, %l0 ;\ mov size + bias, %g2 ;\ @@ -150,12 +160,12 @@ loader [%g5 + %g2]asi, %l5 ;\ loader [%g5 + %g3]asi, %l6 ;\ loader [%g5 + %g4]asi, %l7 ;\ - add %sp, (4 * size), %g5 ;\ + add %g5, (4 * size), %g5 ;\ loader [%g5 + %g1]asi, %i0 ;\ loader [%g5 + %g2]asi, %i1 ;\ loader [%g5 + %g3]asi, %i2 ;\ loader [%g5 + %g4]asi, %i3 ;\ - add %sp, (4 * size), %g5 ;\ + add %g5, (4 * size), %g5 ;\ loader [%g5 + %g1]asi, %i4 ;\ loader [%g5 + %g2]asi, %i5 ;\ loader [%g5 + %g3]asi, %i6 ;\ @@ -169,10 +179,10 @@ add %sp, 32, %g3 ;\ ldda [%g3 + %g1]asi, %l4 ;\ ldda [%g3 + %g2]asi, %l6 ;\ - add %sp, 32, %g3 ;\ + add %g3, 32, %g3 ;\ ldda [%g3 + %g1]asi, %i0 ;\ ldda [%g3 + %g2]asi, %i2 ;\ - add %sp, 32, %g3 ;\ + add %g3, 32, %g3 ;\ ldda [%g3 + %g1]asi, %i4 ;\ ldda [%g3 + %g2]asi, %i6 @@ -446,6 +456,7 @@ * Generic trap type. Call trap() with the specified type. */ .macro tl0_gen type + MAGIC_TRAP_ON tl0_setup \type .align 32 .endm @@ -454,12 +465,14 @@ * This is used to suck up the massive swaths of reserved trap types. * Generates count "reserved" trap vectors. */ + .macro tl0_reserved count .rept \count tl0_gen T_RESERVED .endr .endm + .macro tl1_split #if 0 rdpr %wstate, %g1 @@ -489,62 +502,56 @@ .endm .macro insn_excptn - nop + MAGIC_TRAP_ON .align 32 .endm .macro insn_miss - nop - mov %o0, %g6 - mov 0x23, %o0 - call hv_cnputchar - mov 0x24, %o0 - call hv_cnputchar + MAGIC_TRAP_ON .align 32 .endm .macro data_excptn - nop + MAGIC_TRAP_ON .align 32 .endm .macro data_miss - nop - mov %o0, %g6 - mov 0x23, %o0 - call hv_cnputchar - mov 0x24, %o0 - call hv_cnputchar + MAGIC_TRAP_ON + MAGIC_TRAP_ON + MAGIC_TRAP_ON + MAGIC_TRAP_ON + MAGIC_TRAP_ON .align 32 .endm .macro data_prot - nop + MAGIC_TRAP_ON .align 32 .endm .macro tl0_align - nop + MAGIC_TRAP_ON .align 32 .endm .macro cpu_mondo - nop + MAGIC_TRAP_ON .align 32 .endm .macro dev_mondo - nop + MAGIC_TRAP_ON .align 32 .endm .macro resumable_error - nop + MAGIC_TRAP_ON .align 32 .endm .macro nonresumable_error - nop + MAGIC_TRAP_ON .align 32 .endm @@ -555,16 +562,18 @@ srl %sp, 0, %sp ; \ SPILL(sta, 0, 4, asi) ; \ saved ; \ + MAGIC_TRAP_OFF ; \ retry ; \ - .skip (31-26)*4 ; \ + .skip (31-28)*4 ; \ ba,a,pt %xcc, fault_32bit_##target ; \ ALIGN_128 #define spill_64bit_asi(asi, target) \ SPILL(stxa, SPOFF, 8, asi) ; \ saved ; \ + MAGIC_TRAP_OFF ; \ retry ; \ - .skip (31-25)*4 ; \ + .skip (31-27)*4 ; \ ba,a,pt %xcc, fault_64bit_##target ; \ ALIGN_128 @@ -573,7 +582,7 @@ SPILL(sta, 0, 4, asi) ; \ b spill_clean ; \ mov WSTATE_USER32, %g7 ; \ - .skip (31-26)*4 ; \ + .skip (31-27)*4 ; \ ba,a,pt %xcc, fault_32bit_##target ; \ ALIGN_128 @@ -581,24 +590,25 @@ SPILL(stxa, SPOFF, 8, asi) ; \ b spill_clean ; \ mov WSTATE_USER64, %g7 ; \ - .skip (31-25)*4 ; \ + .skip (31-26)*4 ; \ ba,a,pt %xcc, fault_64bit_##target ; \ ALIGN_128 #define fill_32bit_asi(asi, target) \ srl %sp, 0, %sp ; \ FILL(lda, 0, 4, asi) ; \ - saved ; \ + restored ; \ retry ; \ - .skip (31-26)*4 ; \ + .skip (31-27)*4 ; \ ba,a,pt %xcc, fault_32bit_##target ; \ ALIGN_128 #define fill_64bit_asi(asi, target) \ - FILL(ldxa, SPOFF, 8, asi) ; \ - saved ; \ + FILL(ldxa, SPOFF, 8, asi) ; \ + restored ; \ + MAGIC_TRAP_OFF ; \ retry ; \ - .skip (31-25)*4 ; \ + .skip (31-27)*4 ; \ ba,a,pt %xcc, fault_64bit_##target ; \ .align 128 @@ -623,11 +633,6 @@ .endm .macro spill_64bit_nucleus_not - mov %o0, %g6 - mov 0x23, %o0 - call hv_cnputchar - mov 0x24, %o0 - call hv_cnputchar spill_64bit_asi(ASI_N,not) .endm @@ -652,11 +657,6 @@ .endm .macro fill_64bit_nucleus_not - mov %o0, %g6 - mov 0x23, %o0 - call hv_cnputchar - mov 0x24, %o0 - call hv_cnputchar fill_64bit_asi(ASI_N, not) .endm @@ -694,6 +694,7 @@ .endm .macro spill_64bit_tt1_secondary_so1 + MAGIC_TRAP_ON ba,a,pt %xcc, fault_64bit_so1 nop .align 128 @@ -701,16 +702,17 @@ .endm .macro spill_mixed - nop + MAGIC_TRAP_ON .align 128 .endm .macro fill_mixed - nop + MAGIC_TRAP_ON .align 128 .endm .macro tl1_align + MAGIC_TRAP_ON .align 32 .endm @@ -1701,7 +1703,7 @@ .sect .trap .align 0x8000 - .globl tl0_base,tl0_insn_miss, tl0_insn_excptn, tl0_spill_n_normal + .globl tl0_base tl0_base: tl0_reserved 8 ! 0x0-0x7 tl0_insn_excptn: @@ -1741,44 +1743,52 @@ tl0_priv_action: tl0_gen T_PRIVILEGED_ACTION ! 0x37 tl0_reserved 9 ! 0x38-0x40 -tl0_intr_level: +tl0_intr_level_41: tl0_intr_level ! 0x41-0x4f tl0_reserved 18 ! 0x50-0x61 -tl0_watch_virt: +tl0_watch_virt_62: tl0_gen T_VA_WATCHPOINT ! 0x62 tl0_reserved 10 ! 0x63-0x6c -tl0_data_prot: +tl0_data_prot_6c: data_prot ! 0x6c tl0_reserved 8 ! 0x6d-0x75 -tl0_breakpoint: +tl0_breakpoint_76: tl0_gen T_BREAKPOINT ! 0x76 tl0_reserved 5 ! 0x77-0x7b -tl0_cpu_mondo: +tl0_cpu_mondo_7c: cpu_mondo ! 0x7c -tl0_dev_mondo: +tl0_dev_mondo_7d: dev_mondo ! 0x7d -tl0_resumable_error: +tl0_resumable_error_7e: resumable_error ! 0x7e -tl0_nonresumable_error: +tl0_nonresumable_error_7f: nonresumable_error ! 0x7f -tl0_spill_n_normal: +tl0_spill_n_normal_80: +tl0_spill_0_normal: tl0_reserved 4 ! 0x80 +tl0_spill_1_normal: spill_32bit_primary_sn0 ! 0x84 +tl0_spill_2_normal: spill_64bit_primary_sn0 ! 0x88 +tl0_spill_3_normal: spill_32clean_primary_sn0 ! 0x8c +tl0_spill_4_normal: spill_64clean_primary_sn0 ! 0x90 +tl0_spill_5_normal: spill_32bit_nucleus_not ! 0x94 +tl0_spill_6_normal: spill_64bit_nucleus_not ! 0x98 +tl0_spill_7_normal: spill_mixed ! 0x9c -tl0_spill_n_other: +tl0_spill_n_other_a0: tl0_reserved 4 ! 0xa0 spill_32bit_secondary_so0 ! 0xa4 spill_64bit_secondary_so0 ! 0xa8 spill_32bit_secondary_so0 ! 0xac spill_64bit_secondary_so0 ! 0xb0 tl0_reserved 12 ! 0xb4-0xbf -tl0_fill_n_normal: - tl0_reserved 4 ! 0xa0 +tl0_fill_n_normal_c0: + tl0_reserved 4 ! 0xc0 fill_32bit_primary_fn0 ! 0xc4 fill_64bit_primary_fn0 ! 0xc8 fill_32bit_primary_fn0 ! 0xcc @@ -1786,9 +1796,9 @@ fill_32bit_nucleus_not ! 0xd4 fill_64bit_nucleus_not ! 0xd8 fill_mixed ! 0xdc -tl0_fill_n_other: +tl0_fill_n_other_e0: tl0_reserved 32 ! 0xe0-0xff -tl0_soft: +tl0_soft_100: tl0_gen T_SYSCALL ! 0x100 tl0_gen T_BREAKPOINT ! 0x101 tl0_gen T_DIVISION_BY_ZERO ! 0x102 @@ -1823,16 +1833,16 @@ tl0_gen T_SYSCALL ! 0x142 tl0_gen T_SYSCALL ! 0x143 tl0_reserved 188 ! 0x144-0x1ff -tll_base: +tl1_base: tl1_reserved 9 ! 0x200-0x208 -tll_insn_miss: +tl1_insn_miss_209: insn_miss ! 0x209 tl1_reserved 27 ! 0x20a-0x224 -tl1_clean_window: +tl1_clean_window_224: clean_window ! 0x224 -tl1_divide: +tl1_divide_228: tl1_reserved 8 ! 0x228-0x22f -tl1_data_excptn: +tl1_data_excptn_230: data_excptn ! 0x230 data_miss ! 0x231 tl1_reserved 2 ! 0x232-0x233 @@ -1845,25 +1855,45 @@ tl1_nonresumable_error: nonresumable_error ! 0x27f tl1_spill_n_normal: +tl1_spill_0_normal: tl1_reserved 4 ! 0x280 +tl1_spill_1_normal: spill_32bit_tt1_primary_sn1 ! 0x284 +tl1_spill_2_normal: spill_64bit_tt1_primary_sn1 ! 0x288 +tl1_spill_3_normal: spill_32bit_tt1_primary_sn1 ! 0x28c +tl1_spill_4_normal: spill_64bit_tt1_primary_sn1 ! 0x290 - tl1_reserved ! 0x294 +tl1_spill_5_normal: + tl1_reserved 4 ! 0x294 +tl1_spill_6_normal: spill_64bit_ktt1_sk ! 0x298 +tl1_spill_7_normal: spill_mixed_ktt1_sk ! 0x29c tl1_spill_n_other: +tl1_spill_0_other: tl1_reserved 4 ! 0x2a0 +tl1_spill_1_other: spill_32bit_tt1_secondary_so1 ! 0x2a4 +tl1_spill_2_other: spill_64bit_tt1_secondary_so1 ! 0x2a8 +tl1_spill_3_other: spill_32bit_tt1_secondary_so1 ! 0x2ac +tl1_spill_4_other: spill_64bit_tt1_secondary_so1 ! 0x2b0 - tl1_reserved 12 ! 0x2b4-0x2bf +tl1_spill_5_other: + tl1_reserved 4 ! 0x2b4 +tl1_spill_6_other: + tl1_reserved 4 ! 0x2b8 +tl1_spill_7_other: + tl1_reserved 4 ! 0x2bc tl1_fill_n_normal: tl1_reserved 32 ! 0x2c0-0x2df tl1_fill_n_other: tl1_reserved 32 ! 0x2e0-0x2ff +tl1_soft_traps: + tl1_reserved 256 .globl tl0_end tl0_end: /*
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200603010802.k2182uVL008354>