NEORV32 Software Framework Documentation
The NEORV32 RISC-V Processor
Loading...
Searching...
No Matches
neorv32_dma.h
Go to the documentation of this file.
1// ================================================================================ //
2// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //
3// Copyright (c) NEORV32 contributors. //
4// Copyright (c) 2020 - 2025 Stephan Nolting. All rights reserved. //
5// Licensed under the BSD-3-Clause license, see LICENSE for details. //
6// SPDX-License-Identifier: BSD-3-Clause //
7// ================================================================================ //
8
13
14#ifndef neorv32_dma_h
15#define neorv32_dma_h
16
17#include <stdint.h>
18
19
20/**********************************************************************/
25typedef volatile struct __attribute__((packed,aligned(4))) {
26 uint32_t CTRL;
27 uint32_t SRC_BASE;
28 uint32_t DST_BASE;
29 uint32_t TTYPE;
31
33#define NEORV32_DMA ((neorv32_dma_t*) (NEORV32_DMA_BASE))
34
49
61
62
63
64/**********************************************************************/
68#define DMA_CMD_B2B (0b00 << DMA_TTYPE_QSEL_LSB) // byte to byte
69#define DMA_CMD_B2UW (0b01 << DMA_TTYPE_QSEL_LSB) // byte to unsigned word
70#define DMA_CMD_B2SW (0b10 << DMA_TTYPE_QSEL_LSB) // byte to signed word
71#define DMA_CMD_W2W (0b11 << DMA_TTYPE_QSEL_LSB) // word to word
72
73#define DMA_CMD_SRC_CONST (0b0 << DMA_TTYPE_SRC_INC) // constant source address
74#define DMA_CMD_SRC_INC (0b1 << DMA_TTYPE_SRC_INC) // incrementing source address
75
76#define DMA_CMD_DST_CONST (0b0 << DMA_TTYPE_DST_INC) // constant destination address
77#define DMA_CMD_DST_INC (0b1 << DMA_TTYPE_DST_INC) // incrementing destination address
78
79#define DMA_CMD_ENDIAN (0b1 << DMA_TTYPE_ENDIAN) // convert endianness
81
82
83/**********************************************************************/
92
93
94/**********************************************************************/
98int neorv32_dma_available(void);
99void neorv32_dma_enable(void);
100void neorv32_dma_disable(void);
101void neorv32_dma_transfer(uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config);
102void neorv32_dma_transfer_auto(uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config, int firq_sel, int firq_type);
103int neorv32_dma_status(void);
104int neorv32_dma_done(void);
106
107
108#endif // neorv32_dma_h
NEORV32_DMA_STATUS_enum
Definition neorv32_dma.h:86
@ DMA_STATUS_ERR_WR
Definition neorv32_dma.h:87
@ DMA_STATUS_IDLE
Definition neorv32_dma.h:89
@ DMA_STATUS_BUSY
Definition neorv32_dma.h:90
@ DMA_STATUS_ERR_RD
Definition neorv32_dma.h:88
int neorv32_dma_available(void)
Definition neorv32_dma.c:22
void neorv32_dma_transfer(uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config)
Definition neorv32_dma.c:59
NEORV32_DMA_TTYPE_enum
Definition neorv32_dma.h:51
@ DMA_TTYPE_ENDIAN
Definition neorv32_dma.h:59
@ DMA_TTYPE_QSEL_MSB
Definition neorv32_dma.h:56
@ DMA_TTYPE_SRC_INC
Definition neorv32_dma.h:57
@ DMA_TTYPE_NUM_MSB
Definition neorv32_dma.h:53
@ DMA_TTYPE_NUM_LSB
Definition neorv32_dma.h:52
@ DMA_TTYPE_DST_INC
Definition neorv32_dma.h:58
@ DMA_TTYPE_QSEL_LSB
Definition neorv32_dma.h:55
NEORV32_DMA_CTRL_enum
Definition neorv32_dma.h:36
@ DMA_CTRL_DONE
Definition neorv32_dma.h:43
@ DMA_CTRL_FIRQ_SEL_MSB
Definition neorv32_dma.h:47
@ DMA_CTRL_ERROR_RD
Definition neorv32_dma.h:40
@ DMA_CTRL_AUTO
Definition neorv32_dma.h:38
@ DMA_CTRL_EN
Definition neorv32_dma.h:37
@ DMA_CTRL_BUSY
Definition neorv32_dma.h:42
@ DMA_CTRL_FIRQ_SEL_LSB
Definition neorv32_dma.h:46
@ DMA_CTRL_FIRQ_TYPE
Definition neorv32_dma.h:45
@ DMA_CTRL_ERROR_WR
Definition neorv32_dma.h:41
void neorv32_dma_disable(void)
Definition neorv32_dma.c:45
void neorv32_dma_transfer_auto(uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config, int firq_sel, int firq_type)
Definition neorv32_dma.c:78
int neorv32_dma_status(void)
Definition neorv32_dma.c:98
void neorv32_dma_enable(void)
Definition neorv32_dma.c:36
int neorv32_dma_done(void)
Definition neorv32_dma.c:123
Definition neorv32_dma.h:25
uint32_t SRC_BASE
Definition neorv32_dma.h:27
uint32_t TTYPE
Definition neorv32_dma.h:29
uint32_t CTRL
Definition neorv32_dma.h:26
uint32_t DST_BASE
Definition neorv32_dma.h:28