Skip to content

Commit 712f97a

Browse files
committed
【完善】micropython 固件开发指南
1 parent 8e5f668 commit 712f97a

File tree

2 files changed

+57
-16
lines changed

2 files changed

+57
-16
lines changed

docs/MicroPythonPlug-in/MicroPython 固件开发指南.md

Lines changed: 57 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -2,50 +2,91 @@
22

33
如果手上没有官方支持固件的开发板,就需要自己来动手制作 MicroPython 固件了。由于 RT-Thread 官方提供了 MicroPython 软件包,并且 MicroPython 底层和硬件绑定时对接了 RT-Thread 驱动框架,所以我们可以很方便地在运行了 RT-Thread 的板卡上将 MicroPython 跑起来。
44

5-
接下来我们以 `rt-thread\bsp\stm32\stm32f407-atk-explorer` 为例,讲解如何在 BSP 的基础上制作 MicroPython 固件。
5+
接下来我们以 `rt-thread\bsp\stm32\stm32f407-atk-explorer` 上的 MDK 工程为例,讲解如何在 BSP 的基础上制作 MicroPython 固件。
66

77
### 获取 MicroPython 软件包
88

9-
先使用 `pkgs --upgrade` 命令更新软件包列表,然后通过 env 工具获取 MicroPython 软件包。
9+
先使用 `pkgs --upgrade` 命令更新软件包列表,然后通过 env 工具选中 MicroPython 软件包,最后使用 `pkgs -update` 命令将软件包拉取到本地
1010

1111
![1564476611502](assets/1564476611502.png)
1212

13-
软件包配置完成后记得使用 `pkgs -update` 命令将软件包更新到本地。
14-
1513
### 增大 main 线程栈
1614

17-
为了能正常运行 MicroPython,需要增大 main 线程的栈大小,这里我们将栈大小增加到 8k。
15+
为了能后续在 main 线程中启动 MicroPython 运行时环境,需要增大 main 线程的栈大小,这里我们将栈大小增加到 8k。
1816

1917
![1564476903287](assets/1564476903287.png)
2018

2119
### 配置 MicroPython 运行环境堆大小
2220

23-
接下来需要根据板卡实际剩余 RAM 的情况来给 MicroPython 运行环境分配运行时内存,这里填写的数值越大,就能运行更多代码量的 Python 程序。在本次示例中,由于 RAM 剩余充足,我们在此填写 70k。
21+
接下来根据板卡内存实际剩余情况来给 MicroPython 运行环境分配内存,这里填写的数值越大,就能运行更大代码量的 Python 程序。但是如果这里填写的数值超过了实际可分配内存,就可能会出现无法分配内存而报错。因此在配置此项目之前,需要对系统 RAM 资源的分配情况有一定了解。
22+
23+
#### 查看系统剩余内存
24+
25+
重新生成工程,编译下载后通过 `msh``free` 命令来查看内存使用情况。
2426

25-
如果这里填写的数值过大,可能会出现无法分配内存而报错。所以在配置此项目之前,可以先通过 `msh``free` 命令来查看内存使用情况,对系统 RAM 资源的使用情况有一定了解。
27+
![1564628226157](assets/1564628226157.png)
28+
29+
#### 配置系统
30+
31+
通过上一步查询的内存分配情况,可以看到系统 RAM 资源较为剩余充足。因此我们决定分配 70k 内存给 MicroPython 运行时环境,配置如下图所示:
2632

2733
![1564476923786](assets/1564476923786.png)
2834

2935
### 在根目录挂载文件系统
3036

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 文件系统,需要对系统进行如下配置:
3238

3339
![1564480676371](assets/1564480676371.png)
3440

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)
3663

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+
}
3875

39-
在 main 线程中需要做两件事:
76+
rt_thread_mdelay(100);
4077

41-
- 挂载文件系统到 `\` 目录
42-
- 在 main 线程中启动 MicroPython
78+
/* 运行 MicroPython 启动函数 */
79+
extern void mpy_main(const char *filename);
80+
mpy_main(NULL);
4381

44-
修改 main 线程的代码如下图所示:
82+
rt_kprintf("You can enter repl mode by typing python commands.");
4583

46-
![modify_main_thread](assets/1564481108595.png)
84+
/* 如果想要在 REPL 环境按下 CTRL+D 重启系统可以加上下面这一句 */
85+
/* rt_hw_cpu_reset(); */
86+
}
87+
```
4788
48-
重新编译工程,并下载到板卡中,就会在 main() 线程中自动进入 MicroPython 的交互环境 REPL。此时如果先前没有在存储器上创建相应的文件系统,可能会导致文件系统挂载失败。此时可以使用如下两种方法在存储设备上创建文件系统:
89+
重新编译工程下载到板卡中,就会在 main 线程中自动进入 MicroPython 的交互环境 REPL。此时如果先前没有在存储器上创建相应的文件系统,可能会导致文件系统挂载失败。此时可以使用如下两种方法在存储设备上创建文件系统:
4990
5091
- 按下 `CTRL + D` 进入 msh 使用 `mkfs -t elm W25Q128` 命令创建文件系统
5192
- 在 REPL 交互环境中输入 `import os`,`os.mkfs("elm", "W25Q128")` 命令来创建文件系统
7.02 KB
Loading

0 commit comments

Comments
 (0)