2021-10-11 21:14:00 +08:00
|
|
|
|
## 在 MDK 中使用 FSP
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
- 添加RA Smart Config
|
|
|
|
|
|
2021-10-11 21:14:00 +08:00
|
|
|
|
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/eebf0/eebf0a5b33c953f854c953eb3a3178f7d6748132" alt="img"
|
|
|
|
|
|
|
|
|
|
7. 点击添加的命令打开配置工具:RA Smart Config
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ba85a/ba85af7d20bef68698e34c033367d84cd16d5205" alt="image.png"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
- 添加 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 配置完成后如果有新的文件添加进工程中,不会马上添加进去。需要先编译一次,如果弹出如下提醒,选择 “是” 然后再次编译即可。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5bff7/5bff79c9efee6eb599458c91de6e5aa8fd5522a9" alt="img"
|
|
|
|
|
|
|
|
|
|
|
2021-10-11 21:14:00 +08:00
|
|
|
|
## UART
|
|
|
|
|
|
2021-10-22 15:12:56 +08:00
|
|
|
|
如何添加一个 UART 端口外设配置?
|
|
|
|
|
|
|
|
|
|
1. 选择 Stacks 配置页,点击 New Stack 找到 UART。
|
2021-10-11 21:14:00 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/40ff2/40ff2ecd86d7dbe6256d6f4338c99345960c19bf" alt="image.png"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
2. 配置 UART 参数,因为需要适配 RT-Thread 驱动中使用的命名,所以需要修改命名,设置**name** 、**channel** 、**callback** 是一致的标号。data:image/s3,"s3://crabby-images/baf06/baf067a14e3557fcfedefaa0aefdce565eb5360b" alt="image.png"
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
|
|
|
|
## GPIO 中断
|
|
|
|
|
|
|
|
|
|
如何添加一个 IO 中断?
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
1. 选择引脚编号,进入配置,比如选择 P105 做为中断引脚。可先找到引脚查看可配置成的 IRQx 通道号。
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/7f756/7f756e2fb8a99f94867539a764147545418b9910" alt="image-20211103200949759"
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
2. 打开 ICU 中断通道 IRQ00
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/d47be/d47be484abb8c403d5e134b770f741d07269cbc8" alt="image-20211103200813467"
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
3. 创建 stack 并进入配置。因为需要适配 RT-Thread 驱动中使用的命名,所以需要修改命名,设置**name** 、**channel** 、**callback** 是一致的标号。选择你希望的触发方式,最后保存配置,生成配置代码。
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/245a0/245a0e1969d5cda79b173ac7002705a87e76b1a5" alt=""
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/34c82/34c82c09f09bfd6b21e137ca3baa2c3b46c082f7" alt="image-20211103201047103"
|
|
|
|
|
|
|
|
|
|
4. 测试中断是否成功开启
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
|
|
|
|
```c
|
2021-11-04 14:02:05 +08:00
|
|
|
|
#define IRQ_TEST_PIN "p105"
|
2021-10-22 15:12:56 +08:00
|
|
|
|
void irq_callback_test(void *args)
|
|
|
|
|
{
|
2021-11-04 14:02:05 +08:00
|
|
|
|
rt_kprintf("\n IRQ00 triggered \n");
|
2021-10-22 15:12:56 +08:00
|
|
|
|
}
|
2021-11-03 20:40:06 +08:00
|
|
|
|
|
2021-10-22 15:12:56 +08:00
|
|
|
|
void icu_sample(void)
|
|
|
|
|
{
|
2021-11-04 14:02:05 +08:00
|
|
|
|
/* init */
|
2021-11-03 20:40:06 +08:00
|
|
|
|
rt_uint32_t pin = rt_pin_get(IRQ_TEST_PIN);
|
2021-10-22 15:12:56 +08:00
|
|
|
|
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
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
1. 创建 WDT
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7f72c/7f72c965c2c5557fb6f6fed80306214a2e1b55a6" alt="image-20211019152302939"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
2. 配置 WDT,需要注意在 RT-Thread 中只使用了一个 WDT 设备,所以没有对其进行编号,如果是新创建的 WDT 设备需要注意 name 字段,在驱动中默认使用的是`g_wdt` 。
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9af40/9af40b4b4f2b49e29bf59cea929eb19aaca78e83" alt="image-20211019152407572"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
3. 如何在 ENV 中打开 WDT 以及[WDT 接口使用说明](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/watchdog/watchdog)
|
2021-10-27 18:51:05 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5117d/5117d5b5e4f885adf9fd31d0e687e64de42f175d" alt="image-20211027183406251"
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
|
|
|
|
## RTC
|
|
|
|
|
|
|
|
|
|
1. 添加 RTC 设备
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7c48f/7c48fee19fcfdf95a8164fae2fc61c470e12260f" alt="image-20211019152536749"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
2. 配置 RTC,需要注意在 RT-Thread 中只是用了一个 RTC 设备,所以没有对其进行编号,如果是新创建的 RTC 设备需要注意 name 字段,在驱动中默认使用的是`g_rtc` 。修改 Callback 为 rtc_callback
|
2021-10-22 15:12:56 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d9fb9/d9fb96dcbcd382ae0892841626ffcf0cfd88c434" alt="image-20211019152627412"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
3. 如何在 ENV 中打开 RTC 以及[ RTC 接口使用说明](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/rtc/rtc)
|
2021-10-27 18:51:05 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/be2ca/be2ca911233cc6011037e18fe69ce59d3d5198e3" alt="image-20211027181550233"
|
|
|
|
|
|
|
|
|
|
## Flash
|
|
|
|
|
|
|
|
|
|
1. 创建 Flash
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/35c9b/35c9b674c6495cd0ea1c7965f9946109ef5adc43" alt="image-20211026105031200"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
2. 配置 Flash,需要注意在 RT-Thread 中只使用了一个 flash 设备,所以没有对其进行编号,如果是新创建的 flash 设备需要注意 name 字段,在驱动中默认使用的是`g_flash` 。
|
2021-10-27 18:51:05 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bcb4d/bcb4d38003e36c43f168867b15ed2db593c8d43e" alt="image-20211026105628706"
|
|
|
|
|
|
|
|
|
|
3. 如何在 ENV 中打开 Flash
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9b652/9b65200d1b048f9608e411441c0b2eeddc817307" alt="image-20211026123252310"
|
|
|
|
|
|
|
|
|
|
## SPI
|
|
|
|
|
|
|
|
|
|
1. 添加一个 SPI 外设端口
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7219f/7219f18e2177e853ae4b820152b32d8c72e07b79" alt="image-20211027180820968"
|
|
|
|
|
|
|
|
|
|
2. 配置 channel、name、Clock Phase、Clock Polarity、Callback、 SPI Mode 等参数,波特率在代码中可通过 API 修改,这里可以设置一个默认值。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1fde7/1fde7596137bb2fd33b11cf65f382b287a9be491" alt="img"
|
|
|
|
|
|
|
|
|
|
3. 如何在 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/38b7c/38b7cd791eb9bdd025d9c07b2087c55ca3524f4c" alt="image-20211027181444023"
|
|
|
|
|
|
|
|
|
|
## ADC/DAC
|
|
|
|
|
|
|
|
|
|
创建 ADC/DAC
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/85d1d/85d1d433bef1d73debc83d809f9e1fa7e9d12344" alt="img"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
- **ADC**
|
2021-10-27 18:51:05 +08:00
|
|
|
|
|
|
|
|
|
1. 配置 name、unit、mode,选择扫描的通道编号
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/020d7/020d70e2ae684e3da675a9b948093464f91c011e" alt="img"
|
|
|
|
|
|
|
|
|
|
2. 配置扫描通道对应的引脚
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/697bd/697bdf78a0831a5184191dc6b41f472440ec0997" alt="img"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
3. 在 menuconfig 中打开对应的通道
|
|
|
|
|
|
|
|
|
|
- **DAC**
|
2021-10-27 18:51:05 +08:00
|
|
|
|
|
|
|
|
|
1. 需要先关闭 P014 的默认 mode
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e718c/e718c4f07600da95264504a71400bb027c482fae" alt="img"
|
|
|
|
|
|
|
|
|
|
2. 开启 DAC0 通道
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2584d/2584d3bc51fb7fe2483c8d830a5c082fd15b4d0a" alt="img"
|
|
|
|
|
|
|
|
|
|
3. 修改通道号为 0,与 DAC0 对应
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f1f0f/f1f0f7995c1993930278610b405429cd0a49104a" alt="img"
|
2021-10-29 15:26:59 +08:00
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
4. 在 menuconfig 中打开对应的通道
|
2021-10-29 15:26:59 +08:00
|
|
|
|
|
|
|
|
|
## 通用 PWM 定时器(GPT)
|
|
|
|
|
|
|
|
|
|
GPT 定时器在该芯片中可作为通用定时器,也可以用于产生 PWM 信号。在将其用于产生 PWM 信号时,GPT 定时器提供了 gpt0 - gpt9 总共 10 个通道,每个通道可以设定两个输出端口。当前版本的 PWM 驱动将每个通道都看做一个单独的 PWM 设备,每个设备都只有一个通道。用户可以选择开启一个通道的任意一个输出端口,或将两个端口均开启,但在同时开启两个端口的情况下,它们输出的波形将完全一致。
|
|
|
|
|
|
|
|
|
|
1. 添加 GPT 设备
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/31bbb/31bbb6ba37f6121993d03049f768c941ce42a34b" alt="img"
|
2021-11-03 20:40:06 +08:00
|
|
|
|
|
2021-10-29 15:26:59 +08:00
|
|
|
|
2. 配置通道
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1b15c/1b15c955d89a623489c9faca6879b121048c4153" alt="img"
|
|
|
|
|
|
|
|
|
|
对 GPT 较为关键的配置如图所示,具体解释如下:
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
1. 将``Common`` ->``Pin Output Support`` 设置为 Enable ,以开启 PWM 波形的输出。
|
|
|
|
|
2. 指定 GPT 通道,并根据通道数指定 GPT 的名称,例如此处指定 GPT 通道 3 ,所以 GPT 的名称必须为``g_timer3``。并且将定时器模式设置为 PWM ,并指定每个 PWM 周期的计数值。
|
2021-10-29 15:26:59 +08:00
|
|
|
|
3. 设定 PWM 通道默认输出的占空比,这里为 50% 。
|
|
|
|
|
4. 设定 GPT 通道下两个输出端口的使能状态。
|
|
|
|
|
5. 此处设置 GPT 通道下两个输出端口各自对应的引脚。
|
2021-11-03 20:40:06 +08:00
|
|
|
|
|
2021-10-29 15:26:59 +08:00
|
|
|
|
3. 配置输出引脚
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/29d4e/29d4e125203593568a3463e7eeeab655bc85d8d3" alt="img"
|
|
|
|
|
|
2021-11-03 20:40:06 +08:00
|
|
|
|
在完成上一步对 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/68dd8/68dd858f75e5eb1a57c52c3bd02a0300714a44d1" alt="image-20211103202216381"
|