Skip to content

Commit

Permalink
as_slice instead of as_ref
Browse files Browse the repository at this point in the history
  • Loading branch information
burrbull committed Aug 15, 2019
1 parent 7ac6927 commit 16e537e
Show file tree
Hide file tree
Showing 5 changed files with 21 additions and 14 deletions.
6 changes: 6 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,12 @@ 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]

### Changed

- DMA traits now require AsSlice instead of AsRef

## [v0.4.0] - 2019-08-09

### Added
Expand Down
1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ cortex-m = "0.6.0"
nb = "0.1.2"
cortex-m-rt = "0.6.8"
stm32f1 = "0.8.0"
as-slice = "0.1"

[dependencies.void]
default-features = false
Expand Down
8 changes: 4 additions & 4 deletions src/adc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -583,12 +583,12 @@ impl<PIN> AdcDma<PIN> where PIN: Channel<ADC1> {

impl<B, PIN> crate::dma::CircReadDma<B, u16> for AdcDma<PIN>
where
B: AsMut<[u16]>,
B: as_slice::AsMutSlice<Element=u16>,
PIN: Channel<ADC1>,
{
fn circ_read(mut self, buffer: &'static mut [B; 2]) -> CircBuffer<B, Self> {
{
let buffer = buffer[0].as_mut();
let buffer = buffer[0].as_mut_slice();
self.channel.set_peripheral_address(unsafe{ &(*ADC1::ptr()).dr as *const _ as u32 }, false);
self.channel.set_memory_address(buffer.as_ptr() as u32, true);
self.channel.set_transfer_length(buffer.len() * 2);
Expand All @@ -613,12 +613,12 @@ where

impl<B, PIN> crate::dma::ReadDma<B, u16> for AdcDma<PIN>
where
B: AsMut<[u16]>,
B: as_slice::AsMutSlice<Element=u16>,
PIN: Channel<ADC1>,
{
fn read(mut self, buffer: &'static mut B) -> Transfer<W, &'static mut B, Self> {
{
let buffer = buffer.as_mut();
let buffer = buffer.as_mut_slice();
self.channel.set_peripheral_address(unsafe{ &(*ADC1::ptr()).dr as *const _ as u32 }, false);
self.channel.set_memory_address(buffer.as_ptr() as u32, true);
self.channel.set_transfer_length(buffer.len());
Expand Down
8 changes: 4 additions & 4 deletions src/dma.rs
Original file line number Diff line number Diff line change
Expand Up @@ -482,15 +482,15 @@ pub trait Transmit {

pub trait CircReadDma<B, RS>: Receive
where
B: AsMut<[RS]>,
B: as_slice::AsMutSlice<Element=RS>,
Self: core::marker::Sized,
{
fn circ_read(self, buffer: &'static mut [B; 2]) -> CircBuffer<B, Self>;
}

pub trait ReadDma<B, RS>: Receive
where
B: AsMut<[RS]>,
B: as_slice::AsMutSlice<Element=RS>,
Self: core::marker::Sized,
{
fn read(
Expand All @@ -501,9 +501,9 @@ where

pub trait WriteDma<A, B, TS>: Transmit
where
A: AsRef<[TS]>,
A: as_slice::AsSlice<Element=TS>,
B: Static<A>,
Self: core::marker::Sized,
{
fn write(self, buffer: B) -> Transfer<R, B, Self>;
}
}
12 changes: 6 additions & 6 deletions src/serial.rs
Original file line number Diff line number Diff line change
Expand Up @@ -551,12 +551,12 @@ macro_rules! serialdma {
}
}

impl<B> crate::dma::CircReadDma<B, u8> for $rxdma where B: AsMut<[u8]> {
impl<B> crate::dma::CircReadDma<B, u8> for $rxdma where B: as_slice::AsMutSlice<Element=u8> {
fn circ_read(mut self, buffer: &'static mut [B; 2],
) -> CircBuffer<B, Self>
{
{
let buffer = buffer[0].as_mut();
let buffer = buffer[0].as_mut_slice();
self.channel.set_peripheral_address(unsafe{ &(*$USARTX::ptr()).dr as *const _ as u32 }, false);
self.channel.set_memory_address(buffer.as_ptr() as u32, true);
self.channel.set_transfer_length(buffer.len() * 2);
Expand All @@ -579,12 +579,12 @@ macro_rules! serialdma {
}
}

impl<B> crate::dma::ReadDma<B, u8> for $rxdma where B: AsMut<[u8]> {
impl<B> crate::dma::ReadDma<B, u8> for $rxdma where B: as_slice::AsMutSlice<Element=u8> {
fn read(mut self, buffer: &'static mut B,
) -> Transfer<W, &'static mut B, Self>
{
{
let buffer = buffer.as_mut();
let buffer = buffer.as_mut_slice();
self.channel.set_peripheral_address(unsafe{ &(*$USARTX::ptr()).dr as *const _ as u32 }, false);
self.channel.set_memory_address(buffer.as_ptr() as u32, true);
self.channel.set_transfer_length(buffer.len());
Expand All @@ -604,12 +604,12 @@ macro_rules! serialdma {
}
}

impl<A, B> crate::dma::WriteDma<A, B, u8> for $txdma where A: AsRef<[u8]>, B: Static<A> {
impl<A, B> crate::dma::WriteDma<A, B, u8> for $txdma where A: as_slice::AsSlice<Element=u8>, B: Static<A> {
fn write(mut self, buffer: B
) -> Transfer<R, B, Self>
{
{
let buffer = buffer.borrow().as_ref();
let buffer = buffer.borrow().as_slice();

self.channel.set_peripheral_address(unsafe{ &(*$USARTX::ptr()).dr as *const _ as u32 }, false);

Expand Down

0 comments on commit 16e537e

Please sign in to comment.