|
2 | 2 |
|
3 | 3 | 如果手上没有官方支持固件的开发板,就需要自己来动手制作 MicroPython 固件了。由于 RT-Thread 官方提供了 MicroPython 软件包,并且 MicroPython 底层和硬件绑定时对接了 RT-Thread 驱动框架,所以我们可以很方便地在运行了 RT-Thread 的板卡上将 MicroPython 跑起来。 |
4 | 4 |
|
5 | | -接下来我们以 `rt-thread\bsp\stm32\stm32f407-atk-explorer` 为例,讲解如何在 BSP 的基础上制作 MicroPython 固件。 |
| 5 | +接下来我们以 `rt-thread\bsp\stm32\stm32f407-atk-explorer` 上的 MDK 工程为例,讲解如何在 BSP 的基础上制作 MicroPython 固件。 |
6 | 6 |
|
7 | 7 | ### 获取 MicroPython 软件包 |
8 | 8 |
|
9 | | -先使用 `pkgs --upgrade` 命令更新软件包列表,然后通过 env 工具获取 MicroPython 软件包。 |
| 9 | +先使用 `pkgs --upgrade` 命令更新软件包列表,然后通过 env 工具选中 MicroPython 软件包,最后使用 `pkgs -update` 命令将软件包拉取到本地。 |
10 | 10 |
|
11 | 11 |  |
12 | 12 |
|
13 | | -软件包配置完成后记得使用 `pkgs -update` 命令将软件包更新到本地。 |
14 | | - |
15 | 13 | ### 增大 main 线程栈 |
16 | 14 |
|
17 | | -为了能正常运行 MicroPython,需要增大 main 线程的栈大小,这里我们将栈大小增加到 8k。 |
| 15 | +为了能后续在 main 线程中启动 MicroPython 运行时环境,需要增大 main 线程的栈大小,这里我们将栈大小增加到 8k。 |
18 | 16 |
|
19 | 17 |  |
20 | 18 |
|
21 | 19 | ### 配置 MicroPython 运行环境堆大小 |
22 | 20 |
|
23 | | -接下来需要根据板卡实际剩余 RAM 的情况来给 MicroPython 运行环境分配运行时内存,这里填写的数值越大,就能运行更多代码量的 Python 程序。在本次示例中,由于 RAM 剩余充足,我们在此填写 70k。 |
| 21 | +接下来根据板卡内存实际剩余情况来给 MicroPython 运行环境分配内存,这里填写的数值越大,就能运行更大代码量的 Python 程序。但是如果这里填写的数值超过了实际可分配内存,就可能会出现无法分配内存而报错。因此在配置此项目之前,需要对系统 RAM 资源的分配情况有一定了解。 |
| 22 | + |
| 23 | +#### 查看系统剩余内存 |
| 24 | + |
| 25 | +重新生成工程,编译下载后通过 `msh` 的 `free` 命令来查看内存使用情况。 |
24 | 26 |
|
25 | | -如果这里填写的数值过大,可能会出现无法分配内存而报错。所以在配置此项目之前,可以先通过 `msh` 的 `free` 命令来查看内存使用情况,对系统 RAM 资源的使用情况有一定了解。 |
| 27 | + |
| 28 | + |
| 29 | +#### 配置系统 |
| 30 | + |
| 31 | +通过上一步查询的内存分配情况,可以看到系统 RAM 资源较为剩余充足。因此我们决定分配 70k 内存给 MicroPython 运行时环境,配置如下图所示: |
26 | 32 |
|
27 | 33 |  |
28 | 34 |
|
29 | 35 | ### 在根目录挂载文件系统 |
30 | 36 |
|
31 | | -最后要确保系统中 `/` 目录挂载了文件系统,有了文件系统,我们后续才能使用 [ **MicroPython 开发环境**](https://marketplace.visualstudio.com/items?itemName=RT-Thread.rt-thread-micropython) 将 Python 代码文件同步到板卡中来运行。本次示例中,我们配置使用 elm-fat 文件系统。如果对文件系统相关概念有疑问,可以参考 [文件系统说明文档](https://www.rt-thread.org/document/site/programming-manual/filesystem/filesystem/) 进行配置。 |
| 37 | +最后要确保系统中 `/` 目录挂载了文件系统。有了文件系统,后续才能使用 [**MicroPython 开发环境**](https://marketplace.visualstudio.com/items?itemName=RT-Thread.rt-thread-micropython) 将 Python 代码文件同步到板卡中来运行,本次示例中将使用 elm-fat 文件系统,需要对系统进行如下配置: |
32 | 38 |
|
33 | 39 |  |
34 | 40 |
|
35 | | -配置完成后,记得要使用 env 工具重新生成工程,使配置生效。 |
| 41 | +配置完成后,记得要使用 `scons --target=mkd5` 重新生成工程,使配置在工程中生效。 |
| 42 | + |
| 43 | +### 在 main 线程中启动 MicroPython |
| 44 | + |
| 45 | +最后要在 main 线程中启动 MicroPython,需要完成的功能如下: |
| 46 | + |
| 47 | +1. 挂载文件系统到 `/` 目录 |
| 48 | +2. 启动 MicroPython |
| 49 | + |
| 50 | +上述功能可以通过修改 main 函数来实现,修改 main 代码如下所示: |
| 51 | + |
| 52 | +```c |
| 53 | +#include <rtthread.h> |
| 54 | +#include <rtdevice.h> |
| 55 | +#include <board.h> |
| 56 | +#include <dfs_fs.h> |
| 57 | +#include <rtdevice.h> |
| 58 | + |
| 59 | +#define FS_PARTITION_NAME "W25Q128" |
| 60 | + |
| 61 | +/* defined the LED0 pin: PF9 */ |
| 62 | +#define LED0_PIN GET_PIN(F, 9) |
36 | 63 |
|
37 | | -### 修改 main 线程启动代码 |
| 64 | +int main(void) |
| 65 | +{ |
| 66 | + /* 挂载 elm 文件系统到 / 目录 */ |
| 67 | + if (dfs_mount(FS_PARTITION_NAME, "/", "elm", 0, 0) == 0) |
| 68 | + { |
| 69 | + rt_kprintf("Filesystem initialized!"); |
| 70 | + } |
| 71 | + else |
| 72 | + { |
| 73 | + rt_kprintf("Filesystem initialization failed!"); |
| 74 | + } |
38 | 75 |
|
39 | | -在 main 线程中需要做两件事: |
| 76 | + rt_thread_mdelay(100); |
40 | 77 |
|
41 | | -- 挂载文件系统到 `\` 目录 |
42 | | -- 在 main 线程中启动 MicroPython |
| 78 | + /* 运行 MicroPython 启动函数 */ |
| 79 | + extern void mpy_main(const char *filename); |
| 80 | + mpy_main(NULL); |
43 | 81 |
|
44 | | -修改 main 线程的代码如下图所示: |
| 82 | + rt_kprintf("You can enter repl mode by typing python commands."); |
45 | 83 |
|
46 | | - |
| 84 | + /* 如果想要在 REPL 环境按下 CTRL+D 重启系统可以加上下面这一句 */ |
| 85 | + /* rt_hw_cpu_reset(); */ |
| 86 | +} |
| 87 | +``` |
47 | 88 |
|
48 | | -重新编译工程,并下载到板卡中,就会在 main() 线程中自动进入 MicroPython 的交互环境 REPL。此时如果先前没有在存储器上创建相应的文件系统,可能会导致文件系统挂载失败。此时可以使用如下两种方法在存储设备上创建文件系统: |
| 89 | +重新编译工程下载到板卡中,就会在 main 线程中自动进入 MicroPython 的交互环境 REPL。此时如果先前没有在存储器上创建相应的文件系统,可能会导致文件系统挂载失败。此时可以使用如下两种方法在存储设备上创建文件系统: |
49 | 90 |
|
50 | 91 | - 按下 `CTRL + D` 进入 msh 使用 `mkfs -t elm W25Q128` 命令创建文件系统 |
51 | 92 | - 在 REPL 交互环境中输入 `import os`,`os.mkfs("elm", "W25Q128")` 命令来创建文件系统 |
|
0 commit comments