summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/hppa/hppa/locore.S98
-rw-r--r--sys/arch/hppa/hppa/pmap.c14
-rw-r--r--sys/arch/hppa/include/cpu.h18
3 files changed, 100 insertions, 30 deletions
diff --git a/sys/arch/hppa/hppa/locore.S b/sys/arch/hppa/hppa/locore.S
index 949a9aa63a7..6996a70fee1 100644
--- a/sys/arch/hppa/hppa/locore.S
+++ b/sys/arch/hppa/hppa/locore.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.S,v 1.34 2000/06/05 12:58:29 art Exp $ */
+/* $OpenBSD: locore.S,v 1.35 2000/07/02 02:41:57 mickey Exp $ */
/*
* Copyright (c) 1998-2000 Michael Shalayeff
@@ -159,10 +159,9 @@ ENTRY($start)
copy arg3, t2
ldi NBPG+TF_SIZE, t1
$start_zero_tf
- stw r0, 0(t2)
- stw r0, 4(t2)
+ stws,ma r0, 4(t2)
addib,>= -8, t1, $start_zero_tf
- ldo 8(t2), t2
+ stws,ma r0, 4(t2) /* XXX could use ,bc here, but gas is broken */
/*
* kernel stack lives here (arg3 is page-aligned esym)
@@ -344,7 +343,7 @@ pdc_call_unmapped1
ldw HPPA_FRAME_ARG(7)(r1), t2
ldw HPPA_FRAME_ARG(8)(r1), t3
ldw HPPA_FRAME_ARG(9)(r1), t4
- stw t1, HPPA_FRAME_ARG(4)(sp)
+ stw t1, HPPA_FRAME_ARG(4)(sp) /* XXX can use ,bc */
stw t2, HPPA_FRAME_ARG(5)(sp)
stw t3, HPPA_FRAME_ARG(6)(sp)
stw t4, HPPA_FRAME_ARG(7)(sp)
@@ -362,7 +361,7 @@ pdc_call_unmapped1
mfctl cr25, t2
mfctl cr26, t3
mfctl cr27, t4
- stw t1, HPPA_FRAME_ARG(12)(sp)
+ stw t1, HPPA_FRAME_ARG(12)(sp) /* XXX can use ,bc */
stw t2, HPPA_FRAME_ARG(13)(sp)
stw t3, HPPA_FRAME_ARG(14)(sp)
stw t4, HPPA_FRAME_ARG(15)(sp)
@@ -518,10 +517,11 @@ $syscall
* stack contains a print of some past trapframe, so
* we do not save hard to get information, but do restore
* the whole context later on return anyway.
+ * XXXXXX this is very bad. everything must be saved
*/
ldil L%curproc, t3
ldw R%curproc(sr1, t3), t3
- ldw p_addr(sr1, t3), t2
+ ldw p_addr(sr1, t3), t2 /* XXX can use ,sl */
/* calculate kernel sp, load, create kernel stack frame */
copy sp, t4
@@ -537,13 +537,29 @@ $syscall
* will be saved accordingly in either syscall()
* or deeper called functions
*/
- stw r3 , TF_R3 -TF_SIZE(sr1, t3)
stw r27, TF_R27-TF_SIZE(sr1, t3) /* dp */
+ stw r3 , TF_R3 -TF_SIZE(sr1, t3)
#ifdef DDB
- stw r0, 0(t3) /* terminate frame */
+ /* save callee-save registers */
+ stw r4, 1*4(sr1, t3)
+ stw r5, 2*4(sr1, t3)
+ stw r6, 3*4(sr1, t3)
+ stw r7, 4*4(sr1, t3)
+ stw r8, 5*4(sr1, t3)
+ stw r9, 6*4(sr1, t3)
+ stw r10, 7*4(sr1, t3)
+ stw r11, 8*4(sr1, t3)
+ stw r12, 9*4(sr1, t3)
+ stw r13, 10*4(sr1, t3)
+ stw r14, 11*4(sr1, t3)
+ stw r15, 12*4(sr1, t3)
+ stw r16, 13*4(sr1, t3)
+ stw r17, 14*4(sr1, t3)
+ stw r18, 15*4(sr1, t3)
+ stw r0, 0(sr1, t3) /* terminate frame */
copy r0 , r3
- stw r0, HPPA_FRAME_PSP(sp)
- stw r0, HPPA_FRAME_CRP(sp)
+ stw r0, HPPA_FRAME_PSP(sr1, sp)
+ stw r0, HPPA_FRAME_CRP(sr1, sp)
#endif
/*
@@ -555,7 +571,7 @@ $syscall
* we keep it at 10, since bundling will keep it
* at the same speed as 9 anyway.
*/
- stw arg0, 1*4(sr1, t3)
+ stw arg0, 1*4(sr1, t3) /* XXX can use ,bc */
stw arg1, 2*4(sr1, t3)
stw arg2, 3*4(sr1, t3)
stw arg3, 4*4(sr1, t3)
@@ -1202,7 +1218,7 @@ $tlbd_t
* the correct mapping or NULL.
*/
ldw hpt_entry(r16), r24
-$hash_loop_tlbd_t
+$hash_loop_tlbd_t /* XXX must use ,sl */
comb,=,n r0, r24, TLABEL(all)
ldw pv_va(r24), r25
ldw pv_space(r24), r17
@@ -1255,7 +1271,7 @@ $tlb_gottalook_t
*/
ldw hpt_entry(r24),r24
$hash_loop_t
- comb,=,n r0, r24, TLABEL(all)
+ comb,=,n r0, r24, $tlbiflpa
ldw pv_va(r24),r25
ldw pv_space(r24),r17
comb,<>,n r9,r25,$hash_loop_t
@@ -1352,7 +1368,7 @@ $tlbmiss_l
*/
ldw hpt_entry(r16),r24
$hash_loop_l
- comb,=,n r0, r24, TLABEL(all)
+ comb,=,n r0, r24, $tlbiflpa
ldw pv_va(r24),r25
ldw pv_space(r24),r17
comb,<>,n r9,r25,$hash_loop_l
@@ -1392,6 +1408,58 @@ $tlb_itlb_l
rfir
nop
+$tlbiflpa
+ ldi T_DTLBMISSNA, r16
+ comb,<>,n r1, r16, TLABEL(all)
+ mfctl iir, r17
+ extru r17, 5, 6, r16
+ comib,<>,n 1, r16, TLABEL(all)
+ ldi 0x4d, r25
+ extru r17, 25, 8, r16
+ comb,<>,n r25, r16, TLABEL(all)
+
+ /* ok, this is a miss in LPA */
+ mfctl ipsw, r16
+ depi 1, PSW_N_POS, 1, r16
+ depi 0, 26, 27, r17
+ mtctl r16, ipsw
+
+ ldi $tlbiflpa_zr, r25
+ bv r17(r25)
+$tlbiflpa_zr
+ copy r0, r0 ! rfir
+ copy r0, r1 ! rfir
+ copy r0, r2 ! rfir
+ copy r0, r3 ! rfir
+ copy r0, r4 ! rfir
+ copy r0, r5 ! rfir
+ copy r0, r6 ! rfir
+ copy r0, r7 ! rfir
+ copy r0, r8 ! rfir
+ copy r0, r9 ! rfir
+ copy r0, r10 ! rfir
+ copy r0, r11 ! rfir
+ copy r0, r12 ! rfir
+ copy r0, r13 ! rfir
+ copy r0, r14 ! rfir
+ copy r0, r15 ! rfir
+ copy r0, r16 ! rfir
+ copy r0, r17 ! rfir
+ copy r0, r18 ! rfir
+ copy r0, r19 ! rfir
+ copy r0, r20 ! rfir
+ copy r0, r21 ! rfir
+ copy r0, r22 ! rfir
+ copy r0, r23 ! rfir
+ copy r0, r24 ! rfir
+ copy r0, r25 ! rfir
+ copy r0, r26 ! rfir
+ copy r0, r27 ! rfir
+ copy r0, r28 ! rfir
+ copy r0, r29 ! rfir
+ copy r0, r30 ! rfir
+ copy r0, r31 ! rfir
+
.export $tlb_missend, entry
$tlb_missend
diff --git a/sys/arch/hppa/hppa/pmap.c b/sys/arch/hppa/hppa/pmap.c
index df199cbfdf6..13ecb5dd838 100644
--- a/sys/arch/hppa/hppa/pmap.c
+++ b/sys/arch/hppa/hppa/pmap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.c,v 1.32 2000/01/17 06:51:58 mickey Exp $ */
+/* $OpenBSD: pmap.c,v 1.33 2000/07/02 02:41:57 mickey Exp $ */
/*
* Copyright (c) 1998-2000 Michael Shalayeff
@@ -1609,18 +1609,6 @@ pmap_kremove(va, size)
pmap_remove(kernel_pmap, va, va + size);
}
-int
-kvtop(va)
- caddr_t va;
-{
- if ((vaddr_t)va < virtual_avail)
- return (int)va;
- else if ((vaddr_t)va >= HPPA_IOBEGIN)
- return (int)va;
- else
- return (int)pmap_extract(pmap_kernel(), (vaddr_t)va);
-}
-
#if defined(PMAPDEBUG) && defined(DDB)
#include <ddb/db_output.h>
/*
diff --git a/sys/arch/hppa/include/cpu.h b/sys/arch/hppa/include/cpu.h
index 7c10ee800f3..c274cc0b127 100644
--- a/sys/arch/hppa/include/cpu.h
+++ b/sys/arch/hppa/include/cpu.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.h,v 1.15 2000/06/15 19:11:24 mickey Exp $ */
+/* $OpenBSD: cpu.h,v 1.16 2000/07/02 02:41:56 mickey Exp $ */
/*
* Copyright (c) 2000 Michael Shalayeff
@@ -77,6 +77,12 @@ extern const char *cpu_typename;
#endif
/*
+ * COPR/SFUs
+ */
+#define HPPA_FPUS 0xc0
+#define HPPA_PMSFUS 0x20 /* ??? */
+
+/*
* Exported definitions unique to hp700/PA-RISC cpu support.
*/
@@ -122,12 +128,20 @@ extern const char *cpu_typename;
#define DELAY(x) delay(x)
+static __inline long
+kvtop (const caddr_t va)
+{
+ long ret;
+ /* XXX will it keep page offset ok? */
+ __asm __volatile ("lpa %%r0(%0), %1" : "=r" (ret) : "r" (va));
+ return ret;
+}
+
extern int (*cpu_desidhash) __P((void));
void delay __P((u_int us));
void hppa_init __P((paddr_t start));
void trap __P((int type, struct trapframe *frame));
-int kvtop __P((const caddr_t va));
int dma_cachectl __P((caddr_t p, int size));
int spcopy __P((pa_space_t ssp, const void *src,
pa_space_t dsp, void *dst, size_t size));