Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 9 Mar 2006 08:04:43 GMT
From:      Kip Macy <kmacy@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 93021 for review
Message-ID:  <200603090804.k2984h2J067404@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=93021

Change 93021 by kmacy@kmacy_storage:sun4v_work on 2006/03/09 08:03:46

	add missing bits to support running as user
		- user_rtt: return to user mod
		- cpu_switch: handle new pmap structures
		- handle both user and kernel misses in tsb miss handler
	still need to connect up tl0_trap to transition to trap for demand fault

Affected files ...

.. //depot/projects/kmacy_sun4v/src/sys/sparc64/sparc64/genassym.c#8 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/include/asi.h#11 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/include/asmacros.h#6 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/include/mmu.h#2 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/include/pmap.h#7 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/include/sun4v_cpufunc.h#3 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/include/tsb.h#9 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/include/tte_hash.h#4 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/exception.S#21 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/hcall.S#5 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/machdep.c#9 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/pmap.c#19 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/support.S#9 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/swtch.S#8 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/tsb.c#8 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/tte.c#2 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/tte_hash.c#6 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/wbuf.S#2 edit

Differences ...

==== //depot/projects/kmacy_sun4v/src/sys/sparc64/sparc64/genassym.c#8 (text+ko) ====

@@ -118,6 +118,7 @@
 ASSYM(PAGE_SHIFT_8K, PAGE_SHIFT_8K);
 ASSYM(PAGE_SHIFT_4M, PAGE_SHIFT_4M);
 ASSYM(PAGE_SIZE, PAGE_SIZE);
+ASSYM(PAGE_SIZE_4M, PAGE_SIZE_4M);
 
 ASSYM(CPU_CLKSYNC, CPU_CLKSYNC);
 ASSYM(CPU_INIT, CPU_INIT);
@@ -182,11 +183,12 @@
 ASSYM(VTD_REF, VTD_REF);
 ASSYM(VTD_W, VTD_W);
 ASSYM(VTD_SW_W, VTD_SW_W);
-ASSYM(TTARGET_VA_BITS, TTARGET_VA_BITS);
-ASSYM(TTARGET_VA_SHIFT, TTARGET_VA_SHIFT);
-ASSYM(TTARGET_CTX_SHIFT, TTARGET_CTX_SHIFT);
 
 ASSYM(THE_SHIFT, THE_SHIFT);
+ASSYM(HVTSB_PA, offsetof(struct hv_tsb_info, hvtsb_pa));
+ASSYM(PM_HASHSCRATCH, offsetof(struct pmap, pm_hashscratch));
+ASSYM(PM_TSBSCRATCH, offsetof(struct pmap, pm_tsbscratch));
+ASSYM(PM_TSB_RA, offsetof(struct pmap, pm_tsb_ra));
 #endif
 
 ASSYM(V_INTR, offsetof(struct vmmeter, v_intr));
@@ -219,10 +221,9 @@
 ASSYM(PC_KWBUF_FULL, offsetof(struct pcpu, pc_kwbuf_full));
 ASSYM(PC_KWBUF_SP, offsetof(struct pcpu, pc_kwbuf_sp));
 ASSYM(PC_KWBUF, offsetof(struct pcpu, pc_kwbuf));
-
+ASSYM(PC_PMAP, offsetof(struct pcpu, pc_curpmap));
 #else
 ASSYM(PC_PMAP, offsetof(struct pcpu, pc_pmap));
-ASSYM(PM_TSB, offsetof(struct pmap, pm_tsb));
 #endif 
 
 
@@ -287,7 +288,7 @@
 ASSYM(VM_PMAP, offsetof(struct vmspace, vm_pmap));
 ASSYM(PM_ACTIVE, offsetof(struct pmap, pm_active));
 ASSYM(PM_CONTEXT, offsetof(struct pmap, pm_context));
-
+ASSYM(PM_TSB, offsetof(struct pmap, pm_tsb));
 
 ASSYM(SF_UC, offsetof(struct sigframe, sf_uc));
 

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/include/asi.h#11 (text+ko) ====

@@ -127,8 +127,10 @@
 
 #define SCRATCH_REG_MMFSA             ASI_SCRATCHPAD_0_REG
 #define SCRATCH_REG_PCPU              ASI_SCRATCHPAD_1_REG
-#define SCRATCH_REG_HASH              ASI_SCRATCHPAD_2_REG
-#define SCRATCH_REG_TSB               ASI_SCRATCHPAD_3_REG
+#define SCRATCH_REG_HASH_KERNEL       ASI_SCRATCHPAD_2_REG
+#define SCRATCH_REG_TSB_KERNEL        ASI_SCRATCHPAD_3_REG
+#define SCRATCH_REG_HASH_USER         ASI_SCRATCHPAD_6_REG
+#define SCRATCH_REG_TSB_USER          ASI_SCRATCHPAD_7_REG
 
 #define MMU_CID_P                     0x08
 #define MMU_CID_S                     0x10

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/include/asmacros.h#6 (text+ko) ====

