Skip to content

A UART port driver for the Arylic Up2Stream Pro Board

Notifications You must be signed in to change notification settings

adoble/up2stream-uart

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

97 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

dev-version build

up2stream-uart

This crate provides a UART driver for the Arylic Up2Steam Pro board.

It provides a subset of the functionality provided by the UART interface to the board.

The public API is available as functions exposed by the [Up2Stream] struct.

The main driver is created using up2stream_uart::Up2Stream::new which accepts an UART peripheral that implements the embedded_hal::serial::{Read, Write} traits. Tne UART connection is configured as 115200,8,N,1 with no flow control

Values are not set directly, but through the use of either enums or scalar types (such as [Volume] or [Bass]) that provide range constraints on the values (for instance Bass can only accept values between -10 and +10 inclusive). If a value is out of range an error is returned. As such, type safety is ensured.

Example

Gets the current volume and sets it to a lower level.

use up2stream_uart::{Up2Stream, Volume, ScalarParameter, Error};

// Initialise a serial peripheral on your MCU that implements the traits
// `embedded_hal::serial::{Read, Write}`. This is assigned
// the variable `serial` in the code example


// Initialise the drive using the previously setup serial peripheral
let mut up2stream_device = Up2Stream::new(serial);

// Set the initial volume
let initial_vol = Volume::new(50)?;
up2stream_device.set_volume(initial_vol)?;

// Do some more processing ...

// Get the volume from the device
let actual_volume: i8 = up2stream_device.volume()?.get();

// Reduce the volume by 1 step
if actual_volume > 0 {
    let new_volume = Volume::new(actual_volume - 1)?;
    up2stream_device.set_volume(new_volume)?;
}

Restrictions

Currently only covers a subset of the UART API version 3.

API description for the UART interface to the Up2Stream Pro.

The Arylic API for the UART can be downloaded here.

Legal Notice

Distributed under a MIT license.

The author of this sofware is not affilated in anyway with the manaufacturer or distributers of the Arylic Up2Stream Pro board. The author just brought it for personal use and needed a driver in Rust!

About

A UART port driver for the Arylic Up2Stream Pro Board

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages