foxBMS - Unit Tests  1.1.0
The foxBMS Unit Tests API Documentation
test_dma.c
Go to the documentation of this file.
1 /**
2  *
3  * @copyright © 2010 - 2021, Fraunhofer-Gesellschaft zur Foerderung der angewandten Forschung e.V.
4  * All rights reserved.
5  *
6  * SPDX-License-Identifier: BSD-3-Clause
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions are met:
10  *
11  * 1. Redistributions of source code must retain the above copyright notice, this
12  * list of conditions and the following disclaimer.
13  *
14  * 2. Redistributions in binary form must reproduce the above copyright notice,
15  * this list of conditions and the following disclaimer in the documentation
16  * and/or other materials provided with the distribution.
17  *
18  * 3. Neither the name of the copyright holder nor the names of its
19  * contributors may be used to endorse or promote products derived from
20  * this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
23  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
25  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
26  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
28  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  *
33  * We kindly request you to use one or more of the following phrases to refer to
34  * foxBMS in your hardware, software, documentation or advertising materials:
35  *
36  * - ″This product uses parts of foxBMS®″
37  * - ″This product includes parts of foxBMS®″
38  * - ″This product is derived from foxBMS®″
39  *
40  */
41 
42 /**
43  * @file test_dma.c
44  * @author foxBMS Team
45  * @date 2020-04-01 (date of creation)
46  * @updated 2021-03-24 (date of last update)
47  * @ingroup UNIT_TEST_IMPLEMENTATION
48  * @prefix TEST
49  *
50  * @brief Tests for the dma module
51  *
52  */
53 
54 /*========== Includes =======================================================*/
55 #include "unity.h"
56 #include "MockHL_spi.h"
57 #include "MockHL_sys_dma.h"
58 #include "Mockio.h"
59 #include "Mockmic_dma.h"
60 #include "Mockspi.h"
61 
62 #include "dma.h"
63 
64 TEST_FILE("dma.c")
65 
66 /*========== Definitions and Implementations for Unit Test ==================*/
67 static const spiDAT1_t spi_kLtcDataConfig = {
68  /* struct is implemented in the TI HAL and uses uppercase true and false */
69  .CS_HOLD = FALSE, /* The HW chip select signal is deactivated */
70  .WDEL = TRUE, /* No delay will be inserted */
71  .DFSEL = SPI_FMT_0, /* Data word format select: Data format 0 (SPI1) */
72  .CSNR = 0x0, /* Chip select (CS) number, 0x01h for CS[0] */
73 };
74 
75 uint32_t spi_saveFmt0[] = {
76  0U,
77  0U,
78  0U,
79  0U,
80  0U,
81  0U,
82 };
83 
85  SPI_IDLE,
86  SPI_IDLE,
87  SPI_IDLE,
88  SPI_IDLE,
89  SPI_IDLE,
90 };
91 
92 const uint8_t spi_nrBusyFlags = sizeof(spi_busyFlags) / sizeof(SPI_BUSY_STATE_e);
93 
95  {
97  .pConfig = &spi_kLtcDataConfig,
98  .pNode = spiREG1,
99  .pGioPort = &(spiREG1->PC3),
100  .csPin = 2u,
101  },
102  {
103  .channel = SPI_Interface1,
104  .pConfig = &spi_kLtcDataConfig,
105  .pNode = spiREG1,
106  .pGioPort = &(spiREG1->PC3),
107  .csPin = 2u,
108  },
109  {
110  .channel = SPI_Interface1,
111  .pConfig = &spi_kLtcDataConfig,
112  .pNode = spiREG1,
113  .pGioPort = &(spiREG1->PC3),
114  .csPin = 2u,
115  },
116  {
117  .channel = SPI_Interface1,
118  .pConfig = &spi_kLtcDataConfig,
119  .pNode = spiREG1,
120  .pGioPort = &(spiREG1->PC3),
121  .csPin = 2u,
122  },
123  {
124  .channel = SPI_Interface1,
125  .pConfig = &spi_kLtcDataConfig,
126  .pNode = spiREG1,
127  .pGioPort = &(spiREG1->PC3),
128  .csPin = 2u,
129  },
130 };
131 
133  {DMA_CH0, DMA_CH1}, /* SPI1 */
134  {DMA_CH2, DMA_CH3}, /* SPI2 */
135  {DMA_CH4, DMA_CH5}, /* SPI3 */
136  {DMA_CH6, DMA_CH7}, /* SPI4 */
137  {DMA_CH8, DMA_CH9}, /* SPI5 */
138 };
139 
146 };
147 
149  spiREG1, /* SPI1 */
150  spiREG2, /* SPI2 */
151  spiREG3, /* SPI3 */
152  spiREG4, /* SPI4 */
153  spiREG5, /* SPI5 */
154 };
155 
156 /*========== Setup and Teardown =============================================*/
157 void setUp(void) {
158 }
159 
160 void tearDown(void) {
161 }
162 
163 /*========== Test Cases =====================================================*/
164 
165 void testDummy(void) {
166 }
Headers for the driver for the DMA module.
#define DMA_REQ_LINE_SPI1_TX
Definition: dma_cfg.h:73
#define DMA_REQ_LINE_SPI4_TX
Definition: dma_cfg.h:79
#define DMA_REQ_LINE_SPI1_RX
Definition: dma_cfg.h:74
#define DMA_REQ_LINE_SPI3_TX
Definition: dma_cfg.h:77
#define DMA_REQ_LINE_SPI4_RX
Definition: dma_cfg.h:80
#define DMA_REQ_LINE_SPI3_RX
Definition: dma_cfg.h:78
#define DMA_NUMBER_SPI_INTERFACES
Definition: dma_cfg.h:69
#define DMA_REQ_LINE_SPI5_RX
Definition: dma_cfg.h:82
#define DMA_REQ_LINE_SPI2_RX
Definition: dma_cfg.h:76
#define DMA_REQ_LINE_SPI2_TX
Definition: dma_cfg.h:75
#define DMA_REQ_LINE_SPI5_TX
Definition: dma_cfg.h:81
@ SPI_IDLE
Definition: spi_cfg.h:93
enum SPI_BUSY_STATE SPI_BUSY_STATE_e
@ SPI_Interface1
Definition: spi_cfg.h:99
SPI_INTERFACE_e channel
Definition: spi_cfg.h:108
SPI_INTERFACE_CONFIG_s spi_dmaTransmission[]
Variable used for SPI over DMA transmission. Retains the CS pin to deactivate in DMA callback.
Definition: test_dma.c:94
static const spiDAT1_t spi_kLtcDataConfig
Definition: test_dma.c:67
DMA_REQUEST_CONFIG_s dma_spiDmaRequests[DMA_NUMBER_SPI_INTERFACES]
Definition: test_dma.c:140
spiBASE_t * dma_spiInterfaces[DMA_NUMBER_SPI_INTERFACES]
Definition: test_dma.c:148
SPI_BUSY_STATE_e spi_busyFlags[]
Definition: test_dma.c:84
void testDummy(void)
Definition: test_dma.c:165
void setUp(void)
Definition: test_dma.c:157
void tearDown(void)
Definition: test_dma.c:160
uint32_t spi_saveFmt0[]
Definition: test_dma.c:75
DMA_CHANNEL_CONFIG_s dma_spiDmaChannels[DMA_NUMBER_SPI_INTERFACES]
Definition: test_dma.c:132
const uint8_t spi_nrBusyFlags
Definition: test_dma.c:92