2020-10-12 21:40:05 +08:00
|
|
|
|
# nRF5x BSP 说明
|
2020-04-14 22:17:27 +08:00
|
|
|
|
|
2020-10-12 21:40:05 +08:00
|
|
|
|
## 简介
|
|
|
|
|
|
|
|
|
|
Nordic nRF5x 系列 MCU 应用广泛,且功能齐全、灵活性高,非常适用于 Bluetooth 低功耗蓝牙和 2.4 GHz 超低功耗无线应用。
|
|
|
|
|
|
|
|
|
|
基于官方[sdk16.0](http://developer.nordicsemi.com/nRF5_SDK/nRF5_SDK_v16.x.x/nRF5_SDK_16.0.0_98a08e2.zip)版本的基础上,该BSP将官方的SDK和RT-THREAD生态结合,让开发者可以既可以基于官方的sdk开发自己的应用,也可以使用RT-Thread生态的软件包。
|
|
|
|
|
|
|
|
|
|
目前支持硬件平台:`nrf52832(pca10040)`、`nrf52840`(pca10056)
|
|
|
|
|
|
|
|
|
|
在搭建bsp的时候,通过参考STM32的架构,预留出支持多种nordic芯片的框架,理论上可以支持更多的nordic的平台,限于目前社区小伙伴手上的开发板有限,如果您手上有相关nordic的开发板,欢迎添加对应的nordic的芯片的bsp。
|
|
|
|
|
|
|
|
|
|
Nordic nRF5x系列BSP 目前支持情况如下:
|
|
|
|
|
|
|
|
|
|
| nordic主芯片 | 开发板名称 | bsp所在文件夹 | 备注 |
|
|
|
|
|
| ------------ | ------------------------------------------------------------ | ------------- | ---- |
|
|
|
|
|
| nrf52840 | 官方pca10056 | nrf52840 | |
|
|
|
|
|
| nrf52832 | 官方pca10040 | nrf52832 | |
|
|
|
|
|
| nrf52840 | [青风52840](https://item.taobao.com/item.htm?spm=a1z10.1-c-s.w4004-15118192232.5.46a15d490SURQ9&id=581711815379) | nrf52840 | |
|
|
|
|
|
|
|
|
|
|
### 主要支持功能
|
|
|
|
|
|
|
|
|
|
- 支持官方softdevice的sample: ble_app_uart、ble_app_blinky、ble_app_hrs(softdevice是官方nordic的协议栈名称)
|
|
|
|
|
- 支持nimble的软件包及对应的sample
|
|
|
|
|
- 官方softdevice的sample和RT-THREAD驱动框架结合。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 目录结构
|
2020-04-14 22:17:27 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
nrf5x
|
|
|
|
|
├───docs
|
2020-10-17 21:39:10 +08:00
|
|
|
|
│ └───images // nrf5x文档使用图片
|
2020-04-14 22:17:27 +08:00
|
|
|
|
│ └───nRF5x系列BSP制作教程.md
|
2020-10-17 21:39:10 +08:00
|
|
|
|
├───libraries // nrf5x系列支持BSP
|
2020-04-14 22:17:27 +08:00
|
|
|
|
│ └───drivers // nRF5x 系列设备通用驱动文件
|
|
|
|
|
│ └───templates // 通用设备 BSP 工程模板
|
2020-10-17 21:39:10 +08:00
|
|
|
|
│ │ └───nrf52x // nrf52x 系列 BSP 工程模板
|
2020-04-14 22:17:27 +08:00
|
|
|
|
│ │ └───nrf5x_board_kconfig // 通用 BSP 工程配置文件
|
|
|
|
|
├───nrf52832 // nrf52832 BSP 工程
|
|
|
|
|
│ └───application // 应用代码
|
|
|
|
|
│ │ board // 链接脚本文件,开发板硬件初始化和配置文件
|
|
|
|
|
│ │ package // 软件包目录
|
|
|
|
|
│ │ └───nRF5_SDK // nordic 官方 nRF5x SDK
|
|
|
|
|
│ │ kconfig // 工程配置文件
|
|
|
|
|
│ └───rtconfig.h
|
|
|
|
|
├───nrf52840 // nrf52840 BSP 工程
|
2020-10-17 21:39:10 +08:00
|
|
|
|
└───README.md // nordic 工程整体介绍
|
2020-10-12 21:40:05 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### 如何使用
|
|
|
|
|
|
|
|
|
|
#### RT-THREAD的使用
|
|
|
|
|
|
|
|
|
|
默认的RT-THREAD工程是不带有蓝牙协议栈功能的,方便客户先搭建对应的bsp平台,后续可以选择任意协议栈运行蓝牙。
|
|
|
|
|
|
|
|
|
|
默认的BSP是支持UART和GPIO的,烧入即可亮灯。
|
|
|
|
|
|
|
|
|
|
**准备工作**
|
|
|
|
|
|
|
|
|
|
需要env环境和keil环境,并且对RT-THREAD使用稍微熟悉一些即可。
|
|
|
|
|
|
|
|
|
|
- 首先下载代码,`git clone https://github.com/RT-Thread/rt-thread.git`
|
|
|
|
|
- 进入到目录`rt-thread/bsp/nrf5x/nrf52840`
|
|
|
|
|
- 右击进入env命令行模式
|
|
|
|
|
- menuconfig 选择需要加载的BSP配置并且保存
|
|
|
|
|
- 执行`pkgs --update` 下载对应的硬件软件包(这里的HAL库采用软件包的方式,需要客户自行下载)
|
|
|
|
|
- 执行`scons --target=mdk5` 生成keil工程,烧入即可看到LED小灯闪烁
|
|
|
|
|
- 需要注意的是,如果之前板子上已经烧入softdevice的话,烧入可能会出现烧不进的情况,需要将整颗芯片擦除之后再运行rt-thread裸工程
|
|
|
|
|
|
|
|
|
|
#### Softdevice 的使用
|
|
|
|
|
|
|
|
|
|
首先可以熟悉上述工程的运行,在上述运行的基础上,我们可以试着跑一下ble_app_beacon(这个在SDK16.0中的peripheral 的sample中)
|
|
|
|
|
|
|
|
|
|
- menuconfig 进入Hardware Drivers Config, BLE STACK 选择Nordic softdevice
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/be4b2/be4b2320cc7a4072d2b3f83acfc6a158ad21ea31" alt="image-20201017191936859"
|
|
|
|
|
|
|
|
|
|
- menuconfig 进入peripheral libraries and drivers目录中选中nrf5x_sdk
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6c74e/6c74e5341434b9249565a2e81e3296f9557bd0ba" alt="image-20201017190154925"
|
|
|
|
|
|
|
|
|
|
- 进入目录选择对应的sample
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5bdf2/5bdf2894924531f907f625a787196f1ef7e0ef76" alt="image-20201017190301705"
|
|
|
|
|
|
|
|
|
|
- 保存配置,然后`pkgs --update`, 执行`scons --target=mdk5`
|
2020-10-17 21:39:10 +08:00
|
|
|
|
- 打开keil 工程,softdevice的工程需要烧入官方的协议栈,所以先要烧入softdevice(如果之前已经烧入SDK16.0的softdevice,可以不用执行这一步),点击softdevice工程,烧入即可
|
2020-10-12 21:40:05 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/aba66/aba666946dcb3959b139ffccff0e29f552c6c08b" alt="image-20201017192453525"
|
|
|
|
|
|
|
|
|
|
- 重新选择rtthread工程,进行编译,烧入,通过串口看到如下的输出即代表成功
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/8f099/8f099d36d5a0ff949d2ff48b9fdee0f29f56d865" alt="image-20201017192639096"
|
|
|
|
|
|
|
|
|
|
- 这个时候我们执行命令 `ble_app_beacon` 不同的sample对应不同的命令,看到如下log代表beacon已经跑起来了
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a6bfc/a6bfc934d5720396f356a398f51739e775ea36e1" alt="image-20201017192807997"
|
|
|
|
|
|
|
|
|
|
- 这个时候用nrf connect 来测试可以搜索到对应的beacon
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b5e68/b5e68f6cf752036242b1bc516cf45ab4b155422d" alt="image-20201017193633608"
|
|
|
|
|
|
|
|
|
|
#### nimble的使用
|
|
|
|
|
|
|
|
|
|
如果使用nimble就不能选择softdevice了,所以要清空之前的配置,为了防止误操作,可以选择将nrf52840的目录下面的内容全部执行`git reset --hard` 之后重复上述操作,然后执行`git clean -xfd`清理掉无效的文件
|
|
|
|
|
|
|
|
|
|
- menuconfig进入BLE STACK 选择nimble
|
|
|
|
|
|
|
|
|
|
- menuconfig选择nimble
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7af0c/7af0c7aaa0894da1e1a32cce5b6a62b5d4ad07eb" alt="image-20201017194305048"
|
|
|
|
|
|
|
|
|
|
- 进入Controller Configuration 选择nrf52840
|
|
|
|
|
- 进入Bluetooth Samples 选择ble beacon sample
|
|
|
|
|
- 执行`pkgs --update` 下载需要的软件包
|
|
|
|
|
- 执行`scons --target=mdk5`
|
2021-08-19 15:55:36 +08:00
|
|
|
|
- 打开keil工程,勾选GNU extensions
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a0ec6/a0ec6c35eea4419de2a0e2d319115a794b6d4a92" alt="screen2021-08-19_100407"
|
|
|
|
|
|
2020-10-12 21:40:05 +08:00
|
|
|
|
- 打开keil工程烧入代码,这个时候需要注意的是,如果之前有softdevice存在flash中,需要擦除芯片中的softdevice。
|
|
|
|
|
- 烧入之后执行cmd `ble_ibeacon`
|
|
|
|
|
- 之后用nrf connect 软件可以搜索到对应的beacon设备。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2022-06-09 11:55:11 +08:00
|
|
|
|
## 使用RTT-STUDIO开发
|
|
|
|
|
|
|
|
|
|
RTT-STUDIO V2.2.0及以上版本,支持直接导入BSP创建工程,而可以不用再依赖于基于开发版来创建工程了,这样,我们可以一直体验最新的代码了,是不是很香
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5e4a9/5e4a9d7c49e7130ae47cbf8602257ea5ec641af6" alt="image-20220609112426518"
|
|
|
|
|
|
|
|
|
|
### 导入nRF5x BSP到RTT-STUDIO中
|
|
|
|
|
|
|
|
|
|
1. 右击资源管理窗口,鼠标右击导入
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f17eb/f17eb52bb6676078e040e78f6a7dac1597e4f51e" alt="image-20220609112322574"
|
|
|
|
|
|
|
|
|
|
2. 选择导入BSP到工作空间,点击下一步
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c6848/c684881aec5b592442d3714e914949f6b71c6afd" alt="image-20220609112938212"
|
|
|
|
|
|
|
|
|
|
3. 选择BSP根目录,以及填写工程名称,点击完成
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/97bae/97baef74f968b04aa8c51ee0e429fd6304f94820" alt="image-20220609113142111"
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/810c6/810c67f0c96a2f88b41184c3d9654dcf1de974c5" alt="image-20220609113203519"
|
|
|
|
|
|
|
|
|
|
4. 通过观察控制台LOG,我们发现,其实当执行该操作时,背后的操作逻辑是,进入指定的BSP目录,执行下面的命令
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
先进入指定BSP目录,然后执行下面的额命令
|
|
|
|
|
scons --dist-ide --project-path=D:\RT-ThreadStudio\workspace/nrf52832_test --project-name=nrf52832_test
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1a8b4/1a8b44f86a6ece3df519441724e33945aad79131" alt="image-20220609113439251"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
5. 直接编译工程,发现已经编译成功
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d307d/d307d51d39153434f1d11e9fd1e4a279d631126d" alt="image-20220609113611068"
|
|
|
|
|
|
|
|
|
|
6. 下载程序到开发板,点击下载按钮,发现有如下提示(我目前使用的studio版本是版本: 2.2.3,后续该问题应该可以修复掉)
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bdceb/bdcebe4f2ede92e5039805f11ed4e04695ec4ae9" alt="image-20220609113726186"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
经过请教施工,解决了上面的问题,解决步骤如下
|
|
|
|
|
|
|
|
|
|
6.1 打开导入后的工程目录,打开.settings文件夹中的projcfg.ini文件
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9e876/9e876e7a160769c6bb6b661b5a8dc1db42e0b1dc" alt="image-20220609114026961"
|
|
|
|
|
|
|
|
|
|
6.2 添加如下内容`J-Link`
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ee50f/ee50f1fd4d42133530bcb6ad0083b93fabc6a05a" alt="image-20220609114121378"
|
|
|
|
|
|
|
|
|
|
6.3 打开调试配置界面,填写设备名,设备名具体写什么,可以参考这里[链接](https://www.segger.com/supported-devices/jlink/)
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/3daf9/3daf93d8219bc509e1b05a3ec91336d3e944ab5d" alt="image-20220609114333827"
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4667d/4667df815d64d0f2a699b6ef67cfd29bd4c1c8d3" alt="image-20220609114533743"
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/90f7a/90f7afb31534098d2cf82aaf7399b731063869ab" alt="image-20220609114554402"
|
|
|
|
|
|
2020-10-12 21:40:05 +08:00
|
|
|
|
## FAQ:
|
|
|
|
|
|
|
|
|
|
#### 1. 如果烧入的时候出现如下状况:
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a06e3/a06e342d32ec271f025a3ec7d6c4135bd27f27a1" alt="image-20200912144630334"
|
|
|
|
|
|
|
|
|
|
说明板子上已经烧入了softdevice,需要擦除掉,才能烧入不带有softdevice的程序。
|
|
|
|
|
|
|
|
|
|
下面提供一种擦写softdevice的方法。在keil中选择softdevice Erase的FLASH算法,这个时候就烧写之前可以擦除之前的softdevice。
|
|
|
|
|
|
2021-02-18 06:23:53 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/02dac/02dace09f00ca47097c8b13ad7da149b28f0d1f2" alt="image-20201017194935643"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 2.如果在使用softdevice的时候,连上手机时候出现一些hardfault
|
|
|
|
|
|
|
|
|
|
如下所示:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
psr: 0x8100000f
|
|
|
|
|
r00: 0x00000000
|
|
|
|
|
r01: 0x200034e6
|
|
|
|
|
r02: 0x00000000
|
|
|
|
|
r03: 0x200034dc
|
|
|
|
|
r04: 0x200034dc
|
|
|
|
|
r05: 0x00000000
|
|
|
|
|
r06: 0x200034e6
|
|
|
|
|
r07: 0xdeadbeef
|
|
|
|
|
r08: 0xdeadbeef
|
|
|
|
|
r09: 0xdeadbeef
|
|
|
|
|
r10: 0xdeadbeef
|
|
|
|
|
r11: 0xdeadbeef
|
|
|
|
|
r12: 0x00000000
|
|
|
|
|
lr: 0x000369af
|
|
|
|
|
pc: 0x00036972
|
|
|
|
|
hard fault on handler
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
这个hardfault发生在SOFTDEVICE内部,由于代码不开源,这边尝试了修改如下函数,可以不触发hardfault。
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
rt_hw_interrupt_disable PROC
|
|
|
|
|
EXPORT rt_hw_interrupt_disable
|
|
|
|
|
;MRS r0, PRIMASK
|
|
|
|
|
;CPSID I
|
|
|
|
|
BX LR
|
|
|
|
|
ENDP
|
|
|
|
|
|
|
|
|
|
;/*
|
|
|
|
|
; * void rt_hw_interrupt_enable(rt_base_t level);
|
|
|
|
|
; */
|
|
|
|
|
rt_hw_interrupt_enable PROC
|
|
|
|
|
EXPORT rt_hw_interrupt_enable
|
|
|
|
|
;MSR PRIMASK, r0
|
|
|
|
|
BX LR
|
|
|
|
|
ENDP
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|