@@ -135,21 +135,33 @@
 	mov  SCRATCH_REG_PCPU, PCPU_REG;    \
         ldxa [%g0 + PCPU_REG]ASI_SCRATCHPAD, PCPU_REG;
 
-#define GET_HASH_SCRATCH(reg)              \
-        mov SCRATCH_REG_HASH, reg;         \
+#define GET_HASH_SCRATCH_USER(reg)         \
+        mov SCRATCH_REG_HASH_USER, reg;    \
 	ldxa [%g0 + reg]ASI_SCRATCHPAD, reg;
 
-#define GET_TSB_SCRATCH(reg)              \
-        mov SCRATCH_REG_TSB, reg;         \
+#define GET_HASH_SCRATCH_KERNEL(reg)       \
+        mov SCRATCH_REG_HASH_KERNEL, reg;  \
+	ldxa [%g0 + reg]ASI_SCRATCHPAD, reg; 
+
+#define GET_TSB_SCRATCH_USER(reg)         \
+        mov SCRATCH_REG_TSB_USER, reg;    \
 	ldxa [%g0 + reg]ASI_SCRATCHPAD, reg;
 
-#define SET_HASH_SCRATCH(reg)      stxa reg, [%g0 + SCRATCH_REG_HASH]ASI_SCRATCHPAD
-#define SET_TSB_SCRATCH(reg)       stxa reg, [%g0 + SCRATCH_REG_TSB]ASI_SCRATCHPAD
+#define GET_TSB_SCRATCH_KERNEL(reg)	  \
+        mov SCRATCH_REG_TSB_KERNEL, reg;         \
+	ldxa [%g0 + reg]ASI_SCRATCHPAD, reg; 
+
+#define SET_SCRATCH(offsetreg, reg)   stxa reg, [%g0 + offsetreg]ASI_SCRATCHPAD
 
 #define GET_PCB(reg)	    \
         GET_PCPU_SCRATCH;   \
         ldx [PCPU_REG + PC_CURPCB], reg;
 
+#define SET_MMU_CONTEXT(typereg, reg)     stxa reg, [typereg]ASI_MMU_CONTEXTID
+#define GET_MMU_CONTEXT(typereg, reg)     ldxa [typereg]ASI_MMU_CONTEXTID, reg
+
+
+
 #define	SAVE_GLOBALS(TF) \
 	stx	%g1, [TF + TF_G1]; \
 	stx	%g2, [TF + TF_G2]; \

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/include/mmu.h#2 (text+ko) ====

@@ -76,19 +76,6 @@
 
 
 /*
- * MMU TAG ACCESS register Layout
- *
- * +-------------------------+------------------+
- * | virtual address [63:13] |  context [12:0]  |
- * +-------------------------+------------------+
- *  63			  13	12		0
- */
-#define	TAGACC_CTX_MASK		0x1FFF
-#define	TAGACC_SHIFT		13
-#define	TAGACC_VADDR_MASK	(~TAGACC_CTX_MASK)
-#define	TAGACC_CTX_LSHIFT	(64 - TAGACC_SHIFT)
-
-/*
  * MMU PRIMARY/SECONDARY CONTEXT register
  */
 #define	CTXREG_CTX_MASK		0x1FFF
@@ -103,6 +90,6 @@
  * FLUSH_ADDR is used in the flush instruction to guarantee stores to mmu
  * registers complete.  It is selected so it won't miss in the tlb.
  */
-#define	FLUSH_ADDR	(KERNELBASE + 2 * MMU_PAGESIZE4M)
+#define	FLUSH_ADDR	(KERNBASE + 2 * PAGE_SIZE_4M)
 
 #endif /* _MACHINE_MMU_H_ */

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/include/pmap.h#7 (text+ko) ====

@@ -59,12 +59,16 @@
 
 
 struct pmap {
+	uint64_t                pm_context;
+	uint64_t                pm_hashscratch;
+	uint64_t                pm_tsbscratch;
+	vm_paddr_t              pm_tsb_ra;
+
 	struct	mtx             pm_mtx;
 	struct tte_hash        *pm_hash;
 	TAILQ_HEAD(,pv_entry)	pm_pvlist;	/* list of mappings in pmap */
 	struct hv_tsb_info      pm_tsb;
 	cpumask_t               pm_active;
-	uint16_t                pm_context;
 	struct	pmap_statistics pm_stats;
 };
 

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/include/sun4v_cpufunc.h#3 (text+ko) ====

@@ -32,8 +32,11 @@
 #define	_MACHINE_SUN4V_CPUFUNC_H_
 #include <machine/hypervisor_api.h>
 void set_mmfsa_scratchpad(vm_paddr_t mmfsa);
-void set_hash_scratchpad(vm_offset_t hash);
-void set_tsb_scratchpad(vm_paddr_t tsb);
+
+void set_hash_user_scratchpad(uint64_t);
+void set_tsb_user_scratchpad(uint64_t);
+void set_hash_kernel_scratchpad(uint64_t);
+void set_tsb_kernel_scratchpad(uint64_t);
 
 
 static __inline void * 

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/include/tsb.h#9 (text+ko) ====

