Skip to content

Commit f0e29e5

Browse files
authored
Merge pull request #146 from SummerGGift/update_micropython_docs
[update] micropython docs
2 parents 1613e84 + 9b31d6d commit f0e29e5

File tree

4 files changed

+78
-29
lines changed

4 files changed

+78
-29
lines changed

docs/assets/en_connect_board.gif

233 KB
Loading

docs/external_c_modules.md

Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
# 为 MicroPython 扩展 C 模块
2+
3+
当使用原生 MicroPython 进行开发时,你可能会遇到这样一些限制,比如官方没有实现自己想要的功能,或者你觉得这些实现不符合自己的工作需求。此时,添加自己的 C 模块到 MicroPython 中是一个不错的选择,你可以按照自己的想法,设计适合自己的 Python 函数调用。
4+
5+
为了帮助各位开发者快速添加 C 模块,RT-Thread 提供了相应的辅助工具 [C 绑定代码自动生成器](https://summerggift.github.io/Micropython-C-Generator/)。该工具可以帮助开发者自动生成 C 代码和 MicroPython 之间的接口层,开发者只需将 C 语言编写的功能代码添加到指定位置,MicroPython 即可直接调用该功能。
6+
7+
## Python 调用 C 函数的实现原理
8+
9+
C 语言和 Python 是两种完全不同的语言,如何使用 MicroPython 来调用 C 语言所实现的函数是许多小伙伴非常疑惑的地方。简单来说,这个问题的关键点在于,如何用 C 语言的形式在 MicroPython 源代码中**表述函数的入参和出参**。我举一个例子来讲解这个问题, 请观察如下 Python 函数:
10+
11+
```python
12+
def add(a, b):
13+
return a + b
14+
```
15+
16+
该函数有两个入参,返回一个参数。此时如果能用 C 语言表示该 **Python 函数的输入输出参数**,就可以将一个实现该功能的 C 函数对接到 MicroPython 中。
17+
18+
### 添加用户函数到 MicroPython
19+
20+
假设上述函数的参数类型都为整形,通过自动生成器可以得到如下样板函数:
21+
22+
```c
23+
STATIC mp_obj_t add(
24+
mp_obj_t arg_1_obj,
25+
mp_obj_t arg_2_obj) {
26+
mp_int_t arg_1 = mp_obj_get_int(arg_1_obj); /* 通过 Python 获取的第一个整形参数 arg_1 */
27+
mp_int_t arg_2 = mp_obj_get_int(arg_2_obj); /* 通过 Python 获取的第二个整形参数 arg_2 */
28+
mp_int_t ret_val;
29+
30+
/* Your code start! */
31+
32+
ret_val = arg_1 + arg_2; /* 处理入参 arg_1 和 arg_2,并将结果赋给返回值 ret_val */
33+
34+
/* Your code end! */
35+
36+
return mp_obj_new_int(ret_val); /* 向 python 返回整形参数 ret_val */
37+
}
38+
MP_DEFINE_CONST_FUN_OBJ_2(add_obj, add);
39+
```
40+
41+
生成器会处理好需要导出到 MicroPython 的函数的入参和出参,而开发者只需要编写相应的代码来处理这些输入参数,并且把返回值赋给输出参数即可。 通过包含头文件的方式,可以调用先前编写的 C 函数来对输入参数进行处理,或者根据输入参数来执行相应的动作,添加控制硬件的驱动的原理也是一样的。
42+
43+
最终使用 Python 调用 C 函数的效果如下:
44+
45+
```python
46+
>>> import userfunc
47+
>>> userfunc.add(666,777)
48+
1443
49+
```
50+
51+
### 添加用户模块到 MicroPython
52+
53+
添加用户模块到 MicroPython 中也不难,首先应当熟练掌握上述添加 C 函数的过程,然后参考 PR [add module userfunc to MicroPython](https://github.com/RT-Thread-packages/micropython/pull/144) 来添加属于自己的模块,该 PR 实现了添加 `userfunc` 模块到 MicroPython 的功能,你可以按照同样的方式将自己编写的模块注册到 MicroPython 中,要注意仔细查看这个 PR 中修改的 4 个文件,不要漏掉修改的细节。

docs/firmware-develop.md

Lines changed: 23 additions & 27 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
## MicroPython 固件开发指南
22

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

55
**注意**:RT-Thread MicroPython 需要运行在 **RT-Thread 3.0** 版本以上。
66

@@ -53,12 +53,7 @@ RT-Thread MicroPython mini 版本占用资源最大不超过:
5353

5454
### 在 main 线程中启动 MicroPython
5555

56-
最后要在 main 线程中启动 MicroPython,需要完成的功能如下:
57-
58-
1. 挂载文件系统到 `/` 目录
59-
2. 启动 MicroPython
60-
61-
上述功能可以通过修改 main 函数来实现,修改 main 代码如下所示:
56+
最后要在 main 线程中启动 MicroPython,代码修改如下所示:
6257

6358
```c
6459
#include <rtthread.h>
@@ -67,42 +62,43 @@ RT-Thread MicroPython mini 版本占用资源最大不超过:
6762
#include <dfs_fs.h>
6863
#include <rtdevice.h>
6964

65+
/* 文件系统所在分区名称,根据实际情况填写 */
7066
#define FS_PARTITION_NAME "W25Q128"
7167

72-
/* defined the LED0 pin: PF9 */
73-
#define LED0_PIN GET_PIN(F, 9)
74-
7568
int main(void)
7669
{
77-
/* 挂载 elm 文件系统到 / 目录 */
78-
if (dfs_mount(FS_PARTITION_NAME, "/", "elm", 0, 0) == 0)
70+
/* 挂载 elm 文件系统到 / 目录,如果你所使用的开发板没有文件系统也可以跳过这一步 */
71+
if (dfs_mount(FS_PARTITION_NAME, "/", "elm", 0, 0) == 0)
7972
{
8073
rt_kprintf("Filesystem initialized!");
8174
}
8275
else
8376
{
84-
rt_kprintf("Filesystem initialization failed!");
77+
/* 如果挂载失败,则尝试在文件系统分区重新创建文件系统 */
78+
dfs_mkfs("elm", FS_PARTITION_NAME);
79+
/* 尝试重新挂载文件系统 */
80+
if (dfs_mount(FS_PARTITION_NAME, "/", "elm", 0, 0) == 0)
81+
{
82+
/* 仍然挂载文件系统失败,请自行检查失败原因 */
83+
rt_kprintf("Failed to initialize filesystem!");
84+
}
8585
}
8686

8787
rt_thread_mdelay(100);
8888

89-
/* 运行 MicroPython 启动函数 */
90-
extern void mpy_main(const char *filename);
91-
mpy_main(NULL);
92-
93-
rt_kprintf("You can enter repl mode by typing python commands.");
89+
while(1)
90+
{
91+
/* 在这里让程序进入循环,通过这种方式实现 MicroPython 的软复位*/
92+
extern void mpy_main(const char *filename);
93+
/* 启动 MicroPython */
94+
mpy_main(NULL);
95+
}
9496

95-
/* 如果想要在 REPL 环境按下 CTRL+D 重启系统可以加上下面这一句 */
96-
/* rt_hw_cpu_reset(); */
97+
return RT_EOK;
9798
}
9899
```
99100
100-
重新编译工程下载到板卡中,就会在 main 线程中自动进入 MicroPython 的交互环境 REPL。此时如果先前没有在存储器上创建相应的文件系统,可能会导致文件系统挂载失败。此时可以使用如下两种方法在存储设备上创建文件系统:
101-
102-
- 按下 `CTRL + D` 进入 msh 使用 `mkfs -t elm W25Q128` 命令创建文件系统
103-
- 在 REPL 交互环境中输入 `import os`,`os.mkfs("elm", "W25Q128")` 命令来创建文件系统
104-
105-
注意: **W25Q128** 是本次示例中将要创建文件系统的块设备名称,并不是固定填写该名称。因此在使用上述命令创建文件系统前,需要确定当前系统中块设备的实际名称。
101+
重新编译工程并下载程序到板卡中,就会在 main 线程中自动启动 MicroPython,接下来就可以使用 [**RT-Thread MicroPython 开发环境**](https://marketplace.visualstudio.com/items?itemName=RT-Thread.rt-thread-micropython) 来进行应用开发了。 通过开发环境连接到开发板,即可看到 MicroPython 的交互环境 REPL,如下图所示:
106102
107-
成功创建文件系统后,就可以使用 [ **MicroPython 开发环境**](https://marketplace.visualstudio.com/items?itemName=RT-Thread.rt-thread-micropython) 来进行应用开发了。
103+
![en_connect_board](assets/en_connect_board.gif)
108104

docs/micropython-ide.md

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@ RT-Thread 为广大开发者提供了 VSCode 最好用的 MicroPython 插件 来
1111
- 支持在内存中快速运行代码文件功能
1212
- 支持运行代码片段功能
1313
- 支持多款主流 MicroPython 开发板
14-
- 支持 windows 及 ubuntu 操作系统
14+
- 支持 Windows、Ubuntu、Mac 操作系统
1515

1616
### 安装 IDE 开发环境
1717

@@ -21,4 +21,4 @@ RT-Thread 为广大开发者提供了 VSCode 最好用的 MicroPython 插件 来
2121

2222
可通过查看如下文档进一步了解并使用 RT-Thread MicroPython IDE:
2323

24-
- [RT-Thread MicroPython develop environment](https://marketplace.visualstudio.com/items?itemName=RT-Thread.rt-thread-micropython)
24+
- [RT-Thread MicroPython Develop Environment](https://marketplace.visualstudio.com/items?itemName=RT-Thread.rt-thread-micropython)

0 commit comments

Comments
 (0)