Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 23 Jan 2008 22:54:33 GMT
From:      Warner Losh <imp@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 133959 for review
Message-ID:  <200801232254.m0NMsXfQ023746@repoman.freebsd.org>

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

Change 133959 by imp@imp_paco-paco on 2008/01/23 22:53:42

	Convert tlb.S over to new school.  Chances are these macros would
	be useful to have in a header file...

Affected files ...

.. //depot/projects/mips2-jnpr/src/sys/mips/mips/tlb.S#4 edit
.. //depot/projects/mips2-jnpr/src/sys/mips/mips/tlb32.S#3 delete

Differences ...

==== //depot/projects/mips2-jnpr/src/sys/mips/mips/tlb.S#4 (text+ko) ====

@@ -55,6 +55,8 @@
  *	assembly language support routines.
  */
 
+#include "opt_cputype.h"
+
 #include <machine/asm.h>
 #include <machine/cpu.h>
 #include <machine/cpuregs.h>
@@ -63,8 +65,37 @@
 
 #include "assym.s"
 
+#if defined(ISA_MIPS32)
+#undef WITH_64BIT_CP0
+#elif defined(ISA_MIPS64)
+#define WITH_64BIT_CP0
+#elif defined(ISA_MIPS3)
+#define WITH_64BIT_CP0
+#else
+#error "Please write the code for this ISA"
+#endif
+
+#ifdef WITH_64BIT_CP0
+#define _SLL	dsll
+#define	_SRL	dsrl
+#define	_MFC0	dmfc0
+#define	_MTC0	dmtc0
+#define WIRED_SHIFT 34
+#else
+#define _SLL	sll
+#define	_SRL	srl
+#define	_MFC0	mfc0
+#define	_MTC0	mtc0
+#define WIRED_SHIFT 2
+#endif
 	.set	noreorder			# Noreorder is default style!
+#if defined(ISA_MIPS32)
+	.set	mips32
+#elif defined(ISA_MIPS64)
+	.set	mips64
+#elif defined(ISA_MIPS3)
 	.set	mips3
+#endif
 
 #define	ITLBNOPFIX	nop;nop;nop;nop;nop;nop;nop;nop;nop;nop;
 
@@ -94,22 +125,22 @@
 	ITLBNOPFIX
 	lw	a2, 8(a1)
 	lw	a3, 12(a1)
-	dmfc0	t0, COP_0_TLB_HI		# Save the current PID.
+	_MFC0	t0, COP_0_TLB_HI		# Save the current PID.
 
-	dmtc0	a2, COP_0_TLB_LO0		# Set up entry low0.
-	dmtc0	a3, COP_0_TLB_LO1		# Set up entry low1.
+	_MTC0	a2, COP_0_TLB_LO0		# Set up entry low0.
+	_MTC0	a3, COP_0_TLB_LO1		# Set up entry low1.
 	lw	a2, 0(a1)
 	lw	a3, 4(a1)
 	mtc0	a0, COP_0_TLB_INDEX		# Set the index.
-	dmtc0	a2, COP_0_TLB_PG_MASK		# Set up entry mask.
-	dmtc0	a3, COP_0_TLB_HI		# Set up entry high.
+	_MTC0	a2, COP_0_TLB_PG_MASK		# Set up entry mask.
+	_MTC0	a3, COP_0_TLB_HI		# Set up entry high.
 	MIPS_CPU_NOP_DELAY
 	tlbwi					# Write the TLB
 	MIPS_CPU_NOP_DELAY
 
-	dmtc0	t0, COP_0_TLB_HI		# Restore the PID.
+	_MTC0	t0, COP_0_TLB_HI		# Restore the PID.
 	nop
-	dmtc0	zero, COP_0_TLB_PG_MASK		# Default mask value.
+	_MTC0	zero, COP_0_TLB_PG_MASK		# Default mask value.
 	mtc0	v1, COP_0_STATUS_REG		# Restore the status register
 	ITLBNOPFIX
 	j	ra
@@ -131,7 +162,7 @@
  *--------------------------------------------------------------------------
  */
 LEAF(Mips_SetPID)
-	dmtc0	a0, COP_0_TLB_HI		# Write the hi reg value
+	_MTC0	a0, COP_0_TLB_HI		# Write the hi reg value
 	nop					# required for QED5230
 	nop					# required for QED5230
 	j	ra
@@ -200,11 +231,11 @@
 	ITLBNOPFIX
 	mfc0	t1, COP_0_TLB_WIRED
 	li	v0, MIPS_KSEG0_START		# invalid address
-	dmfc0	t0, COP_0_TLB_HI		# Save the PID
+	_MFC0	t0, COP_0_TLB_HI		# Save the PID
 