@@ -24,6 +24,10 @@
 struct hv_tsb_info;
 
 
+vm_paddr_t tsb_init(struct hv_tsb_info *tsb);
+
+void tsb_deinit(struct hv_tsb_info *tsb);
+
 void tsb_assert_invalid(struct hv_tsb_info *tsb, vm_offset_t va);
 
 void tsb_set_tte(struct hv_tsb_info *tsb, vm_offset_t va, tte_t tte_data, uint64_t ctx);
@@ -38,6 +42,8 @@
 
 void tsb_clear_range(struct hv_tsb_info *tsb, vm_offset_t sva, vm_offset_t eva);
 
-void tsb_set_scratchpad(struct hv_tsb_info *tsb);
+uint64_t tsb_set_scratchpad_kernel(struct hv_tsb_info *tsb);
+
+uint64_t tsb_set_scratchpad_user(struct hv_tsb_info *tsb);
 
 #endif /* !_MACHINE_TSB_H_ */

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/include/tte_hash.h#4 (text+ko) ====

@@ -20,7 +20,9 @@
 
 tte_t *tte_hash_lookup(tte_hash_t hash, vm_offset_t va);
 
-void tte_hash_set_scratchpad(tte_hash_t th);
+uint64_t tte_hash_set_scratchpad_kernel(tte_hash_t th);
+
+uint64_t tte_hash_set_scratchpad_user(tte_hash_t th);
 
 
 

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/exception.S#21 (text+ko) ====

@@ -45,7 +45,9 @@
 #include <machine/hypervisorvar.h>
 #include <machine/errata.h>
 
+
 #include "assym.s"
+#include <machine/mmu.h>
 
 #define PMAP_DEBUG
 #if 1
@@ -220,7 +222,13 @@
 
 	.macro	tl0_reserved	count
 	.rept	\count
+#if 0
 	tl0_gen	T_RESERVED
+#else
+	illtrap
+	.align	32
+#endif
+	
 	.endr
 	.endm
 
@@ -255,6 +263,7 @@
 
 	.macro	insn_excptn
 	MAGIC_TRAP_ON
+	MAGIC_TRAP_ON
 	illtrap
 	.align	32
 	.endm
@@ -888,7 +897,123 @@
 	add	%g1, 1, %g1					;\
 	wrpr	%g1, %cwp
 
-		
+
+	
+	
+ENTRY(utl0)
+	SAVE_GLOBALS(%l7)
+	SAVE_OUTS(%l7)
+	wrpr	%g0, PSTATE_KERNEL, %pstate	! enable ints
+	jmpl	%l3, %o7			! call trap handler
+	  mov	%l7, %o0
+
+ENTRY(user_rtt)
+	! pil handling needs to be re-visited
+	wrpr	%g0, PIL_TICK, %pil
+	ldx	[PCPU(CURTHREAD)], %l0
+	lduw	[%l0 + TD_FLAGS], %l1
+	set	TDF_ASTPENDING | TDF_NEEDRESCHED, %l2
+	and	%l1, %l2, %l1
+	brz,a,pt %l1, 1f
+	 nop
+
+	! handle AST and retry return
+	wrpr	%g0, 0, %pil
+	call	ast
+	  mov   %l7, %o0
+	ba,a,pt	%xcc, user_rtt
+	 nop
+
+1:	ldx	[PCB_REG + PCB_NSAVED], %l1
+	brz,a,pt %l1, 2f
+	  nop
+	wrpr	%g0, 0, %pil
+	mov	T_SPILL, %o0
+	stx	%o0, [%l7 + SPOFF + CCFSZ + TF_TYPE]
+	call	trap
+	  mov	%l7, %o0
+	ba,a	%xcc, user_rtt
+	 nop
+2:
+	ld	[%sp + SPOFF + TF_WSTATE], %l3	
+	!
+	! restore user globals and outs
+	!
+	rdpr	%pstate, %l1
+	wrpr	%l1, PSTATE_IE, %pstate
+	RESTORE_GLOBALS(%l7)
+	wrpr	%g0, 1, %gl
+	mov	%sp, %g6	! save tf pointer
+	RESTORE_OUTS(%l7)
+
+	wrpr	%g0, 0, %pil	! drop pil to 0
+
+	mov	MMU_CID_S, %g1
+	GET_MMU_CONTEXT(%g1, %g2)
+	mov	MMU_CID_S, %g1
+	sethi	%hi(FLUSH_ADDR), %g3
+	SET_MMU_CONTEXT(%g1, %g2)
+	flush	%g3				! flush required by immu
+						! hangover from US I
+	!
+	! setup trap regs
+	!
+	ldx	[%l7 + TF_TPC], %g1
+	ldx	[%l7 + TF_TNPC], %g2
+	ldx	[%l7 + TF_TSTATE], %l0
+	andn	%l0, TSTATE_CWP_MASK, %g4
+	wrpr	%g1, %tpc
+	wrpr	%g2, %tnpc
+
+#if 0
+	!
+	! switch "other" windows back to "normal" windows and
+	! restore to window we originally trapped in
+	!
+	rdpr	%otherwin, %g1
+	wrpr	%g0, 0, %otherwin
+	wrpr	%g0, %g1, %canrestore
+#endif
+	add	%l3, WSTATE_CLEAN_OFFSET, %l3	! convert to "clean" wstate
+	wrpr	%g0, %l3, %wstate
+
+	
+	rdpr	%canrestore, %g1
+	brnz	%g1, 3f
+	nop				! no trap, use restore directly
+	rdpr	%cwp, %g1
+	wrpr	%g1, %g7, %tstate	! needed by wbuf recovery code
+	! hand craft the restore to avoid getting to TL > 2
+	rdpr	%wstate, %g1
+	btst	1, %g1
+	beq	4f
+	nop
+	.global	rtt_fill_start
+rtt_fill_start:
+#if 0
+	fill_32bit_rtt(ASI_AIUP)
+	ba,a	3f
+#endif
+4:
+	fill_64bit_rtt(ASI_AIUP)
+	.global	rtt_fill_end
+rtt_fill_end:
+3:
+	restore				! should not trap
+2:
+	
+	!
+	! set %cleanwin to %canrestore
+	! set %tstate to the correct %cwp
+	! retry resumes user execution
+	!
+	rdpr	%canrestore, %g1
+	wrpr	%g0, %g1, %cleanwin
+	rdpr	%cwp, %g1
+	wrpr	%g1, %g7, %tstate
+	retry
+END(user_rtt)
+END(utl0)		
 
 ENTRY(ktl0)
 	SAVE_GLOBALS(%l7)
