#hardware-abstraction-layer #abstraction-layer #nxp #cortex-m #lpc

no-std lpc55-hal

Hardware Abstraction Layer (HAL) for the NXP LPC55S6x ARM Cortex-33 microcontrollers

7 releases (4 breaking)

0.4.0 Oct 25, 2024
0.3.1 Oct 9, 2024
0.3.0 Jun 10, 2021
0.2.1 May 2, 2021
0.0.3 Jan 6, 2020

#530 in Embedded development

Download history 14/week @ 2024-09-18 25/week @ 2024-09-25 1/week @ 2024-10-02 258/week @ 2024-10-09 105/week @ 2024-10-16 218/week @ 2024-10-23 37/week @ 2024-10-30 52/week @ 2024-11-06 103/week @ 2024-11-13 44/week @ 2024-11-20 29/week @ 2024-11-27 55/week @ 2024-12-04 47/week @ 2024-12-11 23/week @ 2024-12-18 8/week @ 2024-12-25

146 downloads per month
Used in se05x

Apache-2.0 OR MIT

425KB
10K SLoC

Hardware Abstraction Layer (HAL) for NXP LPC55 series Cortex-M33 microcontrollers, written in Rust.

Build Status crates.io LICENSE Documentation Documentation (master)

LPC55 HAL provides a high-level interface to the features of these LPC55 family of MCUs, which is safe, convenient and efficient. It leverages Rust's type system to prevent common mistakes, such as attempting to use an uninitialized peripheral; these will be caught by compile-time errors.

This library implements the embedded-hal, a collection of traits intended to abstract over platform-dependencies, allowing firmware and drivers to be quite portable.

It also implements the usb-device framework.

Moreover, this library is compatible with the Cortex-M implementation of RTIC, a concurrency framework supporting preemptive multitasking with minimal footprint.

Status

Very much work-in-progress!

Current peripherals that mostly work:

  • I2C, SPI, Serial (with all pins)
  • USB FS device

Next up will be:

See also the low-level companion library LPC55S6x PAC.

This HAL is intended to work with cortex-m-rtic v0.5.

Documentation

The API documentation is located at https://docs.rs/lpc55-hal.

In addition, make fetch-docs downloads various vendor-supplied documentation:

Examples

The intention of the examples/ is to showcase the functionality of this library.

They run on the LPCXpresso55S69 development board.

After flashing J-Link firmware on the on-board LPCXpresso V2 debugger:

# in one terminal
make jlink

# in another terminal
make run-example EXAMPLE=rtic_led  # or any other example

Setup

To install rust, follow the install instructions from here: https://rust-embedded.github.io/book/intro/install.html

You also need following targets:

  • thumbv8m.main-none-eabi
  • thumbv8m.main-none-eabihf

Just use following command:

  rustup target add thumbv8m.main-none-eabi
  rustup target add thumbv8m.main-none-eabihf

License

Apache-2.0 or MIT.

Parts of the code are directly lifted from the LPC8xx HAL, others from the various STM32 HALs.

Dependencies

~15MB
~413K SLoC