Skip to content

Commit fd3cf81

Browse files
authored
[BSP] ADD ns800 BSP
1 parent 3f6a21d commit fd3cf81

56 files changed

Lines changed: 14572 additions & 0 deletions

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

.github/ALL_BSP_COMPILE.json

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -518,6 +518,13 @@
518518
"SUB_RTT_BSP": [
519519
"allwinner/d1s"
520520
]
521+
},
522+
{
523+
"RTT_BSP": "novosns",
524+
"RTT_TOOL_CHAIN": "sourcery-arm",
525+
"SUB_RTT_BSP": [
526+
"novosns/ns800/ns800rt7p65-nssinepad"
527+
]
521528
}
522529
]
523530
}

bsp/novosns/ns800/README.md

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
# NS800 BSP 说明
2+
3+
NS800 系列 BSP 目前支持情况如下表所示:
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
Import('RTT_ROOT')
2+
Import('rtconfig')
3+
from building import *
4+
import os
5+
6+
cwd = GetCurrentDir()
7+
src = ['drv_common.c']
8+
path = [cwd]
9+
10+
group = SConscript(os.path.join(cwd, 'drivers', 'SConscript'))
11+
group = group + DefineGroup('HAL_Driver', src, depend = [''], CPPPATH = path)
12+
13+
Return('group')
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
# comment "HAL_Drivers driver-level patch options are kept minimal; peripheral configs live in board/Kconfig"
Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
Import('RTT_ROOT')
2+
Import('rtconfig')
3+
from building import *
4+
import os
5+
6+
cwd = GetCurrentDir()
7+
src = []
8+
path = [cwd, cwd + '/config']
9+
10+
if GetDepend(['BSP_USING_GPIO', 'RT_USING_PIN']):
11+
src += ['drv_gpio.c']
12+
13+
if GetDepend(['BSP_USING_UART', 'RT_USING_SERIAL']):
14+
src += ['drv_uart.c']
15+
16+
if GetDepend(['BSP_USING_CAN', 'RT_USING_CAN']):
17+
src += ['drv_can.c']
18+
19+
if GetDepend(['BSP_USING_ECAP']):
20+
src += ['drv_ecap.c']
21+
22+
group = DefineGroup('HAL_Drivers', src, depend = [''], CPPPATH = path)
23+
24+
Return('group')
Lines changed: 94 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,94 @@
1+
/*
2+
* Copyright (c) 2006-2026, RT-Thread Development Team
3+
*
4+
* SPDX-License-Identifier: Apache-2.0
5+
*
6+
* Change Logs:
7+
* Date Author Notes
8+
* 2018-12-06 zylx first version
9+
*/
10+
11+
#ifndef __ADC_CONFIG_H__
12+
#define __ADC_CONFIG_H__
13+
14+
#include <rtthread.h>
15+
16+
#ifdef __cplusplus
17+
extern "C" {
18+
#endif
19+
20+
#ifdef BSP_USING_ADC1
21+
#ifndef ADC1_CONFIG
22+
#define ADC1_CONFIG \
23+
{ \
24+
.Instance = ADC1, \
25+
.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV4, \
26+
.Init.Resolution = ADC_RESOLUTION_16B, \
27+
.Init.ScanConvMode = ADC_SCAN_DISABLE, \
28+
.Init.EOCSelection = ADC_EOC_SINGLE_CONV, \
29+
.Init.LowPowerAutoWait = DISABLE, \
30+
.Init.ContinuousConvMode = DISABLE, \
31+
.Init.NbrOfConversion = 1, \
32+
.Init.DiscontinuousConvMode = DISABLE, \
33+
.Init.NbrOfDiscConversion = 1, \
34+
.Init.ExternalTrigConv = ADC_SOFTWARE_START, \
35+
.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE, \
36+
.Init.ConversionDataManagement = ADC_CONVERSIONDATA_DR, \
37+
.Init.Overrun = ADC_OVR_DATA_OVERWRITTEN, \
38+
.Init.OversamplingMode = DISABLE, \
39+
}
40+
#endif /* ADC1_CONFIG */
41+
#endif /* BSP_USING_ADC1 */
42+
43+
#ifdef BSP_USING_ADC2
44+
#ifndef ADC2_CONFIG
45+
#define ADC2_CONFIG \
46+
{ \
47+
.Instance = ADC2, \
48+
.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV4, \
49+
.Init.Resolution = ADC_RESOLUTION_16B, \
50+
.Init.ScanConvMode = ADC_SCAN_DISABLE, \
51+
.Init.EOCSelection = ADC_EOC_SINGLE_CONV, \
52+
.Init.LowPowerAutoWait = DISABLE, \
53+
.Init.ContinuousConvMode = DISABLE, \
54+
.Init.NbrOfConversion = 1, \
55+
.Init.DiscontinuousConvMode = DISABLE, \
56+
.Init.NbrOfDiscConversion = 1, \
57+
.Init.ExternalTrigConv = ADC_SOFTWARE_START, \
58+
.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE, \
59+
.Init.ConversionDataManagement = ADC_CONVERSIONDATA_DR, \
60+
.Init.Overrun = ADC_OVR_DATA_OVERWRITTEN, \
61+
.Init.OversamplingMode = DISABLE, \
62+
}
63+
#endif /* ADC2_CONFIG */
64+
#endif /* BSP_USING_ADC2 */
65+
66+
#ifdef BSP_USING_ADC3
67+
#ifndef ADC3_CONFIG
68+
#define ADC3_CONFIG \
69+
{ \
70+
.Instance = ADC3, \
71+
.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV4, \
72+
.Init.Resolution = ADC_RESOLUTION_16B, \
73+
.Init.ScanConvMode = ADC_SCAN_DISABLE, \
74+
.Init.EOCSelection = ADC_EOC_SINGLE_CONV, \
75+
.Init.LowPowerAutoWait = DISABLE, \
76+
.Init.ContinuousConvMode = DISABLE, \
77+
.Init.NbrOfConversion = 1, \
78+
.Init.DiscontinuousConvMode = DISABLE, \
79+
.Init.NbrOfDiscConversion = 1, \
80+
.Init.ExternalTrigConv = ADC_SOFTWARE_START, \
81+
.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE, \
82+
.Init.ConversionDataManagement = ADC_CONVERSIONDATA_DR, \
83+
.Init.Overrun = ADC_OVR_DATA_OVERWRITTEN, \
84+
.Init.OversamplingMode = DISABLE, \
85+
}
86+
#endif /* ADC3_CONFIG */
87+
#endif /* BSP_USING_ADC3 */
88+
89+
#ifdef __cplusplus
90+
}
91+
#endif
92+
93+
#endif /* __ADC_CONFIG_H__ */
94+
Lines changed: 43 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,43 @@
1+
/*
2+
* Copyright (c) 2006-2026, RT-Thread Development Team
3+
*
4+
* SPDX-License-Identifier: Apache-2.0
5+
*
6+
* Change Logs:
7+
* Date Author Notes
8+
* 2020-06-16 thread-liu first version
9+
*/
10+
11+
#ifndef __DAC_CONFIG_H__
12+
#define __DAC_CONFIG_H__
13+
14+
#include <rtthread.h>
15+
16+
#ifdef __cplusplus
17+
extern "C" {
18+
#endif
19+
20+
#ifdef BSP_USING_DAC1
21+
#ifndef DAC1_CONFIG
22+
#define DAC1_CONFIG \
23+
{ \
24+
.Instance = DAC1, \
25+
}
26+
#endif /* DAC2_CONFIG */
27+
#endif /* BSP_USING_DAC2 */
28+
29+
#ifdef BSP_USING_DAC2
30+
#ifndef DAC2_CONFIG
31+
#define DAC2_CONFIG \
32+
{ \
33+
.Instance = DAC2, \
34+
}
35+
#endif /* DAC2_CONFIG */
36+
#endif /* BSP_USING_DAC2 */
37+
38+
#ifdef __cplusplus
39+
}
40+
#endif
41+
42+
#endif /* __DAC_CONFIG_H__ */
43+
Lines changed: 152 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,152 @@
1+
/*
2+
* Copyright (c) 2006-2026, RT-Thread Development Team
3+
*
4+
* SPDX-License-Identifier: Apache-2.0
5+
*
6+
* Change Logs:
7+
* Date Author Notes
8+
* 2019-01-02 zylx first version
9+
* 2019-01-08 SummerGift clean up the code
10+
* 2020-05-02 whj4674672 support stm32h7 dma1 and dma2
11+
*/
12+
13+
#ifndef __DMA_CONFIG_H__
14+
#define __DMA_CONFIG_H__
15+
16+
#include <rtthread.h>
17+
18+
#ifdef __cplusplus
19+
extern "C" {
20+
#endif
21+
22+
/* DMA1 stream0 */
23+
#if defined(BSP_UART2_RX_USING_DMA) && !defined(UART2_RX_DMA_INSTANCE)
24+
#define UART2_DMA_RX_IRQHandler DMA1_Stream0_IRQHandler
25+
#define UART2_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
26+
#define UART2_RX_DMA_INSTANCE DMA1_Stream0
27+
#define UART2_RX_DMA_REQUEST DMA_REQUEST_USART2_RX
28+
#define UART2_RX_DMA_IRQ DMA1_Stream0_IRQn
29+
#endif
30+
31+
/* DMA1 stream1 */
32+
#if defined(BSP_UART2_TX_USING_DMA) && !defined(UART2_TX_DMA_INSTANCE)
33+
#define UART2_DMA_TX_IRQHandler DMA1_Stream1_IRQHandler
34+
#define UART2_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
35+
#define UART2_TX_DMA_INSTANCE DMA1_Stream1
36+
#define UART2_TX_DMA_REQUEST DMA_REQUEST_USART2_TX
37+
#define UART2_TX_DMA_IRQ DMA1_Stream1_IRQn
38+
#endif
39+
40+
/* DMA1 stream2 */
41+
#if defined(BSP_SPI3_RX_USING_DMA) && !defined(SPI3_RX_DMA_INSTANCE)
42+
#define SPI3_DMA_RX_IRQHandler DMA1_Stream2_IRQHandler
43+
#define SPI3_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
44+
#define SPI3_RX_DMA_INSTANCE DMA1_Stream2
45+
#define SPI3_RX_DMA_IRQ DMA1_Stream2_IRQn
46+
#endif
47+
48+
/* DMA1 stream3 */
49+
#if defined(BSP_SPI2_RX_USING_DMA) && !defined(SPI2_RX_DMA_INSTANCE)
50+
#define SPI2_DMA_RX_IRQHandler DMA1_Stream3_IRQHandler
51+
#define SPI2_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
52+
#define SPI2_RX_DMA_INSTANCE DMA1_Stream3
53+
#define SPI2_RX_DMA_IRQ DMA1_Stream3_IRQn
54+
#endif
55+
56+
/* DMA1 stream4 */
57+
#if defined(BSP_SPI2_TX_USING_DMA) && !defined(SPI2_TX_DMA_INSTANCE)
58+
#define SPI2_DMA_TX_IRQHandler DMA1_Stream4_IRQHandler
59+
#define SPI2_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
60+
#define SPI2_TX_DMA_INSTANCE DMA1_Stream4
61+
#define SPI2_TX_DMA_IRQ DMA1_Stream4_IRQn
62+
#endif
63+
64+
65+
/* DMA1 stream5 */
66+
#if defined(BSP_SPI3_TX_USING_DMA) && !defined(SPI3_TX_DMA_INSTANCE)
67+
#define SPI3_DMA_TX_IRQHandler DMA1_Stream5_IRQHandler
68+
#define SPI3_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
69+
#define SPI3_TX_DMA_INSTANCE DMA1_Stream5
70+
#define SPI3_TX_DMA_IRQ DMA1_Stream5_IRQn
71+
#endif
72+
73+
/* DMA1 stream6 */
74+
75+
/* DMA1 stream7 */
76+
#if defined(BSP_SPI3_TX_USING_DMA) && !defined(SPI3_TX_DMA_INSTANCE)
77+
#define SPI3_DMA_TX_IRQHandler DMA1_Stream7_IRQHandler
78+
#define SPI3_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
79+
#define SPI3_TX_DMA_INSTANCE DMA1_Stream7
80+
#define SPI3_TX_DMA_IRQ DMA1_Stream7_IRQn
81+
#endif
82+
83+
/* DMA2 stream0 */
84+
#if defined(BSP_SPI1_RX_USING_DMA) && !defined(SPI1_RX_DMA_INSTANCE)
85+
#define SPI1_DMA_RX_IRQHandler DMA2_Stream0_IRQHandler
86+
#define SPI1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
87+
#define SPI1_RX_DMA_INSTANCE DMA2_Stream0
88+
#define SPI1_RX_DMA_IRQ DMA2_Stream0_IRQn
89+
#endif
90+
91+
/* DMA2 stream1 */
92+
#if defined(BSP_SPI4_TX_USING_DMA) && !defined(SPI4_TX_DMA_INSTANCE)
93+
#define SPI4_DMA_TX_IRQHandler DMA2_Stream1_IRQHandler
94+
#define SPI4_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
95+
#define SPI4_TX_DMA_INSTANCE DMA2_Stream1
96+
#define SPI4_TX_DMA_IRQ DMA2_Stream1_IRQn
97+
#endif
98+
99+
/* DMA2 stream2 */
100+
#if defined(BSP_SPI1_RX_USING_DMA) && !defined(SPI1_RX_DMA_INSTANCE)
101+
#define SPI1_DMA_RX_IRQHandler DMA2_Stream2_IRQHandler
102+
#define SPI1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
103+
#define SPI1_RX_DMA_INSTANCE DMA2_Stream2
104+
#define SPI1_RX_DMA_IRQ DMA2_Stream2_IRQn
105+
#endif
106+
107+
/* DMA2 stream3 */
108+
#if defined(BSP_SPI5_RX_USING_DMA) && !defined(SPI5_RX_DMA_INSTANCE)
109+
#define SPI5_DMA_RX_IRQHandler DMA2_Stream3_IRQHandler
110+
#define SPI5_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
111+
#define SPI5_RX_DMA_INSTANCE DMA2_Stream3
112+
#define SPI5_RX_DMA_IRQ DMA2_Stream3_IRQn
113+
#endif
114+
115+
/* DMA2 stream4 */
116+
#if defined(BSP_SPI5_TX_USING_DMA) && !defined(SPI5_TX_DMA_INSTANCE)
117+
#define SPI5_DMA_TX_IRQHandler DMA2_Stream4_IRQHandler
118+
#define SPI5_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
119+
#define SPI5_TX_DMA_INSTANCE DMA2_Stream4
120+
#define SPI5_TX_DMA_IRQ DMA2_Stream4_IRQn
121+
#endif
122+
123+
/* DMA2 stream5 */
124+
#if defined(BSP_SPI1_TX_USING_DMA) && !defined(SPI1_TX_DMA_INSTANCE)
125+
#define SPI1_DMA_TX_IRQHandler DMA2_Stream5_IRQHandler
126+
#define SPI1_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
127+
#define SPI1_TX_DMA_INSTANCE DMA2_Stream5
128+
#define SPI1_TX_DMA_IRQ DMA2_Stream5_IRQn
129+
#endif
130+
131+
/* DMA2 stream6 */
132+
#if defined(BSP_SPI5_TX_USING_DMA) && !defined(SPI5_TX_DMA_INSTANCE)
133+
#define SPI5_DMA_TX_IRQHandler DMA2_Stream6_IRQHandler
134+
#define SPI5_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
135+
#define SPI5_TX_DMA_INSTANCE DMA2_Stream6
136+
#define SPI5_TX_DMA_IRQ DMA2_Stream6_IRQn
137+
#endif
138+
139+
/* DMA2 stream7 */
140+
#if defined(BSP_QSPI_USING_DMA) && !defined(QSPI_DMA_INSTANCE)
141+
#define QSPI_DMA_IRQHandler DMA2_Stream7_IRQHandler
142+
#define QSPI_DMA_RCC RCC_AHB1ENR_DMA2EN
143+
#define QSPI_DMA_INSTANCE DMA2_Stream7
144+
#define QSPI_DMA_IRQ DMA2_Stream7_IRQn
145+
#endif
146+
147+
#ifdef __cplusplus
148+
}
149+
#endif
150+
151+
#endif /* __DMA_CONFIG_H__ */
152+

0 commit comments

Comments
 (0)