@@ -1052,25 +1177,34 @@
 	MAGIC_TRAP_ON
 	ldxa	[%g1 + %g7]ASI_REAL, %g6	! load in the context
 
-        srlx %g5, TTARGET_VA_SHIFT, %g1	
-	sllx %g6, TTARGET_CTX_SHIFT, %g6
-        or   %g6, %g1, %g6			! %g6 == search tag
+	cmp	%g6, %g0			! kernel?
+	be,pn	%xcc, 1f
+	  srlx	%g5, TTARGET_VA_SHIFT, %g1	
+	GET_HASH_SCRATCH_USER(%g2)
+	ba,pt	%xcc, 2f
+	  sllx	%g6, TTARGET_CTX_SHIFT, %g6
+1:	
+	GET_HASH_SCRATCH_KERNEL(%g2)
+	sllx	%g6, TTARGET_CTX_SHIFT, %g6
+2:	
+        or	%g6, %g1, %g6			! %g6 == search tag
+
+
+	
 
 	! %g4 == fault type %g5 == fault addr %g6 == tag
 	! XXX only handle normal miss for now (look at fault type in the future)
 #ifdef PMAP_DEBUG
 	cmp %g6, %g0			! NULL ptr deref in kernel
-	bne,pt %xcc, 4f
+	bne,pt %xcc, 3f
 	  nop
 tsb_miss_null_deref:	
 	illtrap				! give up
-4:	
+3:	
 #endif	
-        mov 1, %g7
-	sllx %g7, PAGE_SHIFT, %g7
+	sethi %hi(PAGE_MASK), %g7
 	sub %g7, 1, %g7			! %g7==PAGE_MASK
 
-	GET_HASH_SCRATCH(%g2)		! insn 2,3
 	and %g2, %g7, %g4		! size stored in lower 13 bits
 	andn %g2, %g7, %g2		! actual VA of hash
 
@@ -1093,57 +1227,58 @@
 tsb_miss_lookup_0:  
 	ldda [%g2 + %g0]ASI_LDTD_N, %g4
 	cmp %g4, %g0			! entry tag == 0 ?
-	be,pn %xcc, 1f
+	be,pn %xcc, 4f
 	  nop
 	cmp %g4, %g6			! entry tag == VA tag?
-	be,pn %xcc, 2f
+	be,pn %xcc, 5f
 	  nop
 	! entry 1
 tsb_miss_lookup_1:	
 	add %g2, 16, %g2		! next THF
 	ldda [%g2 + %g0]ASI_LDTD_N, %g4
 	cmp %g4, %g0			! entry tag == 0 ?
-	be,pn %xcc, 1f
+	be,pn %xcc, 4f
 	  nop
 	cmp %g4, %g6			! entry tag == search tag?
-	be,pn %xcc, 2f
+	be,pn %xcc, 5f
 	  nop
 	! entry 2
 tsb_miss_lookup_2:	
 	add %g2, 16, %g2		! next THF
 	ldda [%g2 + %g0]ASI_LDTD_N, %g4
 	cmp %g4, %g0			! entry tag == 0 ?
