Skip to content

Commit

Permalink
Add hil test for SpiDmaBus::{read,write}
Browse files Browse the repository at this point in the history
  • Loading branch information
ferris committed Dec 19, 2024
1 parent 01bd24e commit d20329e
Showing 1 changed file with 27 additions and 0 deletions.
27 changes: 27 additions & 0 deletions hil-test/tests/spi_full_duplex.rs
Original file line number Diff line number Diff line change
Expand Up @@ -447,6 +447,33 @@ mod tests {
);
}

#[test]
fn test_dma_bus_read_write(ctx: Context) {
const TRANSFER_SIZE: usize = 4;
let (rx_buffer, rx_descriptors, tx_buffer, tx_descriptors) = dma_buffers!(4);
let dma_rx_buf = DmaRxBuf::new(rx_descriptors, rx_buffer).unwrap();
let dma_tx_buf = DmaTxBuf::new(tx_descriptors, tx_buffer).unwrap();

ctx.pcnt_unit.channel0.set_edge_signal(ctx.pcnt_source);
ctx.pcnt_unit
.channel0
.set_input_mode(EdgeMode::Hold, EdgeMode::Increment);

let mut spi = ctx
.spi
.with_dma(ctx.dma_channel)
.with_buffers(dma_rx_buf, dma_tx_buf);

// Fill the buffer where each byte has 3 pos edges.
let transmit = [0b0110_1010; TRANSFER_SIZE];
let mut rx_buf = [0; TRANSFER_SIZE];
spi.read(&mut rx_buf).unwrap();
assert_eq!(receive, [0; TRANSFER_SIZE]);

spi.write(&mut tx_buf).unwrap();
assert_eq!(ctx.pcnt_unit.value(), (i * 3 * TRANSFER_SIZE) as _);
}

#[test]
fn test_dma_bus_symmetric_transfer(ctx: Context) {
let (rx_buffer, rx_descriptors, tx_buffer, tx_descriptors) = dma_buffers!(4);
Expand Down

0 comments on commit d20329e

Please sign in to comment.