Module Name:    src
Committed By:   skrll
Date:           Wed Nov  4 20:04:01 UTC 2020

Modified Files:
        src/sys/arch/riscv/riscv: trap.c vm_machdep.c

Log Message:
Miscellaneous updates to reflect riscv-privileged-20190608.pdf

Some from zmcgrew@


To generate a diff of this commit:
cvs rdiff -u -r1.12 -r1.13 src/sys/arch/riscv/riscv/trap.c
cvs rdiff -u -r1.3 -r1.4 src/sys/arch/riscv/riscv/vm_machdep.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/arch/riscv/riscv/trap.c
diff -u src/sys/arch/riscv/riscv/trap.c:1.12 src/sys/arch/riscv/riscv/trap.c:1.13
--- src/sys/arch/riscv/riscv/trap.c:1.12	Wed Nov  4 07:09:46 2020
+++ src/sys/arch/riscv/riscv/trap.c	Wed Nov  4 20:04:01 2020
@@ -1,4 +1,4 @@
-/*	$NetBSD: trap.c,v 1.12 2020/11/04 07:09:46 skrll Exp $	*/
+/*	$NetBSD: trap.c,v 1.13 2020/11/04 20:04:01 skrll Exp $	*/
 
 /*-
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
 #define __PMAP_PRIVATE
 #define __UFETCHSTORE_PRIVATE
 
-__RCSID("$NetBSD: trap.c,v 1.12 2020/11/04 07:09:46 skrll Exp $");
+__RCSID("$NetBSD: trap.c,v 1.13 2020/11/04 20:04:01 skrll Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -372,7 +372,7 @@ cpu_trap(struct trapframe *tf, register_
 {
 	const u_int fault_mask = 1U << cause;
 	const intptr_t addr = tval;
-	const bool usertrap_p = (status & SR_PS) == 0;
+	const bool usertrap_p = (status & SR_SPP) == 0;
 	bool ok = true;
 	ksiginfo_t ksi;
 

Index: src/sys/arch/riscv/riscv/vm_machdep.c
diff -u src/sys/arch/riscv/riscv/vm_machdep.c:1.3 src/sys/arch/riscv/riscv/vm_machdep.c:1.4
--- src/sys/arch/riscv/riscv/vm_machdep.c:1.3	Sat Mar 14 16:12:16 2020
+++ src/sys/arch/riscv/riscv/vm_machdep.c	Wed Nov  4 20:04:01 2020
@@ -1,4 +1,4 @@
-/*	$NetBSD: vm_machdep.c,v 1.3 2020/03/14 16:12:16 skrll Exp $	*/
+/*	$NetBSD: vm_machdep.c,v 1.4 2020/11/04 20:04:01 skrll Exp $	*/
 
 /*-
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vm_machdep.c,v 1.3 2020/03/14 16:12:16 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vm_machdep.c,v 1.4 2020/11/04 20:04:01 skrll Exp $");
 
 #define _PMAP_PRIVATE
 
@@ -91,7 +91,9 @@ cpu_lwp_fork(struct lwp *l1, struct lwp 
 	vaddr_t ua2 = uvm_lwp_getuarea(l2);
 	tf = (struct trapframe *)(ua2 + USPACE) - 1;
 	*tf = *l1->l_md.md_utf;
+#ifdef FPE
 	tf->tf_sr &= ~SR_EF;	/* floating point must be disabled */
+#endif
 
 	/* If specified, set a different user stack for a child. */
 	if (stack != NULL) {
@@ -114,12 +116,8 @@ cpu_lwp_fork(struct lwp *l1, struct lwp 
 	tf->tf_s0 = (intptr_t)func;			/* S0 */
 	tf->tf_s1 = (intptr_t)arg;			/* S1 */
 	tf->tf_ra = (intptr_t)cpu_lwp_trampoline;	/* RA */
-	l2->l_md.md_ktf = tf;					/* SP */
-	KASSERT(tf->tf_sr & SR_S);
-#ifdef _LP64
-	KASSERT(tf->tf_sr & SR_S64);
-#endif
-	KASSERT(tf->tf_sr & SR_EI);
+	l2->l_md.md_ktf = tf;				/* SP */
+	KASSERT(tf->tf_sr & SR_SIE);
 }
 
 /*

Reply via email to