-	be,pn %xcc, 1f
+	be,pn %xcc, 4f
 	  nop
 	cmp %g4, %g6			! entry tag == search tag?
-	be,pn %xcc, 2f
+	be,pn %xcc, 5f
 	  nop
 	! entry 3
 tsb_miss_lookup_3:	
 	add %g2, 16, %g2		! next THF
 	ldda [%g2 + %g0]ASI_LDTD_N, %g4
 	cmp %g4, %g0			! entry tag == 0 ?
-	be,pn %xcc, 1f
+	be,pn %xcc, 4f
 	  nop
 	cmp %g4, %g6			! entry tag == search tag?
-	be,pn %xcc, 2f				
+	be,pn %xcc, 5f				
 	  nop
 tsb_miss_not_found:	
-1:	! not found
+4:	! not found
 	! we need to jump to tl0_trap to drop us back down to tl0
 	! and take us to trap(...) to service the fault
 	! skipping this step for the moment so we just do an illtrap
-	illtrap
+	ba	%xcc, tl0_trap
+	  mov   T_DATA_MISS, %g1
 	
 tsb_miss_found:	
-2:	!found
+5:	!found
 	! %g1 == abs index %g2 == THE pointer %g3 == flags
 	! %g4 == tag %g5 == data %g7 == PAGE_MASK
 	! %g3 <- TSB RA %g6 <- TSB size, TTE RA
+	srlx  %g6, TTARGET_CTX_SHIFT, %g6
 
-	! XXX set referenced/modified bit unconditionally for now XXX
 	andcc %g5, %g3, %g0			! already set
-	bnz,pt %xcc, 5f
+	bnz,pt %xcc, 7f
 	  nop
 	andcc %g3, VTD_REF, %g0			! TSB miss
 	bnz,pt %xcc, 6f
@@ -1153,12 +1288,17 @@
 	  or    %g5, %g3, %g5			! add ref/mod bit unconditionally  
 6:		
 	stx   %g5, [%g2 + 8]			! set ref/mod bit
-5:	
-	GET_TSB_SCRATCH(%g3)			! %g3 == TSB (RA)
-
-	
+7:
+	cmp	%g6, %g0			! kernel context?
+	be,pn	%xcc, 8f
+	  nop
+	GET_TSB_SCRATCH_USER(%g3)		! %g3 == TSB (RA)
+	ba,a,pt %xcc, 9f
+	  and  %g3, %g7, %g6			! size of TSB in pages
+8:	
+	GET_TSB_SCRATCH_KERNEL(%g3)		! %g3 == TSB (RA)
 	and  %g3, %g7, %g6			! size of TSB in pages
-	
+9:			
 	andn %g3, %g7, %g3			! TSB real address
 	sllx %g6, (PAGE_SHIFT - TTE_SHIFT), %g6	! nttes
 	subx %g6, 1, %g6			! TSB_MASK
@@ -1169,11 +1309,11 @@
 #ifdef PMAP_DEBUG
 	ldda [%g6]ASI_LDTD_REAL, %g2
 	cmp  %g3, %g5
-	bne,pt %xcc, 3f
+	bne,pt %xcc, 10f
 	  nop
 	illtrap					! die if all we're doing 
 						! is storing same data
-3:	
+10:	
 #endif
 	stxa %g4, [%g6]ASI_REAL			! store tag
 	stxa %g5, [%g6 + %g7]ASI_REAL		! store data
@@ -1211,6 +1351,8 @@
 ENTRY(prot_fault_trap)	
 	illtrap
 END(prot_fault_trap)
+
+
 /*
  * Freshly forked processes come here when switched to for the first time.
  * The arguments to fork_exit() have been setup in the locals, we must move
@@ -1233,7 +1375,7 @@
 	mov	%l1, %o1
 	call	fork_exit
 	 mov	%l2, %o2
-	ba,a	%xcc, tl0_ret
+	ba,a,pt	%xcc, user_rtt
 	 nop
 END(fork_trampoline)
 

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/hcall.S#5 (text+ko) ====

@@ -1377,6 +1377,7 @@
 bad_hcall_error:
 	.asciz	"hypervisor call 0x%x returned an unexpected error %d"
 
+	
 	ENTRY(panic_bad_hcall)
 	mov	%o0, %o2
 	sethi	%hi(bad_hcall_error), %o0
@@ -1398,6 +1399,21 @@
 	  nop
 	END(hv_magic_trap_off)
 
+
+	ENTRY(hv_sim_read)
+	mov	HVIO_SIM_READ, %o5
+	ta	FAST_TRAP
+	retl
+	  nop
+	END(hv_read)
+
+	ENTRY(hv_sim_write)
+	mov	HVIO_SIM_WRITE, %o5
+	ta	FAST_TRAP
+	retl
+	  nop
+	END(hv_write)
 	
 		
+		
 #endif	/* lint || __lint */

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/machdep.c#9 (text+ko) ====


==== //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/pmap.c#19 (text+ko) ====

