当前位置: 首页 > news >正文

MicroPython核心(1):源码获取、编译构建

本文介绍了MicroPython在主要平台进行构建的基本方法,包括如何进行版本控制、获取和构建移植的源代码、构建文档、运行测试,以及MicroPython代码库的目录结构。

使用git进行源码管理

MicroPython托管在GitHub上,并使用Git进行源码管理。在进行下面的步骤之前,需要在本机先安装好Git。

注意:

  • 有关安装说明的参考资料,请参阅Git安装说明,建议先熟悉Git的基本概念和操作再开始下面的工作。
  • .git-blame-ignore-revs文件,可避免git blame的输出被只用于格式化代码而无功能改动的提交所干扰。如何使用请参见 git blame文档 文档。

获取代码

建议维护一个MicroPython代码库的分支以备开发之用。获取源代码的过程如下:

  1. fork仓库https://github.com/micropython/micropython
  2. 获得一个<https://github.com//micropython>分支
  3. 使用以下命令克隆分支仓库:
$ git clone https://github.com/<your-user-name>/micropython

然后,配置远程仓库,以便能够在MicroPython项目上进行协作。

配置远程upstream:

$ cd micropython
$ git remote add upstream https://github.com/micropython/micropython

为方便共享代码变更,在分支版本库中配置 upstreamorigin,也可以维护自己的映射,但建议 origin 映射到分支版本,而upstream映射到MicroPython主版本库。

完成上述配置后,应该与下面类似:

$ git remote -v
origin       https://github.com/<your-user-name>/micropython (fetch)
origin       https://github.com/<your-user-name>/micropython (push)
upstream     https://github.com/micropython/micropython (fetch)
upstream     https://github.com/micropython/micropython (push)

现在已经有一份源代码副本了。默认情况下,它指向的是主分支。为了做好进一步开发的准备,建议在开发分支上工作。

$ git checkout -b dev-branch

这里可以给它起任何名字,每当切换到不同的分支时,都必须编译MicroPython。

编译构建代码

编译MicroPython时,需要编译相应的移植,通常是针对特定的开发板。先安装所需的依赖项,然后构建 MicroPython 交叉编译器,这样才能成功编译和构建。这适用于使用Linux进行编译的情况。Windows说明将在后文提供。

获取依赖项

安装Linux依赖项:

$ sudo apt-get install build-essential libffi-dev git pkg-config

对于stm32的移植,需要ARM交叉编译器:

$ sudo apt-get install gcc-arm-none-eabi libnewlib-arm-none-eabi

Python是必须的,虽然支持Python 2,但建议使用Python 3。检查系统中是否有可用的 Python:

$ python3
Python 3.5.0 (default, Jul 17 2020, 14:04:10)
[GCC 5.4.0 20160609] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>>

所有支持的移植都有不同的依赖性要求,请参见各自的 readme 文件。

构建 MicroPython 交叉编译器

几乎所有移植都需要先编译 mpy-cross,以便对将包含在 port 固件中的 Python 代码进行预编译:

$ cd mpy-cross
$ make

**注意:**mpy-cross 必须针对主机架构而非目标架构构建。

如果构建成功,应该会看到类似下面的信息:

LINK mpy-crosstext          data    bss     dec     hex filename279328          776     880  280984   44998 mpy-cross

**注意:**使用 make -C mpy-cross 在一条语句中编译交叉编译器,而无需移动到 mpy-cross 目录,否则,接下来的步骤将需要执行 cd ... 操作。

MicroPython Unix移植构建

Unix移植是可在 Linux、macOS 和其他类 Unix 操作系统上运行的 MicroPython 版本。它对于开发 MicroPython 非常有用,因为它避免了将代码部署到设备上进行测试的麻烦。在许多方面,它的工作原理与 CPython 的 python 二进制文件非常相似。

要对 Unix 移植构建,需要先安装所有与 Linux 相关的依赖项,详见所需依赖项 。要确保已为该移植安装了所有依赖项。此外,还要确保 gccGNU make 环境能正常运行。下面的示例使用的是 Ubuntu 20.04,但其他 Linux 也可以使用,只需稍作修改即可:

$ gcc --version
gcc (Ubuntu 9.3.0-10ubuntu2) 9.3.0
Copyright (C) 2019 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.then build:
$ cd ports/unix
$ make submodules
$ make

如果MicroPython能被正确构建,应该可以看到下面的信息:

LINK micropythontext         data     bss     dec     hex filename412033         5680    2496  420209   66971 micropython

现在运行:

$ ./micropython
MicroPython v1.13-38-gc67012d-dirty on 2020-09-13; linux version
Use Ctrl-D to exit, Ctrl-E for paste mode
>>> print("hello world")
hello world
>>>

Windows移植构建

Windows 移植包括一个 Visual Studio 项目文件 micropython.vcxproj,可以用它来构建 micropython.exe。该文件可以在 Visual Studio 中打开,也可以使用 msbuild 从命令行编译。另外,也可以使用 mingw 在 Windows 和 Cygwin 或 Linux 中构建。

STM32移植构建

与 Unix 移植版一样,需要安装一些所需的依赖项,然后进行编译:

