From 9b1b3d6f90a91a24f70a252e77a37a9ce3f709b3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rom=C3=A1n=20C=C3=A1rdenas=20Rodr=C3=ADguez?= Date: Wed, 9 Oct 2024 23:03:05 +0200 Subject: [PATCH 1/8] cortex-m-pac crate --- Cargo.toml | 1 + cortex-m-pac/CHANGELOG.md | 8 ++ cortex-m-pac/Cargo.toml | 24 ++++ cortex-m-pac/README.md | 40 ++++++ cortex-m-pac/src/lib.rs | 264 +++++++++++++++++++++++++++++++++++++ cortex-m-pac/src/result.rs | 58 ++++++++ 6 files changed, 395 insertions(+) create mode 100644 cortex-m-pac/CHANGELOG.md create mode 100644 cortex-m-pac/Cargo.toml create mode 100644 cortex-m-pac/README.md create mode 100644 cortex-m-pac/src/lib.rs create mode 100644 cortex-m-pac/src/result.rs diff --git a/Cargo.toml b/Cargo.toml index 059853a0..c8624efa 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -2,6 +2,7 @@ resolver = "2" members = [ "cortex-m", + "cortex-m-pac", "cortex-m-rt", "cortex-m-semihosting", "panic-itm", diff --git a/cortex-m-pac/CHANGELOG.md b/cortex-m-pac/CHANGELOG.md new file mode 100644 index 00000000..c07d965a --- /dev/null +++ b/cortex-m-pac/CHANGELOG.md @@ -0,0 +1,8 @@ +# Change Log + +All notable changes to this project will be documented in this file. + +The format is based on [Keep a Changelog](http://keepachangelog.com/) +and this project adheres to [Semantic Versioning](http://semver.org/). + +## [Unreleased] diff --git a/cortex-m-pac/Cargo.toml b/cortex-m-pac/Cargo.toml new file mode 100644 index 00000000..ad72f5bc --- /dev/null +++ b/cortex-m-pac/Cargo.toml @@ -0,0 +1,24 @@ +[package] +name = "cortex-m-pac" +version = "0.1.0" +edition = "2021" +rust-version = "1.60" +repository = "https://github.com/rust-embedded/cortex-m" +authors = ["The Cortex-M Team ",] +categories = ["embedded", "hardware-support", "no-std"] +description = "Low level access to Cortex-M processors" +documentation = "https://docs.rs/cortex-m-pac" +keywords = ["arm", "cortex-m", "register", "peripheral"] +license = "MIT OR Apache-2.0" +readme = "README.md" + +[package.metadata.docs.rs] +targets = [ + "thumbv8m.main-none-eabihf", + "thumbv6m-none-eabi", + "thumbv7em-none-eabi", + "thumbv7em-none-eabihf", + "thumbv7m-none-eabi", + "thumbv8m.base-none-eabi", + "thumbv8m.main-none-eabi" +] diff --git a/cortex-m-pac/README.md b/cortex-m-pac/README.md new file mode 100644 index 00000000..a48faee7 --- /dev/null +++ b/cortex-m-pac/README.md @@ -0,0 +1,40 @@ +[![crates.io](https://img.shields.io/crates/d/cortex-m-pac.svg)](https://crates.io/crates/cortex-m-pac) +[![crates.io](https://img.shields.io/crates/v/cortex-m-pac.svg)](https://crates.io/crates/cortex-m-pac) + +# `cortex-m-pac` + +> Target-specific traits to be implemented by PACs + +This project is developed and maintained by the [Cortex-M team][team]. + +## [Documentation](https://docs.rs/crate/cortex-m-pac) + +## Minimum Supported Rust Version (MSRV) + +This crate is guaranteed to compile on stable Rust 1.60 and up. It *might* +compile with older versions but that may change in any new patch release. + +## License + +Copyright 2024 [Cortex-M team][team] + +Permission to use, copy, modify, and/or distribute this software for any purpose +with or without fee is hereby granted, provided that the above copyright notice +and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH +REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND +FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS +OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER +TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF +THIS SOFTWARE. + +## Code of Conduct + +Contribution to this crate is organized under the terms of the [Rust Code of +Conduct][CoC], the maintainer of this crate, the [Cortex-M team][team], promises +to intervene to uphold that code of conduct. + +[CoC]: CODE_OF_CONDUCT.md +[team]: https://github.com/rust-embedded/wg#the-cortex-m-team diff --git a/cortex-m-pac/src/lib.rs b/cortex-m-pac/src/lib.rs new file mode 100644 index 00000000..ea175ce5 --- /dev/null +++ b/cortex-m-pac/src/lib.rs @@ -0,0 +1,264 @@ +#![no_std] + +pub mod result; + +use result::Result; + +/// Trait for enums of target-specific exception numbers. +/// +/// This trait should be implemented by a peripheral access crate (PAC) on its enum of available +/// exceptions for a specific device. Alternatively, the `cortex-m` crate provides a default +/// implementation. Each variant must convert to a `usize` of its exception number. +/// +/// # Safety +/// +/// * This trait must only be implemented on the `cortex-m` crate or on a PAC of a Cortex-M target. +/// * This trait must only be implemented on enums of exceptions. +/// * Each enum variant must represent a distinct value (no duplicates are permitted), +/// * Each enum variant must always return the same value (do not change at runtime). +/// * All the exception numbers must be less than or equal to `MAX_EXCEPTION_NUMBER`. +/// * `MAX_EXCEPTION_NUMBER` must coincide with the highest allowed exception number. +pub unsafe trait ExceptionNumber: Copy { + /// Highest number assigned to an exception. + const MAX_EXCEPTION_NUMBER: usize; + + /// Converts an exception to its corresponding number. + fn number(self) -> usize; + + /// Tries to convert a number to a valid exception. + fn from_number(value: usize) -> Result; +} + +/// Trait for enums of target-specific interrupt numbers. +/// +/// This trait should be implemented by a peripheral access crate (PAC) on its enum of available +/// interrupts for a specific device. Each variant must convert to a `usize` of its interrupt number. +/// +/// # Safety +/// +/// * This trait must only be implemented on a PAC of a Cortex-M target. +/// * This trait must only be implemented on enums of interrupts. +/// * Each enum variant must represent a distinct value (no duplicates are permitted), +/// * Each enum variant must always return the same value (do not change at runtime). +/// * All the interrupt numbers must be less than or equal to `MAX_INTERRUPT_NUMBER`. +/// * `MAX_INTERRUPT_NUMBER` must coincide with the highest allowed interrupt number. +pub unsafe trait InterruptNumber: Copy { + /// Highest number assigned to an interrupt source. + const MAX_INTERRUPT_NUMBER: usize; + + /// Converts an interrupt source to its corresponding number. + fn number(self) -> usize; + + /// Tries to convert a number to a valid interrupt. + fn from_number(value: usize) -> Result; +} + +/// Trait for enums of priority levels. +/// +/// This trait should be implemented by a peripheral access crate (PAC) on its enum of available +/// priority numbers for a specific device. Each variant must convert to a `usize` of its priority level. +/// +/// # Safety +/// +/// * This trait must only be implemented on a PAC of a Cortex-M target. +/// * This trait must only be implemented on enums of priority levels. +/// * Each enum variant must represent a distinct value (no duplicates are permitted). +/// * Each enum variant must always return the same value (do not change at runtime). +/// * All the priority level numbers must be less than or equal to `MAX_PRIORITY_NUMBER`. +/// * `MAX_PRIORITY_NUMBER` must coincide with the highest allowed priority number. +pub unsafe trait PriorityNumber: Copy { + /// Number assigned to the highest priority level. + const MAX_PRIORITY_NUMBER: usize; + + /// Converts a priority level to its corresponding number. + fn number(self) -> usize; + + /// Tries to convert a number to a valid priority level. + fn from_number(value: usize) -> Result; +} + +/// Trait for enums of core identifiers. +/// +/// This trait should be implemented by a peripheral access crate (PAC) on its enum of available +/// cores for a specific device. Each variant must convert to a `usize` of its core ID number. +/// +/// # Safety +/// +/// * This trait must only be implemented on a PAC of a Cortex-M target. +/// * This trait must only be implemented on enums of core IDs. +/// * Each enum variant must represent a distinct value (no duplicates are permitted), +/// * Each anum variant must always return the same value (do not change at runtime). +/// * All the core ID numbers must be less than or equal to `MAX_CORE_ID_NUMBER`. +/// * `MAX_CORE_ID_NUMBER` must coincide with the highest allowed core ID number. +pub unsafe trait CoreIdNumber: Copy { + /// Highest number assigned to a core. + const MAX_CORE_ID_NUMBER: usize; + + /// Converts a Core ID to its corresponding number. + fn number(self) -> usize; + + /// Tries to convert a number to a valid Core ID. + fn from_number(value: usize) -> Result; +} + +#[cfg(test)] +mod test { + use super::*; + use crate::result::Error; + + #[derive(Clone, Copy, Debug, Eq, PartialEq)] + enum Exception { + E1 = 1, + E3 = 3, + } + + #[derive(Clone, Copy, Debug, Eq, PartialEq)] + enum Interrupt { + I1 = 1, + I2 = 2, + I4 = 4, + } + + #[derive(Clone, Copy, Debug, Eq, PartialEq)] + enum Priority { + P0 = 0, + P1 = 1, + P2 = 2, + P3 = 3, + } + + #[derive(Clone, Copy, Debug, Eq, PartialEq)] + enum CoreId { + H0 = 0, + H1 = 1, + H2 = 2, + } + + unsafe impl ExceptionNumber for Exception { + const MAX_EXCEPTION_NUMBER: usize = Self::E3 as usize; + + #[inline] + fn number(self) -> usize { + self as _ + } + + #[inline] + fn from_number(number: usize) -> Result { + match number { + 1 => Ok(Exception::E1), + 3 => Ok(Exception::E3), + _ => Err(Error::InvalidVariant(number)), + } + } + } + + unsafe impl InterruptNumber for Interrupt { + const MAX_INTERRUPT_NUMBER: usize = Self::I4 as usize; + + #[inline] + fn number(self) -> usize { + self as _ + } + + #[inline] + fn from_number(number: usize) -> Result { + match number { + 1 => Ok(Interrupt::I1), + 2 => Ok(Interrupt::I2), + 4 => Ok(Interrupt::I4), + _ => Err(Error::InvalidVariant(number)), + } + } + } + + unsafe impl PriorityNumber for Priority { + const MAX_PRIORITY_NUMBER: usize = Self::P3 as usize; + + #[inline] + fn number(self) -> usize { + self as _ + } + + #[inline] + fn from_number(number: usize) -> Result { + match number { + 0 => Ok(Priority::P0), + 1 => Ok(Priority::P1), + 2 => Ok(Priority::P2), + 3 => Ok(Priority::P3), + _ => Err(Error::InvalidVariant(number)), + } + } + } + + unsafe impl CoreIdNumber for CoreId { + const MAX_CORE_ID_NUMBER: usize = Self::H2 as usize; + + #[inline] + fn number(self) -> usize { + self as _ + } + + #[inline] + fn from_number(number: usize) -> Result { + match number { + 0 => Ok(CoreId::H0), + 1 => Ok(CoreId::H1), + 2 => Ok(CoreId::H2), + _ => Err(Error::InvalidVariant(number)), + } + } + } + + #[test] + fn check_exception_enum() { + assert_eq!(Exception::E1.number(), 1); + assert_eq!(Exception::E3.number(), 3); + + assert_eq!(Exception::from_number(0), Err(Error::InvalidVariant(0))); + assert_eq!(Exception::from_number(1), Ok(Exception::E1)); + assert_eq!(Exception::from_number(2), Err(Error::InvalidVariant(2))); + assert_eq!(Exception::from_number(3), Ok(Exception::E3)); + assert_eq!(Exception::from_number(4), Err(Error::InvalidVariant(4))); + } + + #[test] + fn check_interrupt_enum() { + assert_eq!(Interrupt::I1.number(), 1); + assert_eq!(Interrupt::I2.number(), 2); + assert_eq!(Interrupt::I4.number(), 4); + + assert_eq!(Interrupt::from_number(0), Err(Error::InvalidVariant(0))); + assert_eq!(Interrupt::from_number(1), Ok(Interrupt::I1)); + assert_eq!(Interrupt::from_number(2), Ok(Interrupt::I2)); + assert_eq!(Interrupt::from_number(3), Err(Error::InvalidVariant(3))); + assert_eq!(Interrupt::from_number(4), Ok(Interrupt::I4)); + assert_eq!(Interrupt::from_number(5), Err(Error::InvalidVariant(5))); + } + + #[test] + fn check_priority_enum() { + assert_eq!(Priority::P0.number(), 0); + assert_eq!(Priority::P1.number(), 1); + assert_eq!(Priority::P2.number(), 2); + assert_eq!(Priority::P3.number(), 3); + + assert_eq!(Priority::from_number(0), Ok(Priority::P0)); + assert_eq!(Priority::from_number(1), Ok(Priority::P1)); + assert_eq!(Priority::from_number(2), Ok(Priority::P2)); + assert_eq!(Priority::from_number(3), Ok(Priority::P3)); + assert_eq!(Priority::from_number(4), Err(Error::InvalidVariant(4))); + } + + #[test] + fn check_core_id_enum() { + assert_eq!(CoreId::H0.number(), 0); + assert_eq!(CoreId::H1.number(), 1); + assert_eq!(CoreId::H2.number(), 2); + + assert_eq!(CoreId::from_number(0), Ok(CoreId::H0)); + assert_eq!(CoreId::from_number(1), Ok(CoreId::H1)); + assert_eq!(CoreId::from_number(2), Ok(CoreId::H2)); + assert_eq!(CoreId::from_number(3), Err(Error::InvalidVariant(3))); + } +} diff --git a/cortex-m-pac/src/result.rs b/cortex-m-pac/src/result.rs new file mode 100644 index 00000000..b55c8beb --- /dev/null +++ b/cortex-m-pac/src/result.rs @@ -0,0 +1,58 @@ +use core::fmt; + +/// Convenience alias for the [Result](core::result::Result) type for the library. +pub type Result = core::result::Result; + +/// Represents error variants for the library. +#[derive(Clone, Copy, Debug, Eq, PartialEq)] +pub enum Error { + /// Attempted out-of-bounds access. + IndexOutOfBounds { + index: usize, + min: usize, + max: usize, + }, + /// Invalid field value. + InvalidFieldValue { + field: &'static str, + value: usize, + bitmask: usize, + }, + /// Invalid value of a register field that does not match any known variants. + InvalidFieldVariant { field: &'static str, value: usize }, + /// Invalid value. + InvalidValue { value: usize, bitmask: usize }, + /// Invalid value that does not match any known variants. + InvalidVariant(usize), + /// Unimplemented function or type. + Unimplemented, +} + +impl fmt::Display for Error { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + match self { + Self::IndexOutOfBounds { index, min, max } => write!( + f, + "out-of-bounds access, index: {index}, min: {min}, max: {max}" + ), + Self::InvalidFieldValue { + field, + value, + bitmask, + } => write!( + f, + "invalid {field} field value: {value:#x}, valid bitmask: {bitmask:#x}", + ), + Self::InvalidFieldVariant { field, value } => { + write!(f, "invalid {field} field variant: {value:#x}") + } + Self::InvalidValue { value, bitmask } => { + write!(f, "invalid value: {value:#x}, valid bitmask: {bitmask:#x}",) + } + Self::InvalidVariant(value) => { + write!(f, "invalid variant: {value:#x}") + } + Self::Unimplemented => write!(f, "unimplemented"), + } + } +} From 5429dc6c0e1ab4531b217b87ffafbbc017833437 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rom=C3=A1n=20C=C3=A1rdenas=20Rodr=C3=ADguez?= Date: Tue, 15 Oct 2024 23:27:16 +0200 Subject: [PATCH 2/8] impl core::error::Error --- cortex-m-pac/src/result.rs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/cortex-m-pac/src/result.rs b/cortex-m-pac/src/result.rs index b55c8beb..ceee019a 100644 --- a/cortex-m-pac/src/result.rs +++ b/cortex-m-pac/src/result.rs @@ -56,3 +56,5 @@ impl fmt::Display for Error { } } } + +impl core::error::Error for Error {} From 34f3419726a19792ef7d8722dd137f242411e3e5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rom=C3=A1n=20C=C3=A1rdenas=20Rodr=C3=ADguez?= Date: Wed, 16 Oct 2024 10:00:11 +0200 Subject: [PATCH 3/8] Update cortex-m-pac/Cargo.toml Co-authored-by: Ralph Ursprung <39383228+rursprung@users.noreply.github.com> --- cortex-m-pac/Cargo.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cortex-m-pac/Cargo.toml b/cortex-m-pac/Cargo.toml index ad72f5bc..be458a15 100644 --- a/cortex-m-pac/Cargo.toml +++ b/cortex-m-pac/Cargo.toml @@ -2,7 +2,7 @@ name = "cortex-m-pac" version = "0.1.0" edition = "2021" -rust-version = "1.60" +rust-version = "1.81" repository = "https://github.com/rust-embedded/cortex-m" authors = ["The Cortex-M Team ",] categories = ["embedded", "hardware-support", "no-std"] From 0fef31e6c084512d10d226e158304f9d2b3afed9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rom=C3=A1n=20C=C3=A1rdenas=20Rodr=C3=ADguez?= Date: Wed, 16 Oct 2024 12:39:23 +0200 Subject: [PATCH 4/8] Tweak CI for excluding cortex-m-pac on MSRV --- .github/workflows/ci.yml | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 4c10968f..91421398 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -27,4 +27,8 @@ jobs: with: toolchain: ${{ matrix.rust }} - name: Run tests + if: ${{ matrix.rust != '1.61.0' }} run: cargo test --all --exclude cortex-m-rt --exclude testsuite --features cortex-m/critical-section-single-core + - name: Run tests for 1.61.0 (need to exclude cortex-m-pac) + if: ${{ matrix.rust == '1.61.0' }} + run: cargo test --all --exclude cortex-m-rt --exclude testsuite --exclude cortex-m-pac --features cortex-m/critical-section-single-core From 71ee4da4a370db9baa595e5be69faa2461d68fad Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rom=C3=A1n=20C=C3=A1rdenas=20Rodr=C3=ADguez?= Date: Mon, 5 May 2025 10:41:31 +0200 Subject: [PATCH 5/8] Make Error non-exhaustive --- cortex-m-pac/src/result.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/cortex-m-pac/src/result.rs b/cortex-m-pac/src/result.rs index ceee019a..fa158529 100644 --- a/cortex-m-pac/src/result.rs +++ b/cortex-m-pac/src/result.rs @@ -5,6 +5,7 @@ pub type Result = core::result::Result; /// Represents error variants for the library. #[derive(Clone, Copy, Debug, Eq, PartialEq)] +#[non_exhaustive] pub enum Error { /// Attempted out-of-bounds access. IndexOutOfBounds { From 5ad71558901ce01c73e83af3c87e8ed5706e9eb6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rom=C3=A1n=20C=C3=A1rdenas=20Rodr=C3=ADguez?= Date: Wed, 4 Jun 2025 12:06:28 +0200 Subject: [PATCH 6/8] Fix errors in README.md --- cortex-m-pac/README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/cortex-m-pac/README.md b/cortex-m-pac/README.md index a48faee7..6eae4fbd 100644 --- a/cortex-m-pac/README.md +++ b/cortex-m-pac/README.md @@ -11,12 +11,12 @@ This project is developed and maintained by the [Cortex-M team][team]. ## Minimum Supported Rust Version (MSRV) -This crate is guaranteed to compile on stable Rust 1.60 and up. It *might* +This crate is guaranteed to compile on stable Rust 1.81 and up. It *might* compile with older versions but that may change in any new patch release. ## License -Copyright 2024 [Cortex-M team][team] +Copyright 2024 [Arm team][team] Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice @@ -37,4 +37,4 @@ Conduct][CoC], the maintainer of this crate, the [Cortex-M team][team], promises to intervene to uphold that code of conduct. [CoC]: CODE_OF_CONDUCT.md -[team]: https://github.com/rust-embedded/wg#the-cortex-m-team +[team]: https://github.com/rust-embedded/wg#the-arm-team From a616f31a413e68eecbd7a9e640a712213ef03112 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rom=C3=A1n=20C=C3=A1rdenas=20Rodr=C3=ADguez?= Date: Fri, 3 Oct 2025 08:35:51 +0200 Subject: [PATCH 7/8] Rename to cortex-m-types --- .github/workflows/ci.yml | 4 ++-- Cargo.toml | 2 +- {cortex-m-pac => cortex-m-types}/CHANGELOG.md | 0 {cortex-m-pac => cortex-m-types}/Cargo.toml | 4 ++-- {cortex-m-pac => cortex-m-types}/README.md | 12 ++++++------ {cortex-m-pac => cortex-m-types}/src/lib.rs | 0 {cortex-m-pac => cortex-m-types}/src/result.rs | 0 7 files changed, 11 insertions(+), 11 deletions(-) rename {cortex-m-pac => cortex-m-types}/CHANGELOG.md (100%) rename {cortex-m-pac => cortex-m-types}/Cargo.toml (89%) rename {cortex-m-pac => cortex-m-types}/README.md (73%) rename {cortex-m-pac => cortex-m-types}/src/lib.rs (100%) rename {cortex-m-pac => cortex-m-types}/src/result.rs (100%) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 91421398..421094fc 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -29,6 +29,6 @@ jobs: - name: Run tests if: ${{ matrix.rust != '1.61.0' }} run: cargo test --all --exclude cortex-m-rt --exclude testsuite --features cortex-m/critical-section-single-core - - name: Run tests for 1.61.0 (need to exclude cortex-m-pac) + - name: Run tests for 1.61.0 (need to exclude cortex-m-types) if: ${{ matrix.rust == '1.61.0' }} - run: cargo test --all --exclude cortex-m-rt --exclude testsuite --exclude cortex-m-pac --features cortex-m/critical-section-single-core + run: cargo test --all --exclude cortex-m-rt --exclude testsuite --exclude cortex-m-types --features cortex-m/critical-section-single-core diff --git a/Cargo.toml b/Cargo.toml index c8624efa..82eba374 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -2,7 +2,7 @@ resolver = "2" members = [ "cortex-m", - "cortex-m-pac", + "cortex-m-types", "cortex-m-rt", "cortex-m-semihosting", "panic-itm", diff --git a/cortex-m-pac/CHANGELOG.md b/cortex-m-types/CHANGELOG.md similarity index 100% rename from cortex-m-pac/CHANGELOG.md rename to cortex-m-types/CHANGELOG.md diff --git a/cortex-m-pac/Cargo.toml b/cortex-m-types/Cargo.toml similarity index 89% rename from cortex-m-pac/Cargo.toml rename to cortex-m-types/Cargo.toml index be458a15..33b9829d 100644 --- a/cortex-m-pac/Cargo.toml +++ b/cortex-m-types/Cargo.toml @@ -1,5 +1,5 @@ [package] -name = "cortex-m-pac" +name = "cortex-m-types" version = "0.1.0" edition = "2021" rust-version = "1.81" @@ -7,7 +7,7 @@ repository = "https://github.com/rust-embedded/cortex-m" authors = ["The Cortex-M Team ",] categories = ["embedded", "hardware-support", "no-std"] description = "Low level access to Cortex-M processors" -documentation = "https://docs.rs/cortex-m-pac" +documentation = "https://docs.rs/cortex-m-types" keywords = ["arm", "cortex-m", "register", "peripheral"] license = "MIT OR Apache-2.0" readme = "README.md" diff --git a/cortex-m-pac/README.md b/cortex-m-types/README.md similarity index 73% rename from cortex-m-pac/README.md rename to cortex-m-types/README.md index 6eae4fbd..36188439 100644 --- a/cortex-m-pac/README.md +++ b/cortex-m-types/README.md @@ -1,13 +1,13 @@ -[![crates.io](https://img.shields.io/crates/d/cortex-m-pac.svg)](https://crates.io/crates/cortex-m-pac) -[![crates.io](https://img.shields.io/crates/v/cortex-m-pac.svg)](https://crates.io/crates/cortex-m-pac) +[![crates.io](https://img.shields.io/crates/d/cortex-m-types.svg)](https://crates.io/crates/cortex-m-types) +[![crates.io](https://img.shields.io/crates/v/cortex-m-types.svg)](https://crates.io/crates/cortex-m-types) -# `cortex-m-pac` +# `cortex-m-types` > Target-specific traits to be implemented by PACs -This project is developed and maintained by the [Cortex-M team][team]. +This project is developed and maintained by the [Arm team][team]. -## [Documentation](https://docs.rs/crate/cortex-m-pac) +## [Documentation](https://docs.rs/crate/cortex-m-types) ## Minimum Supported Rust Version (MSRV) @@ -33,7 +33,7 @@ THIS SOFTWARE. ## Code of Conduct Contribution to this crate is organized under the terms of the [Rust Code of -Conduct][CoC], the maintainer of this crate, the [Cortex-M team][team], promises +Conduct][CoC], the maintainer of this crate, the [Arm team][team], promises to intervene to uphold that code of conduct. [CoC]: CODE_OF_CONDUCT.md diff --git a/cortex-m-pac/src/lib.rs b/cortex-m-types/src/lib.rs similarity index 100% rename from cortex-m-pac/src/lib.rs rename to cortex-m-types/src/lib.rs diff --git a/cortex-m-pac/src/result.rs b/cortex-m-types/src/result.rs similarity index 100% rename from cortex-m-pac/src/result.rs rename to cortex-m-types/src/result.rs From ea8785770f763d9e4cd430fa320d32d78f453dac Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rom=C3=A1n=20C=C3=A1rdenas=20Rodr=C3=ADguez?= Date: Fri, 3 Oct 2025 09:24:37 +0200 Subject: [PATCH 8/8] Bump Clippy action to Rust 1.81 --- .github/workflows/clippy.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/clippy.yml b/.github/workflows/clippy.yml index 582fe6bc..6367f741 100644 --- a/.github/workflows/clippy.yml +++ b/.github/workflows/clippy.yml @@ -9,7 +9,7 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - - uses: dtolnay/rust-toolchain@1.61 + - uses: dtolnay/rust-toolchain@1.81 with: components: clippy - run: cargo clippy --all --features cortex-m/critical-section-single-core -- --deny warnings