ISSDK  1.7
IoT Sensing Software Development Kit
RTE_Device.h
Go to the documentation of this file.
1 /*
2  * The Clear BSD License
3  * Copyright (c) 2016, Freescale Semiconductor, Inc.
4  * Copyright 2016-2017 NXP
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without modification,
8  * are permitted (subject to the limitations in the disclaimer below) provided
9  * that the following conditions are met:
10  *
11  * o Redistributions of source code must retain the above copyright notice, this list
12  * of conditions and the following disclaimer.
13  *
14  * o Redistributions in binary form must reproduce the above copyright notice, this
15  * list of conditions and the following disclaimer in the documentation and/or
16  * other materials provided with the distribution.
17  *
18  * o Neither the name of the copyright holder nor the names of its
19  * contributors may be used to endorse or promote products derived from this
20  * software without specific prior written permission.
21  *
22  * NO EXPRESS OR IMPLIED LICENSES TO ANY PARTY'S PATENT RIGHTS ARE GRANTED BY THIS LICENSE.
23  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
24  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
25  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
27  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
28  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
30  * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
32  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33  */
34 
35 #ifndef __RTE_DEVICE_H
36 #define __RTE_DEVICE_H
37 
38 /* Driver name mapping. */
39 #define RTE_I2C0 1
40 #define RTE_I2C0_DMA_EN 0
41 #define RTE_I2C1 1
42 #define RTE_I2C1_DMA_EN 0
43 
44 #define RTE_SPI0 0
45 #define RTE_SPI0_DMA_EN 0
46 #define RTE_SPI1 1
47 #define RTE_SPI1_DMA_EN 0
48 
49 /* Use UART0 - UART2. */
50 #define RTE_USART0 0
51 #define RTE_USART0_DMA_EN 0
52 #define RTE_USART1 1
53 #define RTE_USART1_DMA_EN 0
54 #define RTE_USART2 1
55 #define RTE_USART2_DMA_EN 0
56 /* Use LPUART0. */
57 #define RTE_USART3 0
58 #define RTE_USART3_DMA_EN 0
59 
60 /* UART configuration. */
61 #define USART_RX_BUFFER_LEN 64
62 #define USART1_RX_BUFFER_ENABLE 1
63 #define USART2_RX_BUFFER_ENABLE 1
64 
65 /* DSPI configuration. */
66 #define RTE_SPI0_PCS_TO_SCK_DELAY 1000
67 #define RTE_SPI0_SCK_TO_PSC_DELAY 1000
68 #define RTE_SPI0_BETWEEN_TRANSFER_DELAY 1000
69 #define RTE_SPI0_MASTER_PCS_PIN_SEL kDSPI_MasterPcs0
70 #define RTE_SPI0_DMA_TX_CH 0
71 #define RTE_SPI0_DMA_TX_PERI_SEL (uint8_t) kDmaRequestMux0SPI0Tx
72 #define RTE_SPI0_DMA_TX_DMAMUX_BASE DMAMUX0
73 #define RTE_SPI0_DMA_TX_DMA_BASE DMA0
74 #define RTE_SPI0_DMA_RX_CH 1
75 #define RTE_SPI0_DMA_RX_PERI_SEL (uint8_t) kDmaRequestMux0SPI0Rx
76 #define RTE_SPI0_DMA_RX_DMAMUX_BASE DMAMUX0
77 #define RTE_SPI0_DMA_RX_DMA_BASE DMA0
78 #define RTE_SPI0_DMA_LINK_DMA_BASE DMA0
79 #define RTE_SPI0_DMA_LINK_CH 2
80 
81 #define RTE_SPI1_PCS_TO_SCK_DELAY 1000
82 #define RTE_SPI1_SCK_TO_PSC_DELAY 1000
83 #define RTE_SPI1_BETWEEN_TRANSFER_DELAY 1000
84 #define RTE_SPI1_MASTER_PCS_PIN_SEL kDSPI_MasterPcs0
85 #define RTE_SPI1_DMA_TX_CH 0
86 #define RTE_SPI1_DMA_TX_PERI_SEL (uint8_t) kDmaRequestMux0SPI1
87 #define RTE_SPI1_DMA_TX_DMAMUX_BASE DMAMUX0
88 #define RTE_SPI1_DMA_TX_DMA_BASE DMA0
89 #define RTE_SPI1_DMA_RX_CH 1
90 #define RTE_SPI1_DMA_RX_PERI_SEL (uint8_t) kDmaRequestMux0SPI1
91 #define RTE_SPI1_DMA_RX_DMAMUX_BASE DMAMUX0
92 #define RTE_SPI1_DMA_RX_DMA_BASE DMA0
93 #define RTE_SPI1_DMA_LINK_DMA_BASE DMA0
94 #define RTE_SPI1_DMA_LINK_CH 2
95 
96 /*I2C configuration*/
97 #define RTE_I2C0_Master_DMA_BASE DMA0
98 #define RTE_I2C0_Master_DMA_CH 0
99 #define RTE_I2C0_Master_DMAMUX_BASE DMAMUX0
100 #define RTE_I2C0_Master_PERI_SEL kDmaRequestMux0I2C0
101 
102 #define RTE_I2C1_Master_DMA_BASE DMA0
103 #define RTE_I2C1_Master_DMA_CH 1
104 #define RTE_I2C1_Master_DMAMUX_BASE DMAMUX0
105 #define RTE_I2C1_Master_PERI_SEL kDmaRequestMux0I2C1
106 
107 /* UART configuration. */
108 #define RTE_USART0_DMA_TX_CH 0
109 #define RTE_USART0_DMA_TX_PERI_SEL (uint8_t) kDmaRequestMux0UART0Tx
110 #define RTE_USART0_DMA_TX_DMAMUX_BASE DMAMUX0
111 #define RTE_USART0_DMA_TX_DMA_BASE DMA0
112 #define RTE_USART0_DMA_RX_CH 1
113 #define RTE_USART0_DMA_RX_PERI_SEL (uint8_t) kDmaRequestMux0UART0Rx
114 #define RTE_USART0_DMA_RX_DMAMUX_BASE DMAMUX0
115 #define RTE_USART0_DMA_RX_DMA_BASE DMA0
116 
117 #define RTE_USART1_DMA_TX_CH 0
118 #define RTE_USART1_DMA_TX_PERI_SEL (uint8_t) kDmaRequestMux0UART1Tx
119 #define RTE_USART1_DMA_TX_DMAMUX_BASE DMAMUX0
120 #define RTE_USART1_DMA_TX_DMA_BASE DMA0
121 #define RTE_USART1_DMA_RX_CH 1
122 #define RTE_USART1_DMA_RX_PERI_SEL (uint8_t) kDmaRequestMux0UART1Rx
123 #define RTE_USART1_DMA_RX_DMAMUX_BASE DMAMUX0
124 #define RTE_USART1_DMA_RX_DMA_BASE DMA0
125 
126 #define RTE_USART2_DMA_TX_CH 0
127 #define RTE_USART2_DMA_TX_PERI_SEL (uint8_t) kDmaRequestMux0UART2Tx
128 #define RTE_USART2_DMA_TX_DMAMUX_BASE DMAMUX0
129 #define RTE_USART2_DMA_TX_DMA_BASE DMA0
130 #define RTE_USART2_DMA_RX_CH 1
131 #define RTE_USART2_DMA_RX_PERI_SEL (uint8_t) kDmaRequestMux0UART2Rx
132 #define RTE_USART2_DMA_RX_DMAMUX_BASE DMAMUX0
133 #define RTE_USART2_DMA_RX_DMA_BASE DMA0
134 
135 #endif /* __RTE_DEVICE_H */