@@ -354,7 +354,8 @@
 	oldpmap->pm_active &= ~1;
 	pmap->pm_active |= 1;
 #endif
-	tte_hash_set_scratchpad(pmap->pm_hash);
+	pmap->pm_hashscratch = tte_hash_set_scratchpad_user(pmap->pm_hash);
+	pmap->pm_tsbscratch = tsb_set_scratchpad_user(&pmap->pm_tsb);
 	PCPU_SET(curpmap, pmap);
 	critical_exit();
 }
@@ -479,7 +480,7 @@
 	kernel_pmap->pm_tsb.hvtsb_rsvd = 0;
 	kernel_pmap->pm_tsb.hvtsb_pa = pa;
 
-	tsb_set_scratchpad(&kernel_pmap->pm_tsb);
+	tsb_set_scratchpad_kernel(&kernel_pmap->pm_tsb);
 	
 	/*
 	 * Initialize kernel TSB for 4M pages
@@ -620,7 +621,7 @@
 	 * attempts to do updates until they're legal
 	 */
 	pm->pm_hash = tte_hash_kernel_create(kernel_hash, PAGE_SIZE_4M);
-	tte_hash_set_scratchpad(pm->pm_hash);
+	pm->pm_hashscratch = tte_hash_set_scratchpad_kernel(pm->pm_hash);
 
 	for (i = 0; i < sz; i++) {
 		if (translations[i].om_start < VM_MIN_PROM_ADDRESS ||
@@ -631,7 +632,7 @@
 		for (off = 0; off < translations[i].om_size; off += PAGE_SIZE) {
 			va = translations[i].om_start + off;
 			pa = TTE_GET_PA(translations[i].om_tte) + off;
-			tte_hash_insert(kernel_pmap->pm_hash, va, pa | TTE_KERNEL | VTD_8K);
+			tte_hash_insert(pm->pm_hash, va, pa | TTE_KERNEL | VTD_8K);
 		}
 	}
 }
@@ -665,15 +666,12 @@
 void
 pmap_clear_modify(vm_page_t m)
 {
-	/* XXX Need to also clear this in the TSB if possible :-( */
-	UNIMPLEMENTED;
 	tte_clear_phys_bit(m, VTD_W);
 }
 
 void
 pmap_clear_reference(vm_page_t m)
 {
-	UNIMPLEMENTED;
 	tte_clear_phys_bit(m, VTD_REF);
 }
 
@@ -1157,7 +1155,6 @@
 pmap_pinit0(pmap_t pmap)
 {
 	PMAP_LOCK_INIT(pmap);
-	pmap->pm_hash = NULL;
 	pmap->pm_active = 0;
 	pmap->pm_context = 0;
 	PCPU_SET(curpmap, pmap);
@@ -1180,6 +1177,7 @@
 		("max context limit hit - need to implement context recycling"));
 
 	pmap->pm_hash = tte_hash_create(pmap->pm_context);
+	pmap->pm_tsb_ra = tsb_init(&pmap->pm_tsb);
 	pmap->pm_active = 0;
 	TAILQ_INIT(&pmap->pm_pvlist);
 	bzero(&pmap->pm_stats, sizeof pmap->pm_stats);
@@ -1298,6 +1296,7 @@
 	    pmap->pm_stats.resident_count));
 
 	pmap_lazyfix(pmap);
+	tsb_deinit(&pmap->pm_tsb);
 	tte_hash_destroy(pmap->pm_hash);
 	PMAP_LOCK_DESTROY(pmap);
 }

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/support.S#9 (text+ko) ====

@@ -353,7 +353,7 @@
  * int copyin(const void *uaddr, void *kaddr, size_t len)
  */
 ENTRY(copyin)
-	wr	%g0, ASI_AIUP, %asi
+	wr	%g0, ASI_AIUS, %asi
 	_MEMCPY(%o1, %o0, %o2, E, E, a, %asi)
 	retl
 	 clr	%o0
@@ -363,7 +363,7 @@
  * int copyinstr(const void *uaddr, void *kaddr, size_t len, size_t *done)
  */
 ENTRY(copyinstr)
-	wr	%g0, ASI_AIUP, %asi
+	wr	%g0, ASI_AIUS, %asi
 	_COPYSTR(%o0, %o1, %o2, %o3, a, %asi, E, E)
 	retl
 	 mov	%g1, %o0
@@ -373,7 +373,7 @@
  * int copyout(const void *kaddr, void *uaddr, size_t len)
  */
 ENTRY(copyout)
-	wr	%g0, ASI_AIUP, %asi
+	wr	%g0, ASI_AIUS, %asi
 	_MEMCPY(%o1, %o0, %o2, a, %asi, E, E)
 	retl
 	 clr	%o0
@@ -412,7 +412,7 @@
  * int32_t casuword32(volatile int32_t *p, int32_t e, int32_t s)
  */
 ENTRY(casuword32)