-	dmtc0	v0, COP_0_TLB_HI		# Mark entry high as invalid
-	dmtc0	zero, COP_0_TLB_LO0		# Zero out low entry0.
-	dmtc0	zero, COP_0_TLB_LO1		# Zero out low entry1.
+	_MTC0	v0, COP_0_TLB_HI		# Mark entry high as invalid
+	_MTC0	zero, COP_0_TLB_LO0		# Zero out low entry0.
+	_MTC0	zero, COP_0_TLB_LO1		# Zero out low entry1.
 	mtc0	zero, COP_0_TLB_PG_MASK 	# Zero out mask entry.
 /*
  * Align the starting value (t1) and the upper bound (a0).
@@ -218,7 +249,7 @@
 	bne	t1, a0, 1b
 	nop
 
-	dmtc0	t0, COP_0_TLB_HI		# Restore the PID
+	_MTC0	t0, COP_0_TLB_HI		# Restore the PID
 	mtc0	v1, COP_0_STATUS_REG		# Restore the status register
 	ITLBNOPFIX
 	j	ra
@@ -246,9 +277,9 @@
 	ITLBNOPFIX
 	li	v0, (PG_HVPN | PG_ASID)
 	and	a0, a0, v0			# Make shure valid hi value.
-	dmfc0	t0, COP_0_TLB_HI		# Get current PID
+	_MFC0	t0, COP_0_TLB_HI		# Get current PID
 	mfc0	t3, COP_0_TLB_PG_MASK		# Save current pgMask
-	dmtc0	a0, COP_0_TLB_HI		# look for addr & PID
+	_MTC0	a0, COP_0_TLB_HI		# look for addr & PID
 	MIPS_CPU_NOP_DELAY
 	tlbp					# Probe for the entry.
 	MIPS_CPU_NOP_DELAY
@@ -256,15 +287,15 @@
 	li	t1, MIPS_KSEG0_START		# Load invalid entry.
 	bltz	v0, 1f				# index < 0 => !found
 	nop
-	dmtc0	t1, COP_0_TLB_HI		# Mark entry high as invalid
+	_MTC0	t1, COP_0_TLB_HI		# Mark entry high as invalid
 
-	dmtc0	zero, COP_0_TLB_LO0		# Zero out low entry.
-	dmtc0	zero, COP_0_TLB_LO1		# Zero out low entry.
+	_MTC0	zero, COP_0_TLB_LO0		# Zero out low entry.
+	_MTC0	zero, COP_0_TLB_LO1		# Zero out low entry.
 	MIPS_CPU_NOP_DELAY
 	tlbwi
 	MIPS_CPU_NOP_DELAY
 1:
-	dmtc0	t0, COP_0_TLB_HI		# restore PID
+	_MTC0	t0, COP_0_TLB_HI		# restore PID
 	mtc0	t3, COP_0_TLB_PG_MASK		# Restore pgMask
 	mtc0	v1, COP_0_STATUS_REG		# Restore the status register
 	ITLBNOPFIX
@@ -293,13 +324,13 @@
 	and	t1, a0, 0x1000			# t1 = Even/Odd flag
 	li	v0, (PG_HVPN | PG_ASID)
 	and	a0, a0, v0
-	dmfc0	t0, COP_0_TLB_HI		# Save current PID
-	dmtc0	a0, COP_0_TLB_HI		# Init high reg
+	_MFC0	t0, COP_0_TLB_HI		# Save current PID
+	_MTC0	a0, COP_0_TLB_HI		# Init high reg
 	and	a2, a1, PG_G			# Copy global bit
 	MIPS_CPU_NOP_DELAY
 	tlbp					# Probe for the entry.
-	dsll	a1, a1, 34
-	dsrl	a1, a1, 34
+	_SLL	a1, a1, WIRED_SHIFT
+	_SRL	a1, a1, WIRED_SHIFT
 	nop
 	mfc0	v0, COP_0_TLB_INDEX		# See what we got
 	bne	t1, zero, 2f			# Decide even odd
@@ -310,16 +341,16 @@
 
 	tlbr					# update, read entry first
 	MIPS_CPU_NOP_DELAY
-	dmtc0	a1, COP_0_TLB_LO0		# init low reg0.
+	_MTC0	a1, COP_0_TLB_LO0		# init low reg0.
 	MIPS_CPU_NOP_DELAY
 	tlbwi					# update slot found
 	b	4f
 	nop
 1:
 	mtc0	zero, COP_0_TLB_PG_MASK 	# init mask.
-	dmtc0	a0, COP_0_TLB_HI		# init high reg.
-	dmtc0	a1, COP_0_TLB_LO0		# init low reg0.
-	dmtc0	a2, COP_0_TLB_LO1		# init low reg1.
+	_MTC0	a0, COP_0_TLB_HI		# init high reg.
+	_MTC0	a1, COP_0_TLB_LO0		# init low reg0.
+	_MTC0	a2, COP_0_TLB_LO1		# init low reg1.
 	MIPS_CPU_NOP_DELAY
 	tlbwr					# enter into a random slot
 	MIPS_CPU_NOP_DELAY
@@ -333,7 +364,7 @@
 
 	tlbr					# read the entry first
 	MIPS_CPU_NOP_DELAY
-	dmtc0	a1, COP_0_TLB_LO1		# init low reg1.
+	_MTC0	a1, COP_0_TLB_LO1		# init low reg1.
 	MIPS_CPU_NOP_DELAY
 	tlbwi					# update slot found
 	MIPS_CPU_NOP_DELAY
@@ -341,15 +372,15 @@
 	nop
 3:
 	mtc0	zero, COP_0_TLB_PG_MASK		# init mask.
-	dmtc0	a0, COP_0_TLB_HI		# init high reg.
-	dmtc0	a2, COP_0_TLB_LO0		# init low reg0.
-	dmtc0	a1, COP_0_TLB_LO1		# init low reg1.
+	_MTC0	a0, COP_0_TLB_HI		# init high reg.
+	_MTC0	a2, COP_0_TLB_LO0		# init low reg0.
+	_MTC0	a1, COP_0_TLB_LO1		# init low reg1.
 	MIPS_CPU_NOP_DELAY
 	tlbwr					# enter into a random slot
 
 4:						# Make shure pipeline
 	MIPS_CPU_NOP_DELAY
-	dmtc0	t0, COP_0_TLB_HI		# restore PID
+	_MTC0	t0, COP_0_TLB_HI		# restore PID
 	mtc0	v1, COP_0_STATUS_REG		# Restore the status register
 	ITLBNOPFIX
 	j	ra
@@ -374,17 +405,17 @@
 	mfc0	v1, COP_0_STATUS_REG		# Save the status register.
 	mtc0	zero, COP_0_STATUS_REG		# Disable interrupts
 	ITLBNOPFIX
-	dmfc0	t0, COP_0_TLB_HI		# Get current PID
+	_MFC0	t0, COP_0_TLB_HI		# Get current PID
 
 	mtc0	a0, COP_0_TLB_INDEX		# Set the index register
 	MIPS_CPU_NOP_DELAY
 	tlbr					# Read from the TLB
 	MIPS_CPU_NOP_DELAY
 	mfc0	t2, COP_0_TLB_PG_MASK		# fetch the hi entry
-	dmfc0	t3, COP_0_TLB_HI		# fetch the hi entry
-	dmfc0	t4, COP_0_TLB_LO0		# See what we got
-	dmfc0	t5, COP_0_TLB_LO1		# See what we got
-	dmtc0	t0, COP_0_TLB_HI		# restore PID
+	_MFC0	t3, COP_0_TLB_HI		# fetch the hi entry
+	_MFC0	t4, COP_0_TLB_LO0		# See what we got
+	_MFC0	t5, COP_0_TLB_LO1		# See what we got
+	_MTC0	t0, COP_0_TLB_HI		# restore PID
 	MIPS_CPU_NOP_DELAY
 	mtc0	v1, COP_0_STATUS_REG		# Restore the status register
 	ITLBNOPFIX
@@ -408,7 +439,7 @@
  *--------------------------------------------------------------------------
  */
 LEAF(Mips_TLBGetPID)
