summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2006-07-09 19:41:24 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2006-07-09 19:41:24 +0000
commit57fc2ecaf5a260923bb5d4bbd1822131d07f9e70 (patch)
treeb55d71dc08cbf58ccbbe46bddc2c58f4ec916d07 /sys/arch
parent503aeb1e9f38fa52d04ce019d8354815d5d13ed7 (diff)
If running on a 68030 or 68040 system, use the transparent translation
registers to program an 1GB untranslated window over the physical memory, and use it to define __HAVE_PMAP_DIRECT for faster pool operation.
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/hp300/hp300/locore.s40
-rw-r--r--sys/arch/hp300/include/pmap.h8
-rw-r--r--sys/arch/hp300/include/vmparam.h5
3 files changed, 40 insertions, 13 deletions
diff --git a/sys/arch/hp300/hp300/locore.s b/sys/arch/hp300/hp300/locore.s
index 0d508bab1bb..d47e2593cc9 100644
--- a/sys/arch/hp300/hp300/locore.s
+++ b/sys/arch/hp300/hp300/locore.s
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.s,v 1.57 2006/06/24 13:20:17 miod Exp $ */
+/* $OpenBSD: locore.s,v 1.58 2006/07/09 19:41:21 miod Exp $ */
/* $NetBSD: locore.s,v 1.91 1998/11/11 06:41:25 thorpej Exp $ */
/*
@@ -545,7 +545,7 @@ Lmmu_enable:
.long 0x4e7b1807 | movc d1,srp
jra Lstploaddone
Lmotommu1:
- RELOC(protorp, a0)
+ ASRELOC(protorp, a0)
movl #0x80000202,a0@ | nolimit + share global + 4 byte PTEs
movl d1,a0@(4) | + segtable address
pmove a0@,srp | load the supervisor root pointer
@@ -590,8 +590,18 @@ Lhighcode:
moveq #0,d0 | ensure TT regs are disabled
.long 0x4e7b0004 | movc d0,itt0
.long 0x4e7b0005 | movc d0,itt1
- .long 0x4e7b0006 | movc d0,dtt0
.long 0x4e7b0007 | movc d0,dtt1
+
+ /*
+ * Set up transparent translation for supervisor data access.
+ * The range 0xc0000000-0xffffffff will not be translated, and
+ * thus yields a 1:1 mapping of the physical memory in the top
+ * of the address space (as long as we don't have more than
+ * 1GB of memory, which will be very unlikely...)
+ */
+ movl #0xc03fa000,d0
+ .long 0x4e7b0006 | movc d0,dtt0
+
.word 0xf4d8 | cinva bc
.word 0xf518 | pflusha
movl #0x8000,d0
@@ -600,9 +610,19 @@ Lhighcode:
movc d0,cacr | turn on both caches
jmp Lenab1
Lmotommu2:
+ cmpl #MMU_68030,a0@ | 68030?
+ jne Lmotommu2b | no, skip
+ /*
+ * Set up transparent translation for supervisor data access
+ * (FC == 5), similar to the 68040 logic above.
+ */
+ ASRELOC(mmuscratch, a2)
+ movl #0xc03f8150,a2@ | build our TT0 value
+ .long 0xf0120800 | pmove a2@,tt0
+Lmotommu2b:
movl #MMU_IEN+MMU_FPE,INTIOBASE+MMUBASE+MMUCMD
- | enable 68881 and i-cache
- RELOC(prototc, a2)
+ | enable MMU and i-cache
+ ASRELOC(mmuscratch, a2)
movl #0x82c0aa00,a2@ | value to load TC with
pmove a2@,tc | load it
jmp Lenab1
@@ -1831,7 +1851,7 @@ ENTRY(loadustp)
LmotommuC:
#endif
pflusha | flush entire TLB
- lea _C_LABEL(protorp),a0 | CRP prototype
+ lea _ASM_LABEL(protorp),a0 | CRP prototype
movl d0,a0@(4) | stash USTP
pmove a0@,crp | load root pointer
movl #CACHE_CLR,d0
@@ -2046,16 +2066,14 @@ GLOBAL(ectype)
GLOBAL(fputype)
.long FPU_68882 | default to 68882 FPU
-#if defined(M68K_MMU_HP)
GLOBAL(pmap_aliasmask)
.long 0
-#endif
-GLOBAL(protorp)
+ASLOCAL(protorp)
.long 0,0 | prototype root pointer
-GLOBAL(prototc)
- .long 0 | prototype translation control
+ASLOCAL(mmuscratch)
+ .long 0 | scratch space for 68851/68030 MMU operation
GLOBAL(internalhpib)
.long 1 | has internal HP-IB, default to yes
diff --git a/sys/arch/hp300/include/pmap.h b/sys/arch/hp300/include/pmap.h
index 1c134b9078f..9f3fd2bcdaf 100644
--- a/sys/arch/hp300/include/pmap.h
+++ b/sys/arch/hp300/include/pmap.h
@@ -1,10 +1,16 @@
-/* $OpenBSD: pmap.h,v 1.14 2002/03/14 01:26:31 millert Exp $ */
+/* $OpenBSD: pmap.h,v 1.15 2006/07/09 19:41:23 miod Exp $ */
#ifndef _MACHINE_PMAP_H_
#define _MACHINE_PMAP_H_
#include <m68k/pmap_motorola.h>
+#if !defined(M68020)
+#define pmap_map_direct(pg) ((vaddr_t)VM_PAGE_TO_PHYS(pg))
+#define pmap_unmap_direct(va) PHYS_TO_VM_PAGE((paddr_t)va)
+#define __HAVE_PMAP_DIRECT
+#endif
+
#ifdef _KERNEL
void pmap_init_md(void);
#define PMAP_INIT_MD() pmap_init_md()
diff --git a/sys/arch/hp300/include/vmparam.h b/sys/arch/hp300/include/vmparam.h
index 67d96869377..c583866ff7c 100644
--- a/sys/arch/hp300/include/vmparam.h
+++ b/sys/arch/hp300/include/vmparam.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: vmparam.h,v 1.16 2006/06/04 17:20:38 miod Exp $ */
+/* $OpenBSD: vmparam.h,v 1.17 2006/07/09 19:41:23 miod Exp $ */
/* $NetBSD: vmparam.h,v 1.16 1998/08/20 08:33:48 kleink Exp $ */
/*
@@ -48,6 +48,9 @@
#include <m68k/vmparam.h>
+#undef VM_MAX_KERNEL_ADDRESS
+#define VM_MAX_KERNEL_ADDRESS (0xc0000000 - PAGE_SIZE)
+
/*
* Constants which control the way the VM system deals with memory segments.
* The hp300 only has one physical memory segment.