-	casa	[%o0] ASI_AIUP, %o1, %o2
+	casa	[%o0] ASI_AIUS, %o1, %o2
 	retl
 	 mov	%o2, %o0
 END(casuword32)
@@ -421,7 +421,7 @@
  * int64_t casuword64(volatile int64_t *p, int64_t e, int64_t s)
  */
 ENTRY(casuword64)
-	casxa	[%o0] ASI_AIUP, %o1, %o2
+	casxa	[%o0] ASI_AIUS, %o1, %o2
 	retl
 	 mov	%o2, %o0
 END(casuword64)
@@ -431,7 +431,7 @@
  */
 ENTRY(fuword8)
 	retl
-	 lduba	[%o0] ASI_AIUP, %o0
+	 lduba	[%o0] ASI_AIUS, %o0
 END(fuword8)
 
 /*
@@ -439,7 +439,7 @@
  */
 ENTRY(fuword16)
 	retl
-	 lduha	[%o0] ASI_AIUP, %o0
+	 lduha	[%o0] ASI_AIUS, %o0
 END(fuword16)
 
 /*
@@ -447,7 +447,7 @@
  */
 ENTRY(fuword32)
 	retl
-	 lduwa	[%o0] ASI_AIUP, %o0
+	 lduwa	[%o0] ASI_AIUS, %o0
 END(fuword32)
 
 /*
@@ -455,14 +455,14 @@
  */
 ENTRY(fuword64)
 	retl
-	 ldxa	[%o0] ASI_AIUP, %o0
+	 ldxa	[%o0] ASI_AIUS, %o0
 END(fuword64)
 
 /*
  * int suword8(const void *base, int word)
  */
 ENTRY(suword8)
-	stba	%o1, [%o0] ASI_AIUP
+	stba	%o1, [%o0] ASI_AIUS
 	retl
 	 clr	%o0
 END(suword8)
@@ -471,7 +471,7 @@
  * int suword16(const void *base, int word)
  */
 ENTRY(suword16)
-	stha	%o1, [%o0] ASI_AIUP
+	stha	%o1, [%o0] ASI_AIUS
 	retl
 	 clr	%o0
 END(suword16)
@@ -480,7 +480,7 @@
  * int suword32(const void *base, int32_t word)
  */
 ENTRY(suword32)
-	stwa	%o1, [%o0] ASI_AIUP
+	stwa	%o1, [%o0] ASI_AIUS
 	retl
 	 clr	%o0
 END(suword32)
@@ -489,7 +489,7 @@
  * int suword64(const void *base, int64_t word)
  */
 ENTRY(suword64)
-	stxa	%o1, [%o0] ASI_AIUP
+	stxa	%o1, [%o0] ASI_AIUS
 	retl
 	 clr	%o0
 END(suword64)
@@ -503,14 +503,14 @@
  */
 ENTRY(fuswintr)
 	retl
-	 lduha	[%o0] ASI_AIUP, %o0
+	 lduha	[%o0] ASI_AIUS, %o0
 END(fuswintr)
 
 /*
  * int suswintr(const void *base, int word)
  */
 ENTRY(suswintr)
-	stha	%o1, [%o0] ASI_AIUP
+	stha	%o1, [%o0] ASI_AIUS
 	retl
 	 clr	%o0
 END(suswintr)
@@ -666,24 +666,37 @@
 	retl
 	  nop
 END(set_mmfsa_scratchpad)
-ENTRY(set_hash_scratchpad)
-	mov     SCRATCH_REG_HASH, %g2
+ENTRY(set_pcpu_scratchpad)
+	mov     SCRATCH_REG_PCPU, %g2
+	stxa	%o0, [%g0 + %g2]ASI_SCRATCHPAD
+	retl
+	  nop
+END(set_pcpu_scratchpad)
+ENTRY(set_hash_kernel_scratchpad)
+	mov     SCRATCH_REG_HASH_KERNEL, %g2
+	stxa	%o0, [%g0 + %g2]ASI_SCRATCHPAD
+	retl
+	  nop
+END(set_hash_kernel_scratchpad)
+ENTRY(set_tsb_kernel_scratchpad)
+	mov     SCRATCH_REG_TSB_KERNEL, %g2
 	stxa	%o0, [%g0 + %g2]ASI_SCRATCHPAD
 	retl
 	  nop
-END(set_hash_scratchpad)
-ENTRY(set_pcpu_scratchpad)
-	mov     SCRATCH_REG_PCPU, %g2
+END(set_tsb_kernel_scratchpad)
+
+ENTRY(set_hash_user_scratchpad)
+	mov     SCRATCH_REG_HASH_USER, %g2
 	stxa	%o0, [%g0 + %g2]ASI_SCRATCHPAD
 	retl
 	  nop
-END(set_pcpu_scratchpad)
-ENTRY(set_tsb_scratchpad)
-	mov     SCRATCH_REG_TSB, %g2
+END(set_hash_user_scratchpad)
+ENTRY(set_tsb_user_scratchpad)
+	mov     SCRATCH_REG_TSB_USER, %g2
 	stxa	%o0, [%g0 + %g2]ASI_SCRATCHPAD
 	retl
 	  nop