-	dmfc0	v0, COP_0_TLB_HI		# get PID
+	_MFC0	v0, COP_0_TLB_HI		# get PID
 	j	ra
 	and	v0, v0, VMTLB_PID		# mask off PID
 END(Mips_TLBGetPID)
@@ -428,7 +459,7 @@
 	mfc0	v1, COP_0_STATUS_REG		# save status register
 	mtc0	zero, COP_0_STATUS_REG		# disable interrupts
 
-	dmfc0	t4, COP_0_TLB_HI		# Get current PID
+	_MFC0	t4, COP_0_TLB_HI		# Get current PID
 	move	t2, a0
 	mfc0	t1, COP_0_TLB_WIRED
 	li	v0, MIPS_KSEG0_START		# invalid address
@@ -440,14 +471,14 @@
 	MIPS_CPU_NOP_DELAY
 	tlbr					# obtain an entry
 	MIPS_CPU_NOP_DELAY
-	dmfc0	a0, COP_0_TLB_LO1
+	_MFC0	a0, COP_0_TLB_LO1
 	and	a0, a0, PG_G			# check to see it has G bit
 	bnez	a0, 2f
 	nop
 
-	dmtc0	v0, COP_0_TLB_HI		# make entryHi invalid
-	dmtc0	zero, COP_0_TLB_LO0		# zero out entryLo0
-	dmtc0	zero, COP_0_TLB_LO1		# zero out entryLo1
+	_MTC0	v0, COP_0_TLB_HI		# make entryHi invalid
+	_MTC0	zero, COP_0_TLB_LO0		# zero out entryLo0
+	_MTC0	zero, COP_0_TLB_LO1		# zero out entryLo1
 	mtc0	zero, COP_0_TLB_PG_MASK		# zero out mask entry
 	MIPS_CPU_NOP_DELAY
 	tlbwi					# invalidate the TLB entry
@@ -456,7 +487,7 @@
 	bne	t1, t2, 1b
 	nop
 
-	dmtc0	t4, COP_0_TLB_HI		# restore PID
+	_MTC0	t4, COP_0_TLB_HI		# restore PID
 	mtc0	t3, COP_0_TLB_PG_MASK		# restore pgMask
 	MIPS_CPU_NOP_DELAY
 	mtc0	v1, COP_0_STATUS_REG		# restore status register



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