mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-26 03:27:04 +08:00
- [update] 更新 template 工程配置 - [update] 更新 PLATFORM 配置 - [add] 添加 ra icu 驱动文件 - [add] 增加传感器类型 IAQ、EtOH - [add] 添加 CAN 驱动 - [add] 添加 RW007 驱动及使用说明 - [fix] GCC 编译问题 - [fix] flash 驱动 - [fix] 修改 scons 脚本配置
297 lines
11 KiB
Markdown
297 lines
11 KiB
Markdown
## 在 MDK 中使用 FSP
|
||
|
||
### 添加RA Smart Config
|
||
|
||
1. 打开 MDK,选择 “Tools -> Customize Tools Menu…”
|
||
2. 点击 “new” 图标,添加一条自定义命令: RA Smart Configurator
|
||
3. Command 输入工具的安装路径, 点击“…”找到安装路径下的“rasc.exe”文件并选中 (setup_fsp_v3_1_0_rasc_ 安装目录下)
|
||
4. Initial Folder 输入参数: $P
|
||
5. Arguments 输入参数: --device $D --compiler ARMv6 configuration.xml
|
||
6. 点击 OK 保存命令“Tools -> RA smart Configurator”
|
||
|
||
data:image/s3,"s3://crabby-images/aabee/aabee0f2cb0276443e93f28adba27df18850cf71" alt="img"
|
||
|
||
7. 点击添加的命令打开配置工具:RA Smart Config
|
||
|
||
data:image/s3,"s3://crabby-images/3d70b/3d70bc19b2a50fe87aa801221a593aefdfc648ba" alt="image.png"
|
||
|
||
### 添加 Device Partition Manager,添加步骤同上。
|
||
|
||
1. 输入命令名称:`Device Partition Manager`
|
||
2. Command: 在安装路径选中`rasc.exe`
|
||
3. Initial Folder :`$P`
|
||
4. Arguments:`-application com.renesas.cdt.ddsc.dpm.ui.dpmapplication configuration.xml "SL%L"`
|
||
|
||
> PS:以上相关操作也可以在 FSP 的说明文档中找到。
|
||
>
|
||
> 文档路径(本地):在 FSP 的安装目录下 .\fsp_documentation\v3.1.0\fsp_user_manual_v3.1.0\index.html
|
||
>
|
||
> 文档路径(官网):https://www2.renesas.cn/jp/zh/software-tool/flexible-software-package-fsp#document
|
||
|
||
### FSP 版本选择
|
||
|
||
此 BSP 使用 **FSP 3.1.0** 版本为基础制作,优先推荐使用 FSP 3.1.0 版本进行配置修改。
|
||
|
||
**使用 RASC 前请务必检查 FSP version 、Board、Device 配置项是否正确。**
|
||
|
||
data:image/s3,"s3://crabby-images/a51f7/a51f7610e73d57ec1901b34c27dfedbda880e550" alt="fsp_version"
|
||
|
||
## 更新工程配置
|
||
|
||
使用 FSP 配置完成后如果有新的文件添加进工程中,不会马上添加进去。需要先编译一次,如果弹出如下提醒,选择 “是” 然后再次编译即可。
|
||
|
||
data:image/s3,"s3://crabby-images/993f0/993f0e1a9b968dd0dc2ad432da13a2ae6ff9ace1" alt="img"
|
||
|
||
## 如何使用 RASC 添加外设
|
||
|
||
**注意:文档中的外设添加步骤均为单独配置的说明,排版顺序不代表外设添加顺序,如遇到引脚冲突请查阅开发板及芯片手册的相关章节。**
|
||
|
||
### UART
|
||
|
||
如何添加一个 UART 端口外设配置?
|
||
|
||
1. 选择 Stacks 配置页,点击 New Stack 找到 UART。
|
||
|
||
data:image/s3,"s3://crabby-images/96058/9605815de46bc9e54514f3663ce3f2e92b5c96b5" alt="image.png"
|
||
|
||
2. 配置 UART 参数,因为需要适配 RT-Thread 驱动中使用的命名,所以需要修改命名,设置**name** 、**channel** 、**callback** 是一致的标号。data:image/s3,"s3://crabby-images/76ee7/76ee73ee6e7ce9a5f70d5c6cfd2edcef490ef1a7" alt="image.png"
|
||
|
||
### GPIO 中断
|
||
|
||
如何添加一个 IO 中断?
|
||
|
||
1. 选择引脚编号,进入配置,比如选择 P105 做为中断引脚。可先找到引脚查看可配置成的 IRQx 通道号。
|
||
|
||
data:image/s3,"s3://crabby-images/433c1/433c1d34d772fd1a7bb60961fa0c861ab18b33b5" alt="image-20211103200949759"
|
||
|
||
2. 打开 ICU 中断通道 IRQ00
|
||
|
||
data:image/s3,"s3://crabby-images/fce5b/fce5b501c1081074ef73ede49a6d73959b8c0fc4" alt="image-20211103200813467"
|
||
|
||
3. 创建 stack 并进入配置。因为需要适配 RT-Thread 驱动中使用的命名,所以需要修改命名,设置**name** 、**channel** 、**callback** 是一致的标号。选择你希望的触发方式,最后保存配置,生成配置代码。
|
||
|
||
data:image/s3,"s3://crabby-images/a3847/a3847eb3667b13de7aa027e3da47d932d8013230" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/1409e/1409ec9f7770c03adbdf14620e27d0971c76497f" alt="image-20211103201047103"
|
||
|
||
4. 测试中断是否成功开启
|
||
|
||
```c
|
||
#define IRQ_TEST_PIN "p105"
|
||
void irq_callback_test(void *args)
|
||
{
|
||
rt_kprintf("\n IRQ00 triggered \n");
|
||
}
|
||
|
||
void icu_sample(void)
|
||
{
|
||
/* init */
|
||
rt_uint32_t pin = rt_pin_get(IRQ_TEST_PIN);
|
||
rt_kprintf("\n pin number : 0x%04X \n", pin);
|
||
rt_err_t err = rt_pin_attach_irq(pin, PIN_IRQ_MODE_RISING, irq_callback_test, RT_NULL);
|
||
if(RT_EOK != err)
|
||
{
|
||
rt_kprintf("\n attach irq failed. \n");
|
||
}
|
||
err = rt_pin_irq_enable(pin, PIN_IRQ_ENABLE);
|
||
if(RT_EOK != err)
|
||
{
|
||
rt_kprintf("\n enable irq failed. \n");
|
||
}
|
||
}
|
||
MSH_CMD_EXPORT(icu_sample, icu sample);
|
||
```
|
||
|
||
### WDT
|
||
|
||
1. 创建 WDT
|
||
|
||
data:image/s3,"s3://crabby-images/6bf79/6bf798d32568db6a542c502d977c6f3134684f38" alt="image-20211019152302939"
|
||
|
||
2. 配置 WDT,需要注意在 RT-Thread 中只使用了一个 WDT 设备,所以没有对其进行编号,如果是新创建的 WDT 设备需要注意 name 字段,在驱动中默认使用的是`g_wdt` 。
|
||
|
||
data:image/s3,"s3://crabby-images/00f40/00f40692bdb5eecb8d10c1c820db8e75fd759386" alt="image-20211019152407572"
|
||
|
||
3. 如何在 ENV 中打开 WDT 以及[WDT 接口使用说明](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/watchdog/watchdog)
|
||
|
||
data:image/s3,"s3://crabby-images/957c4/957c43f94ac5d9ff95c4398c92528d2c3a62c9c2" alt="image-20211027183406251"
|
||
|
||
### RTC
|
||
|
||
1. 添加 RTC 设备
|
||
|
||
data:image/s3,"s3://crabby-images/4cbf8/4cbf89bd0b89a6cc4c0d29345a43627f3ef68ecb" alt="image-20211019152536749"
|
||
|
||
2. 配置 RTC,需要注意在 RT-Thread 中只是用了一个 RTC 设备,所以没有对其进行编号,如果是新创建的 RTC 设备需要注意 name 字段,在驱动中默认使用的是`g_rtc` 。修改 Callback 为 rtc_callback
|
||
|
||
data:image/s3,"s3://crabby-images/1709a/1709a9aeb340b8a160ac9e4c2cd6e3acaa44ca93" alt="image-20211019152627412"
|
||
|
||
3. 如何在 ENV 中打开 RTC 以及[ RTC 接口使用说明](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/rtc/rtc)
|
||
|
||
data:image/s3,"s3://crabby-images/c47a5/c47a5e150b56f213457ae4eb259123224b64a9b9" alt="image-20211027181550233"
|
||
|
||
### Flash
|
||
|
||
1. 创建 Flash
|
||
|
||
data:image/s3,"s3://crabby-images/f4731/f4731184cedf2acef75e631eccf97cb4843d2e2f" alt="image-20211026105031200"
|
||
|
||
2. 配置 Flash,需要注意在 RT-Thread 中只使用了一个 flash 设备,所以没有对其进行编号,如果是新创建的 flash 设备需要注意 name 字段,在驱动中默认使用的是`g_flash` 。
|
||
|
||
data:image/s3,"s3://crabby-images/a636a/a636a857a30e893fa9f76617fc3a02a9f96423f1" alt="image-20211026105628706"
|
||
|
||
3. 如何在 ENV 中打开 Flash
|
||
|
||
data:image/s3,"s3://crabby-images/636b0/636b0afcfb29e580fa5511d9669696c8bf0d5d75" alt="image-20211026123252310"
|
||
|
||
### SPI
|
||
|
||
1. 添加一个 SPI 外设端口
|
||
|
||
data:image/s3,"s3://crabby-images/9feee/9feee7ff80e6f7f36b535524a7ab60732f2cda2f" alt="image-20211027180820968"
|
||
|
||
2. 配置 channel、name、Clock Phase、Clock Polarity、Callback、 SPI Mode 等参数,波特率在代码中可通过 API 修改,这里可以设置一个默认值。
|
||
|
||
data:image/s3,"s3://crabby-images/2e292/2e292821ade0b630b254b706e661ab5f6a58e51f" alt="img"
|
||
|
||
3. 在 Pins 中打开 SPI0 ,配置端口引脚。**注意:请勿在此处配置 SSLx 片选引脚,片选引脚的控制在驱动程序中由软件控制。**
|
||
|
||
data:image/s3,"s3://crabby-images/fa22c/fa22c6950f66a21c4916561d21aeb298d2934a9f" alt="image-20211209162334093"
|
||
|
||
|
||
4. 如何在 ENV 中打开 SPI 以及 [SPI 接口使用说明](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/spi/spi)
|
||
|
||
data:image/s3,"s3://crabby-images/cc24f/cc24f1f9b56547ca43f43f3aeddd17ea875d5518" alt="image-20211027181444023"
|
||
|
||
### ADC/DAC
|
||
|
||
创建 ADC/DAC
|
||
|
||
data:image/s3,"s3://crabby-images/4a88f/4a88fb71aa7a5e509bc467b695a04e88c3270821" alt="img"
|
||
|
||
- **ADC**
|
||
|
||
1. 配置 name、unit、mode,选择扫描的通道编号
|
||
|
||
data:image/s3,"s3://crabby-images/249d1/249d142f9b831d7240a2a64a55eaccbd8d7f57b6" alt="img"
|
||
|
||
2. 配置扫描通道对应的引脚
|
||
|
||
data:image/s3,"s3://crabby-images/5fb6e/5fb6e8527a415b5f83ca88b420703a18b6b42bb0" alt="img"
|
||
|
||
3. 在 menuconfig 中打开对应的通道
|
||
|
||
- **DAC**
|
||
|
||
1. 需要先关闭 P014 的默认 mode
|
||
|
||
data:image/s3,"s3://crabby-images/a9a30/a9a304580aab9157dc15e79036f23d0ff69b0147" alt="img"
|
||
|
||
2. 开启 DAC0 通道
|
||
|
||
data:image/s3,"s3://crabby-images/32964/32964358bc9acf8573cb9169245af47b0ca4e7e5" alt="img"
|
||
|
||
3. 修改通道号为 0,与 DAC0 对应
|
||
|
||
data:image/s3,"s3://crabby-images/ae650/ae650b4f0d035261a91ea89ca7689eccfcc6a6cf" alt="img"
|
||
|
||
4. 在 menuconfig 中打开对应的通道
|
||
|
||
### 通用 PWM 定时器(GPT)
|
||
|
||
GPT 定时器在该芯片中可作为通用定时器,也可以用于产生 PWM 信号。在将其用于产生 PWM 信号时,GPT 定时器提供了 gpt0 - gpt9 总共 10 个通道,每个通道可以设定两个输出端口。当前版本的 PWM 驱动将每个通道都看做一个单独的 PWM 设备,每个设备都只有一个通道。用户可以选择开启一个通道的任意一个输出端口,或将两个端口均开启,但在同时开启两个端口的情况下,它们输出的波形将完全一致。
|
||
|
||
1. 添加 GPT 设备
|
||
|
||
data:image/s3,"s3://crabby-images/24072/240720eff7bc050f5e9cf0979b125a9205169758" alt="img"
|
||
2. 配置通道
|
||
|
||
data:image/s3,"s3://crabby-images/954af/954afa576560c4306afd76c7ebd0b6b50349e7d0" alt="img"
|
||
|
||
对 GPT 较为关键的配置如图所示,具体解释如下:
|
||
|
||
1. 将``Common`` ->``Pin Output Support`` 设置为 Enable ,以开启 PWM 波形的输出。
|
||
2. 指定 GPT 通道,并根据通道数指定 GPT 的名称,例如此处指定 GPT 通道 3 ,所以 GPT 的名称必须为``g_timer3``。并且将定时器模式设置为 PWM ,并指定每个 PWM 周期的计数值。
|
||
3. 设定 PWM 通道默认输出的占空比,这里为 50% 。
|
||
4. 设定 GPT 通道下两个输出端口的使能状态。
|
||
5. 此处设置 GPT 通道下两个输出端口各自对应的引脚。
|
||
3. 配置输出引脚
|
||
|
||
data:image/s3,"s3://crabby-images/6bc7a/6bc7af1d57ff58bc49ad2031133f688e694b5faa" alt="img"
|
||
|
||
在完成上一步对 GPT 定时器的设置后,根据图示找到对应 GPT 通道输出引脚设置的界面(这里是 GPT3),将图中标号 **1** 处设置为 ``GTIOCA or GTIOCB`` ,并根据需要在图中标号 **2** 处设置 GPT 通道下两个输出端口各自对应的输出引脚。
|
||
|
||
4. 在 menuconfig 中打开对应的通道,[RT-Thread 的 pwm 框架介绍](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/pwm/pwm)
|
||
|
||
data:image/s3,"s3://crabby-images/3276f/3276ff2506eb8275bf2e69d488967424f748c8cf" alt="image-20211103202216381"
|
||
|
||
### CAN
|
||
|
||
1. 添加CAN
|
||
|
||
data:image/s3,"s3://crabby-images/7ed90/7ed90527f58f365635e0d6a83f2be8c5f673057a" alt="image-20211102145023112"
|
||
|
||
2. 配置Callback为 `can0_callback` 或 `can1_callback`
|
||
|
||
data:image/s3,"s3://crabby-images/8c37e/8c37effdcab7b629bbcbaea286e4dd70cf08be0f" alt="image-20211102145227603"
|
||
|
||
3. 配置其他选项,并生成代码。
|
||
|
||
4. 使用ENV使能CAN。[CAN设备使用说明](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/can/can)
|
||
|
||
data:image/s3,"s3://crabby-images/afda2/afda28c449ccaa249c891151d94a9f275d32a923" alt="image-20211102145613309"
|
||
|
||
|
||
### 使用 WiFi 模块 [RW007 ](https://github.com/RT-Thread-packages/rw007)
|
||
|
||
1. 软件包配置中找到 RW007,并修改为下图配置
|
||
|
||
data:image/s3,"s3://crabby-images/37419/374193ecb61772a6c708bc3ae6855f3d25ca9a94" alt="image-20211108142805319"
|
||
|
||
2. menuconfig 中打开驱动的 RW007 配置,默认使用了 SPI1 端口。所以需要打开 SPI1 总线。
|
||
|
||
data:image/s3,"s3://crabby-images/07116/071162d1e7e492500e1e84cc289a5296b8850727" alt="image-20211108142453678"
|
||
|
||
data:image/s3,"s3://crabby-images/52c1d/52c1d85825e57ce610e35b0371295df2ad01e9b8" alt="image-20211213212034701"
|
||
|
||
3. 在设备驱动框架中打开 [WLAN 框架](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/wlan/wlan),
|
||
|
||
data:image/s3,"s3://crabby-images/170e6/170e6ab736332fb46be11b259f996d1b88fae5b5" alt="image-20211108143027485"
|
||
|
||
在网络配置中打开 NETDEV 组件:
|
||
|
||
data:image/s3,"s3://crabby-images/c49a7/c49a7eaf97443ed6d19089fff202d6c549ce7dec" alt="image-20211108143712513"
|
||
|
||
在 kernel 中打开 mempool 配置:
|
||
|
||
data:image/s3,"s3://crabby-images/bae72/bae7263feb9dc23f8b79ddd04919c69885e9c24a" alt="image-20211209161902884"
|
||
|
||
4. FSP 中打开添加 SPI 外设端口,[如何添加SPI](#SPI)。下图以 SPI1 端口为例的配置如下:
|
||
|
||
data:image/s3,"s3://crabby-images/5551d/5551df4a226f4be2c191190b1bcb0f4b96115a71" alt="image-20211108183631379"
|
||
|
||
5. RW007 有一个从机控制的 INT 引脚,需要占用一个 IRQ 通道,下图以 P506 为例的配置如下:
|
||
|
||
data:image/s3,"s3://crabby-images/251eb/251eb809bdc2b73126327fa5936ec0730a8b2b8e" alt="image-20211108183724282"
|
||
|
||
6. RW007 的 RESET 控制引脚修改默认配置,这里在 RASC 中 mode 设为关闭,交由 RW007 中进行控制。
|
||
|
||
data:image/s3,"s3://crabby-images/dc370/dc3707d8a0f60f37a75a35e6bcfe460dadd8cbde" alt="image-20211213144108558"
|
||
|
||
7. 配置完成,检查 MDK 工程中是否加入了必要的文件
|
||
|
||
data:image/s3,"s3://crabby-images/66ce2/66ce2bc665f0e21a67189f4fe927dd0bc14c3569" alt="image-20211109102232233"
|
||
|
||
8. 编译下载,验证结果。
|
||
|
||
系统启动会自动获取 RW007 的信息,输入`wifi scan` 命令扫描环境中的 WiFi 信号。[更多 WiFi 命令](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/wlan/wlan?id=finsh-%e5%91%bd%e4%bb%a4)
|
||
|
||
data:image/s3,"s3://crabby-images/9f103/9f10371c06edf36559b836972429c9bfd6e3e515" alt="image-20211109103856130"
|
||
|
||
使用 `WiFi join` 命令连接 WiFi 热点 :
|
||
|
||
data:image/s3,"s3://crabby-images/82468/8246805fe716b615879b9f3361b318da07391204" alt="image-20211109104735733"
|
||
|
||
使用 `ping rt-thread.com` 测试网络连接:
|
||
|
||
data:image/s3,"s3://crabby-images/0e12f/0e12f615ff5d7cd9a0cea323cb12888e38105c0a" alt="image-20211109104700939" |