$ cd ports/stm32
$ make submodules
$ make

有关固件刷新的更多详情,请参阅stm32文档。

**注意:**请参阅 “所需的依赖项”,以确保为该移植安装了所有依赖项。arm-none-eabi-gcc也应位于 $PATH 中, 或通过设置环境变量或在 make 命令行参数中手动通过 CROSS_COMPILE 指定。

还可以指定开发板:

$ cd ports/stm32
$ make BOARD=<board> submodules
$ make BOARD=<board>

关于可用的可用板,可以参考ports/stm32/boards,例如 “PYBV11"或"NUCLEO_WB55”。

文档构建

MicroPython 文档使用 Sphinx 创建。如果已经安装了 Python,则使用 pip 安装 Sphinx。建议使用虚拟环境:

$ python3 -m venv env
$ source env/bin/activate
$ pip install -r docs/requirements.txt

进入docs目录

$ cd docs

构建文档:

$ make html

在浏览器中打开 docs/build/html/index.html,查看本地文档。请参阅有关导入文档的文档,以使用 “阅读文档”。

运行测试

在Linux移植上运行测试套件中的所有测试:

$ cd ports/unix
$ make test

在通过USB连接的开发板或设备上运行一系列测试:

$ cd tests
$ ./run-tests.py --target minimal --device /dev/ttyACM0

目录结构

在某些实施细节方面,有几个目录值得注意。以下是源代码顶级文件夹的细分。

目录说明
py包含编译器、运行时和核心库的实现
mpy-crossMicroPython交叉编译器,可将Python脚本预编译为字节码
ports支持移植的所有 MicroPython 版本的代码
lib任何移植使用的低级 C 语言库,其中大部分是第三方库
drivers具有针对特定硬件的驱动程序,旨在支持多种移植
extmod包含更多非核心模块的 C 语言实现
docs网站上的标准文档https://docs.micropython.org/
tests测试套件的实现
tools包含构建和 CI 流程使用的脚本,以及pyboard.py和mpremote等工具
examples把MicroPython作为库和本地模块构建的示例代码

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • GO 中如何防止 goroutine 泄露
  • Spring Boot各类变量的使用
  • Redis原理篇(String)
  • MVC的设计理念
  • NLP自然语言处理介绍
  • openssl3.2 - linux脚本(.sh)调用openssl命令行参数的简单确认方法
  • 【迅搜19】扩展(二)TNTSearch和JiebaPHP方案
  • 5G_射频测试_参考规范(一)
  • ssh:connect to host github.com port 22: Connection timed out
  • pyspark笔记:over
  • Halcon 边缘提取
  • 【JavaWeb】XML Tomcat10 HTTP
  • 计算机组成原理 第一弹
  • [GN] Vue3.2 快速上手 ---- 核心语法2
  • flask 与小程序 菜品详情和分享功能
  • @jsonView过滤属性
  • 【162天】黑马程序员27天视频学习笔记【Day02-上】
  • 【附node操作实例】redis简明入门系列—字符串类型
  • 10个确保微服务与容器安全的最佳实践
  • Angular6错误 Service: No provider for Renderer2
  • co模块的前端实现
  • DataBase in Android
  • es6要点
  • HashMap剖析之内部结构
  • Java面向对象及其三大特征
  • React-flux杂记
  • redis学习笔记(三):列表、集合、有序集合
  • Spark in action on Kubernetes - Playground搭建与架构浅析
  • SQL 难点解决:记录的引用
  • Three.js 再探 - 写一个跳一跳极简版游戏
  • 官方新出的 Kotlin 扩展库 KTX,到底帮你干了什么?
  • 海量大数据大屏分析展示一步到位:DataWorks数据服务+MaxCompute Lightning对接DataV最佳实践...
  • 技术胖1-4季视频复习— (看视频笔记)
  • 模仿 Go Sort 排序接口实现的自定义排序
  • 前端技术周刊 2019-01-14:客户端存储
  • 怎么把视频里的音乐提取出来
  • 职业生涯 一个六年开发经验的女程序员的心声。
  • RDS-Mysql 物理备份恢复到本地数据库上
  • ​1:1公有云能力整体输出,腾讯云“七剑”下云端
  • #define
  • #NOIP 2014# day.2 T2 寻找道路
  • (07)Hive——窗口函数详解
  • (12)Linux 常见的三种进程状态
  • (12)目标检测_SSD基于pytorch搭建代码
  • (6)添加vue-cookie
  • (HAL)STM32F103C6T8——软件模拟I2C驱动0.96寸OLED屏幕
  • (leetcode学习)236. 二叉树的最近公共祖先
  • (八)Flink Join 连接
  • (超详细)2-YOLOV5改进-添加SimAM注意力机制
  • (动手学习深度学习)第13章 计算机视觉---微调
  • (十一)JAVA springboot ssm b2b2c多用户商城系统源码:服务网关Zuul高级篇
  • (四)stm32之通信协议
  • (一)u-boot-nand.bin的下载
  • (原創) 物件導向與老子思想 (OO)
  • * 论文笔记 【Wide Deep Learning for Recommender Systems】