From 36e33a8ef05e3a13250d3c09d5c14977fa31b0a4 Mon Sep 17 00:00:00 2001
From: Ruslan Bukin
Date: Fri, 17 Jan 2020 16:48:20 +0000
Subject: [PATCH] Use unsigned loads in fubyte, fuword16, generic_bs_r_1,
generic_bs_r_2 as these functions should do zero-extend.
Discovered by running pci_read_cap(), and by hint from James Clarke.
Reviewed by: James Clarke
Sponsored by: DARPA, AFRL
Differential Revision: https://reviews.freebsd.org/D23236
---
sys/riscv/riscv/bus_space_asm.S | 6 +++---
sys/riscv/riscv/support.S | 6 +++---
2 files changed, 6 insertions(+), 6 deletions(-)
diff --git a/sys/riscv/riscv/bus_space_asm.S b/sys/riscv/riscv/bus_space_asm.S
index 95e94ed040bc..6b65b7c4e785 100644
--- a/sys/riscv/riscv/bus_space_asm.S
+++ b/sys/riscv/riscv/bus_space_asm.S
@@ -1,5 +1,5 @@
/*-
- * Copyright (c) 2016 Ruslan Bukin
+ * Copyright (c) 2016-2020 Ruslan Bukin
* All rights reserved.
*
* Portions of this software were developed by SRI International and the
@@ -38,13 +38,13 @@ __FBSDID("$FreeBSD$");
ENTRY(generic_bs_r_1)
add a3, a1, a2
- lb a0, 0(a3)
+ lbu a0, 0(a3)
ret
END(generic_bs_r_1)
ENTRY(generic_bs_r_2)
add a3, a1, a2
- lh a0, 0(a3)
+ lhu a0, 0(a3)
ret
END(generic_bs_r_2)
diff --git a/sys/riscv/riscv/support.S b/sys/riscv/riscv/support.S
index 1de905fdf843..3f0ec08ac768 100644
--- a/sys/riscv/riscv/support.S
+++ b/sys/riscv/riscv/support.S
@@ -1,5 +1,5 @@
/*-
- * Copyright (c) 2015-2018 Ruslan Bukin
+ * Copyright (c) 2015-2020 Ruslan Bukin
* All rights reserved.
*
* Portions of this software were developed by SRI International and the
@@ -102,7 +102,7 @@ ENTRY(fubyte)
la a6, fsu_fault /* Load the fault handler */
SET_FAULT_HANDLER(a6, a1) /* And set it */
ENTER_USER_ACCESS(a1)
- lb a0, 0(a0) /* Try loading the data */
+ lbu a0, 0(a0) /* Try loading the data */
EXIT_USER_ACCESS(a1)
SET_FAULT_HANDLER(x0, a1) /* Reset the fault handler */
ret /* Return */
@@ -117,7 +117,7 @@ ENTRY(fuword16)
la a6, fsu_fault /* Load the fault handler */
SET_FAULT_HANDLER(a6, a1) /* And set it */
ENTER_USER_ACCESS(a1)
- lh a0, 0(a0) /* Try loading the data */
+ lhu a0, 0(a0) /* Try loading the data */
EXIT_USER_ACCESS(a1)
SET_FAULT_HANDLER(x0, a1) /* Reset the fault handler */
ret /* Return */