-END(set_hash_scratchpad)
+END(set_tsb_user_scratchpad)
 	
 		
 /*

==== //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/swtch.S#8 (text+ko) ====

@@ -27,10 +27,11 @@
 #include <machine/asm.h>
 __FBSDID("$FreeBSD: src/sys/sparc64/sparc64/swtch.S,v 1.33 2004/05/26 12:06:52 tmm Exp $");
 
+#include <machine/asi.h>
 #include <machine/asmacros.h>
-#include <machine/asi.h>
 #include <machine/ktr.h>
 #include <machine/tstate.h>
+#include <machine/hypervisorvar.h>
 
 #include "assym.s"
 
@@ -122,21 +123,24 @@
 	stx	%i1, [PCPU(CURPCB)]
 
 	wrpr	%g0, PSTATE_NORMAL, %pstate
-	mov	%i1, PCB_REG
+	mov	%i1, PCB_REG				! load in new PCB
 	wrpr	%g0, PSTATE_KERNEL, %pstate
 
+	/*
+	 *	End of saving old context
+	 *	Start of loading new context
+	 */
 	ldx	[PCB_REG + PCB_SP], %fp
 	ldx	[PCB_REG + PCB_PC], %i7
 	sub	%fp, CCFSZ, %sp
 
+
 	/*
 	 * Point to the pmaps of the new process, and of the last non-kernel
 	 * process to run.
 	 */
 	ldx	[%i0 + TD_PROC], %i2
-#if 0
 	ldx	[PCPU(PMAP)], %l2
-#endif
 	ldx	[%i2 + P_VMSPACE], %i5
 	add	%i5, VM_PMAP, %i2
 
@@ -147,108 +151,51 @@
 	stx	%l2, [%g1 + KTR_PARM2]
 9:
 #endif
-
 	/*
 	 * If they are the same we are done.
 	 */
-	cmp	%l2, %i2
+	cmp	%l2, %i2			! current pmap == new pmap?
 	be,a,pn %xcc, 5f
-	 nop
+	  nop
 
-	/*
-	 * If the new process is a kernel thread we can just leave the old
-	 * context active and avoid recycling its context number.
-	 */
-	SET(vmspace0, %i4, %i3)
-	cmp	%i5, %i3
-	be,a,pn %xcc, 5f
-	 nop
+	ldx	[%i2 + PM_CONTEXT], %l5		! new context == kernel?
+	cmp	%g0, %l5
+	be,a,pn	%xcc, 5f
+	  nop	
 
-	/*
-	 * If there was no non-kernel pmap, don't try to deactivate it.
-	 */
-	brz,a,pn %l2, 3f
-	 nop
+	MAGIC_TRAP_ON
+	mov	SCRATCH_REG_HASH_USER, %l6
+	mov	SCRATCH_REG_TSB_USER, %l7
+	ldx	[%i2 + PM_HASHSCRATCH], %l3	
+	ldx	[%i2 + PM_TSBSCRATCH], %l4
+	stx	%i2, [PCPU(PMAP)]
 
-	/*
-	 * Mark the pmap of the last non-kernel vmspace to run as no longer
-	 * active on this cpu.
-	 */
-	lduw	[%l2 + PM_ACTIVE], %l3
-	lduw	[PCPU(CPUMASK)], %l4
-	andn	%l3, %l4, %l3
-	stw	%l3, [%l2 + PM_ACTIVE]
+	SET_SCRATCH(%l6,%l3)			! XXX we're assuming the 
+	SET_SCRATCH(%l7,%l4)			! scratch values <= 32 bits
 
-	/*
-	 * Take away its context number.
-	 */
-	lduw	[PCPU(CPUID)], %l3
-	sllx	%l3, INT_SHIFT, %l3
-	add	%l2, PM_CONTEXT, %l4
-	mov	-1, %l5
-	stw	%l5, [%l3 + %l4]
 
-	/*
-	 * Find a new tlb context.  If we've run out we have to flush all user
-	 * mappings from the tlb and reset the context numbers.
-	 */
-3:	lduw	[PCPU(TLB_CTX)], %i3
-	lduw	[PCPU(TLB_CTX_MAX)], %i4
-	cmp	%i3, %i4
-	bne,a,pt %xcc, 4f
-	 nop
-	SET(invlctx, %i5, %i4)
-	ldx	[%i4], %i5
-	call	%i5
-	 nop
-	lduw	[PCPU(TLB_CTX_MIN)], %i3
+	ldx	[%i2 + PM_TSB_RA], %l3
 
-	/*
-	 * Advance next free context.
-	 */
-4:	add	%i3, 1, %i4
-	stw	%i4, [PCPU(TLB_CTX)]
+	mov	MMU_CID_S, %l6
 
-	/*

>>> TRUNCATED FOR MAIL (1000 lines) <<<



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200603090804.k2984h2J067404>