Browse Source

Revert "support for S-mode interrupts"

This reverts commit 41c50dd49e0077db3701f7a8210d3c9f8e6ff3ca.
Román Cárdenas 1 year ago
parent
commit
4ad4cfdbff
6 changed files with 53 additions and 118 deletions
  1. 2 6
      .github/workflows/riscv.yaml
  2. 0 4
      riscv/CHANGELOG.md
  3. 0 1
      riscv/Cargo.toml
  4. 2 9
      riscv/src/critical_section.rs
  5. 49 91
      riscv/src/interrupt.rs
  6. 0 7
      riscv/src/lib.rs

+ 2 - 6
.github/workflows/riscv.yaml

@@ -1,6 +1,6 @@
 on:
   push:
-    branches: [ master, riscv-pac ]
+    branches: [ master ]
   pull_request:
   merge_group:
 
@@ -31,12 +31,8 @@ jobs:
       with:
         toolchain: ${{ matrix.toolchain }}
         targets: ${{ matrix.target }}
-    - name: Build (M-mode)
+    - name: Build (no features)
       run: cargo build --package riscv --target ${{ matrix.target }}
-    - name: Build (M-mode, critical section)
-      run: cargo build --package riscv --target ${{ matrix.target }} --features=critical-section-single-hart
-    - name: Build (S-mode)
-      run: cargo build --package riscv --target ${{ matrix.target }} --features=s-mode
     - name: Build (all features)
       run: cargo build --package riscv --target ${{ matrix.target }} --all-features
 

+ 0 - 4
riscv/CHANGELOG.md

@@ -9,8 +9,6 @@ and this project adheres to [Semantic Versioning](http://semver.org/).
 
 ### Added
 
-- `s-mode` feature for reexporting `machine::supervisor` or `interrupt::supervisor` to `interrupt`
-- Support for supervisor-level interrupts in `interrupt::supervisor`
 - Add CI workflow to check that CHANGELOG.md file has been modified in PRs
 - Add `read_csr_as_rv32`, `set_rv32`, and `clear_rv32` macros
 - Add `mstatus::uxl` and `mstatus::sxl`
@@ -22,8 +20,6 @@ and this project adheres to [Semantic Versioning](http://semver.org/).
 
 ### Changed
 
-- `critical-section` implementation depends on `s-mode` feature
-- machine-level interrupt functions moved to `interrupt::machine`
 - Cargo workspace for riscv and riscv-rt
 - Update `embedded-hal` dependency to v1.0.0-rc.2 (bumps MSRV to 1.60)
 - `misa::MXL` renamed to `misa::XLEN`

+ 0 - 1
riscv/Cargo.toml

@@ -20,7 +20,6 @@ targets = [
 ]
 
 [features]
-s-mode = []
 critical-section-single-hart = ["critical-section/restore-state-bool"]
 
 [dependencies]

+ 2 - 9
riscv/src/critical_section.rs

@@ -1,23 +1,16 @@
 use critical_section::{set_impl, Impl, RawRestoreState};
 
 use crate::interrupt;
+use crate::register::mstatus;
 
 struct SingleHartCriticalSection;
 set_impl!(SingleHartCriticalSection);
 
 unsafe impl Impl for SingleHartCriticalSection {
-    #[cfg(not(feature = "s-mode"))]
     unsafe fn acquire() -> RawRestoreState {
         let mut mstatus: usize;
         core::arch::asm!("csrrci {}, mstatus, 0b1000", out(reg) mstatus);
-        core::mem::transmute::<_, crate::register::mstatus::Mstatus>(mstatus).mie()
-    }
-
-    #[cfg(feature = "s-mode")]
-    unsafe fn acquire() -> RawRestoreState {
-        let mut sstatus: usize;
-        core::arch::asm!("csrrci {}, sstatus, 0b0010", out(reg) sstatus);
-        core::mem::transmute::<_, crate::register::sstatus::Sstatus>(sstatus).sie()
+        core::mem::transmute::<_, mstatus::Mstatus>(mstatus).mie()
     }
 
     unsafe fn release(was_active: RawRestoreState) {

+ 49 - 91
riscv/src/interrupt.rs

@@ -1,105 +1,63 @@
 //! Interrupts
 
 // NOTE: Adapted from cortex-m/src/interrupt.rs
-
-pub mod machine {
-    use crate::register::mstatus;
-
-    /// Disables all interrupts in the current hart (machine mode).
-    #[inline]
-    pub fn disable() {
-        unsafe { mstatus::clear_mie() }
-    }
-
-    /// Enables all the interrupts in the current hart (machine mode).
-    ///
-    /// # Safety
-    ///
-    /// Do not call this function inside a critical section.
-    #[inline]
-    pub unsafe fn enable() {
-        mstatus::set_mie()
-    }
-
-    /// Execute closure `f` with interrupts disabled in the current hart (machine mode).
-    ///
-    /// This method does not synchronise multiple harts, so it is not suitable for
-    /// using as a critical section. See the `critical-section` crate for a cross-platform
-    /// way to enter a critical section which provides a `CriticalSection` token.
-    ///
-    /// This crate provides an implementation for `critical-section` suitable for single-hart systems,
-    /// based on disabling all interrupts. It can be enabled with the `critical-section-single-hart` feature.
-    #[inline]
-    pub fn free<F, R>(f: F) -> R
-    where
-        F: FnOnce() -> R,
-    {
-        let mstatus = mstatus::read();
-
-        // disable interrupts
-        disable();
-
-        let r = f();
-
-        // If the interrupts were active before our `disable` call, then re-enable
-        // them. Otherwise, keep them disabled
-        if mstatus.mie() {
-            unsafe { enable() };
-        }
-
-        r
+use crate::register::mstatus;
+
+/// Disables all interrupts in the current hart.
+#[inline]
+pub unsafe fn disable() {
+    match () {
+        #[cfg(riscv)]
+        () => mstatus::clear_mie(),
+        #[cfg(not(riscv))]
+        () => unimplemented!(),
     }
 }
-pub mod supervisor {
-    use crate::register::sstatus;
 
-    /// Disables all interrupts in the current hart (supervisor mode).
-    #[inline]
-    pub fn disable() {
-        unsafe { sstatus::clear_sie() }
+/// Enables all the interrupts in the current hart.
+///
+/// # Safety
+///
+/// - Do not call this function inside a critical section.
+#[inline]
+pub unsafe fn enable() {
+    match () {
+        #[cfg(riscv)]
+        () => mstatus::set_mie(),
+        #[cfg(not(riscv))]
+        () => unimplemented!(),
     }
+}
 
-    /// Enables all the interrupts in the current hart (supervisor mode).
-    ///
-    /// # Safety
-    ///
-    /// Do not call this function inside a critical section.
-    #[inline]
-    pub unsafe fn enable() {
-        sstatus::set_sie()
-    }
-
-    /// Execute closure `f` with interrupts disabled in the current hart (supervisor mode).
-    ///
-    /// This method does not synchronise multiple harts, so it is not suitable for
-    /// using as a critical section. See the `critical-section` crate for a cross-platform
-    /// way to enter a critical section which provides a `CriticalSection` token.
-    ///
-    /// This crate provides an implementation for `critical-section` suitable for single-hart systems,
-    /// based on disabling all interrupts. It can be enabled with the `critical-section-single-hart` feature.
-    #[inline]
-    pub fn free<F, R>(f: F) -> R
-    where
-        F: FnOnce() -> R,
-    {
-        let sstatus = sstatus::read();
-
-        // disable interrupts
+/// Execute closure `f` with interrupts disabled in the current hart.
+///
+/// This method does not synchronise multiple harts, so it is not suitable for
+/// using as a critical section. See the `critical-section` crate for a cross-platform
+/// way to enter a critical section which provides a `CriticalSection` token.
+///
+/// This crate provides an implementation for `critical-section` suitable for single-hart systems,
+/// based on disabling all interrupts. It can be enabled with the `critical-section-single-hart` feature.
+#[inline]
+pub fn free<F, R>(f: F) -> R
+where
+    F: FnOnce() -> R,
+{
+    let mstatus = mstatus::read();
+
+    // disable interrupts
+    unsafe {
         disable();
+    }
 
-        let r = f();
+    let r = f();
 
-        // If the interrupts were active before our `disable` call, then re-enable
-        // them. Otherwise, keep them disabled
-        if sstatus.sie() {
-            unsafe { enable() };
+    // If the interrupts were active before our `disable` call, then re-enable
+    // them. Otherwise, keep them disabled
+    if mstatus.mie() {
+        unsafe {
+            enable();
         }
-
-        r
     }
-}
 
-#[cfg(not(feature = "s-mode"))]
-pub use machine::*;
-#[cfg(feature = "s-mode")]
-pub use supervisor::*;
+    r
+}

+ 0 - 7
riscv/src/lib.rs

@@ -15,17 +15,10 @@
 //!
 //! # Optional features
 //!
-//! ## `s-mode`
-//!
-//! This feature re-exports in `interrupt` S-mode interrupt functions defined in `interrupt::supervisor`.
-//! By default, the crate assumes that the target is running in M-mode.
-//! Thus, `interrupt` re-exports the M-mode functions defined in `interrupt::machine`.
-//!
 //! ## `critical-section-single-hart`
 //!
 //! This feature enables a [`critical-section`](https://github.com/rust-embedded/critical-section)
 //! implementation suitable for single-hart targets, based on disabling interrupts globally.
-//! This feature uses S-mode interrupt handling if the `s-mode` feature is enabled, and M-mode otherwise.
 //!
 //! It is **unsound** to enable it on multi-hart targets,
 //! and may cause functional problems in systems where some interrupts must NOT be disabled