一个调试器,干掉四套工具链,我把调试、下载、量产、IAP升级 全都塞进了一个小盒子里 | 技术集结

天资达人 时政新闻 2026-03-06 3171 0

RT-Thread正式启动硬件产品生态共建计划"你有创意,我帮你推广",我们寻找那些藏在工作台、实验室和创客空间的嵌入式硬件创意——无论是一块开发板、一个智能工具,还是一套完整的解决方案。我们诚挚邀请社区开发者、创客和硬件公司,将您的创意原型带到RT-Thread生态,也欢迎已有成熟产品直接入驻!!欢迎加入我们的硬件生态计划,可发送作品(建议包含:产品介绍、演示视频/图片、技术亮点、您的介绍)邮件至hardware@rt-thread.com

今天我们也荣幸的向大家首推MicroKeen(MKLink),以下来自MKLink创作者的作品内容,欢迎支持!

0

先看一个真实的产品生命周期

第一阶段:研发 —— Debug 才是核心战场

很多人以为下载速度是重点。

错。

下载速度只是最基本的需求。

真正需要解决的是:

printf 打印日志

实时数据可视化

rtos的任务时序分析

于是你会用到:

SWD调试工具

USB 转串口查看日志

数据可视化工具(如 J-Scope 类工具)

SystemView 类工具分析任务时序

第二阶段:小批量 / 量产 —— 又换一套工具

终于调通。

进入试产。

问题来了:

你总不能让产线工人用调试器烧录吧?

于是又要买:

脱机下载器

固定烧录流程

重新培训产线

研发阶段的工具,不能直接用于生产。

这本来是一个“同类功能”。

却被割裂成两套体系。

第三阶段:售后 —— 真正的拦路虎

产品发出去以后。

Bug 会出现。

甲方会提新需求。

必须升级固件。

这时候你要做什么?

写 IAP Bootloader

再开发 PC 升级上位机

再维护一套通信协议

于是——

又一套工具体系诞生了。

问题的本质

研发一套工具。

量产一套工具。

售后一套工具。

同一个产品,三套工具。

1

我们真的需要那么多调试工具吗?

1、正版调试器确实强,但不是谁都负担的起

说到调试器,市面上有很多选择,功能强大、生态成熟的不在少数。

但现实是:

项目一多,成本直线上升

团队多人开发,每人一台?

产线要不要配?

售后要不要备?

工具成本,很快就从“合理”,变成“压力”。

ca7bedd6-17cc-11f1-96ea-92fbcf53809c.png

2、用盗版?风险提示你忍得了吗?

你一定见过这些提示:

盗版检测:the connected probe appears to be a j-link clone

连接故障:The connected J-Link is defective

质量堪忧:市面上常见的盗版jlink,质量一言难尽,当调试器本身不稳定时,你的研发效率就已经被拖垮了。

3、真正的问题:工具链是割裂的

典型开发流程:

每个阶段都在换工具。

每换一次:

学习成本

维护成本

培训成本

适配成本

真正消耗的不是钱。

是精力。

2

我想做一件更简单的事

我问自己一个问题:

能不能用一套硬件,覆盖整个产品生命周期?

于是有了 MicroKeen(MKLink)。

功能覆盖

caba6a0c-17cc-11f1-96ea-92fbcf53809c.png

购买地址

MKLinkV2 :

https://item.taobao.com/item.htm?ft=t&id=895964393739

MKLinkV3 :

https://item.taobao.com/item.htm?ft=t&id=1013104417098

MKLinkV4 :

https://item.taobao.com/item.htm?ft=t&id=1020501356342

3

MicroKeen的底层逻辑

它不是一个“下载器”,是开发平台。

1、性能基础:不是随便选的 MCU

采用 先楫半导体 HPM 高性能 MCU:

360 MHz 主频

内置 USB High-Speed PHY

这不是为了“堆配置”。

而是为了并行运行多种调试任务。

2、软件架构:不是堆功能,而是做平台

RT-Thread RTOS

提供稳定的多任务调度与资源管理,支撑调试、下载、数据转发并行运行;

CherryUSB 协议线

基于 USB HS,实现 CDC / MSC 多类设备高速并行工作;

PikaPython 脚本引擎

在设备侧运行 Python解释器,支持脱机下载与升级流程的脚本化与二次开发;

Arm-2D 图形加速库

UI加速引擎,实现流畅、低资源占用的本地人机交互界面。

3、关键创新点:一根 USB 线,全搞定

一个 USB 口,同时支持:

CMSIS-DAP 调试

USB 转串口(最高 12M Baud)

RTT 转发

SystemView 协议

VOFA+ 协议

脱机下载

IAP升级

WinUSB 免驱

你不再需要:

RTTViewer

J-Scope

额外串口工具

开发升级上位机

真正实现:

Debug 全家桶,一体化。

4

它到底能干什么?

1、下载速度,真的快

与目前市面上最新的调试器速度对比,目标芯片使用 STM32H743,开发环境 MDK V5.39,分别使用 MicroLink 和某主流调试器将 2558KB 的 HEX 文件下载到内部 FLASH 中。使用逻辑分析仪测试时钟引脚,计算出擦除,编程,校验全过程的时间,MicroLink 使用时间为 24.205 秒,对比调试器使用时间为 33.439 秒,测试数据如下图:

cacd61fc-17cc-11f1-96ea-92fbcf53809c.jpg

MicroLink测试结果:

caddd49c-17cc-11f1-96ea-92fbcf53809c.jpg

测试结果对比:

caee59ca-17cc-11f1-96ea-92fbcf53809c.png

2、高速USB转串口

MicroLink内置USB转串口功能,支持常见的串口和485通信,串口最大支持12M波特率,无丢包。

cb013450-17cc-11f1-96ea-92fbcf53809c.png

使用逻辑分析仪抓取波形如图所示,每个bit传输的时间为1/10M=100ns。

cb0c9fac-17cc-11f1-96ea-92fbcf53809c.png

3、RTT,不再绑定专用上位机

MicroKeen(MKLink)实现了对 SEGGER Real Time Transfer(RTT)的原生支持,在不中断目标系统运行的前提下,实现高速、双向的实时数据交互与调试通信,是传统串口调试方式的高效替代方案。

实现原理:

cb1e3cbc-17cc-11f1-96ea-92fbcf53809c.jpg

只要拥有了MKLink,你就可以享受以下的便利:

无需占用UART,将printf重定位到RTT;

不需要使用专门的RTTView上位机,支持任意串口助手;

高速通信,不影响芯片的实时响应。

比如使用SSCOM,连接MicroLink的虚拟串口,输入以下指令:

RTTView.start(0x20000000,1024,0)

0x20000000:搜索RTT控制块的起始地址;

1024:搜寻范围大小;

0:启动RTT的通道。

cb321c64-17cc-11f1-96ea-92fbcf53809c.png

4、VOFA+ 可视化,不占 MCU 串口

MicroKeen(MKLink)已完成对 VOFA+ 上位机协议的原生适配,可在功能与使用体验上替代传统调试器的数据可视化工具(如 J-Scope)。

实现原理:

MKLink 通过 SWD 直接读取目标芯片内存中的变量数据,并实时封装为 VOFA+ 协议,经 USB CDC 虚拟串口发送至 PC,实现对运行中变量的曲线显示、波形分析与参数调试,且不占用 MCU 串口资源、不侵入业务代码。

核心优势:

无需占用 MCU 串口资源

基于 SWD 的非侵入式采集

支持多种数据类型

高速刷新,稳定可靠

打开VOFA+上位机,并连接虚拟串口,发送

vofa.send(0x20000030,"uint8_t",0x2000154c,"float",0x20001550,"float",0.00001)

0x20000030:变量1内存地址;

uint8_t:变量1数据类型;

0.00001:读取周期,单位秒,最小支持1us

cb537d5a-17cc-11f1-96ea-92fbcf53809c.png

5、原汁原味的SystemView

MicroKeen(MKLink)已完成对 SEGGER SystemView 协议的原生支持,无需额外分析硬件,即可实现对 RTOS 运行状态的任务级可视化分析,显著降低系统级调试门槛。

实现原理:

cb63b3aa-17cc-11f1-96ea-92fbcf53809c.png

核心优势:

无需额外 Trace 硬件

基于 RTT 的低侵入式采集

支持主流 RTOS(RT-Thread / FreeRTOS

任务级、时间轴级运行态分析

即插即用,兼容官方 SystemView 工具

cb772598-17cc-11f1-96ea-92fbcf53809c.png

6、脱机下载?直接脚本化

MKLink支持脱机离线下载的功能,借助于强大的PikaPython开源项目,让MKLink可以使用python脚本进行二次开发,可以非常容易地定制升级流程。

MKLink的虚拟U盘中有一个offline_download.py文件,内容如下:

importPikaStdLibimporttimeimportcmdimportload# SWD 时钟频率(Hz)SWD_CLOCK_HZ =10000000# 设置下载速度cmd.set_swd_clock(SWD_CLOCK_HZ)abort =False# 加载下载算法ifload.flm("FLM/STM32F10x_1024.FLM",0x08000000,0x20000000) !=0: print("load flm failed") abort =True break# 下载bin文件 ifload.bin("bootloader.bin",0x08000000) !=0: print("load bin failed") abort =True break # 下载hex文件 ifload.hex("rt-thread.hex") !=0: print("load hex failed") abort =True break

ifnot abort: cmd.set_beep_on() time.sleep_ms(100) cmd.set_beep_off()else: print("auto download aborted")

该代码通过加载FLM算法文件,将多个二进制文件(如bootloader.bin和rt-thread.hex)分别烧录到STM32内部不同地址的flash中。

注意:请根据您的实际项目需求,修改以下内容:

下载算法文件名称(如 "FLM/STM32F10x_1024.FLM"):应替换为对应芯片和Flash型号的 FLM 文件。

下载文件名称及地址(如 "bootloader.bin"、"rt-thread.hex",及其对应的地址):请确保文件名和烧录地址与您的程序结构一致。

7、售后升级?MicoKeen搭配MicroBoot为君解忧

MKLink内置Ymodem协议,支持通过串口进行可靠的文件传输。ymodem协议在多次重传时仍能保持数据的完整性,非常适用于嵌入式系统的固件升级。

使用内置的ymodem协议发送文件,首先需要目标设备支持ymodem协议接收文件。

MicorBoot开源框架集成了ymodem模块,可以方便用户直接安装使用,具体使用方法请看MicorBoot简介。

MicroBoot简介:

https://microboot.readthedocs.io/zh-cn/latest/

借助python脚本,只需要在脚本中编写几行代码,便可以让MKLINK摇身一变为ymodem文件传输工具,给单片机设备做IAP升级。

importPikaStdLibimportcmdimportymymodem = ym.ymodem("uart",115200)#ymodem = ym.ymodem("485",115200)ymodem.send("rt-thread.hex")

无需额外开发 PC 升级软件。

5

开源向实:不止是一个工具,也是一个开发平台

基于 MKLink 硬件平台,后续将持续开放并完善完整示例工程,

涵盖:

RT-Thread:在先辑硬件平台上的工程化实践

CherryUSB:USB HS 多类设备的真实应用范例

PikaPython:嵌入式 Python 在工具与流程中的落地使用

Arm-2D:高性能UI加速引擎,实现流畅图形与人机交互

开发者不仅可以“使用” MKLink,还可以将 下载器本身作为开发板,学习、验证并实践这些优秀开源项目在真实产品中的协同使用方式。

开源不止于代码,价值在于落地

MKLink,希望成为连接开源生态与工程实战的那座桥梁。

MKLink简介:

https://microboot.readthedocs.io/zh-cn/latest/tools/microlink/microlink/

6

真正的意义

MicroLink 的价值,不在“它比谁快”。

而在于:

它把工具链统一了。

研发用它 ;

调试用它 ;

量产用它 ;

售后也用它;

我做 MicroKeen,不是为了替代谁。

而是想解决一个问题:

为什么一个产品生命周期,需要这么多工具链?

如果你也受够了频繁切换工具。

也许它,会是你想要的答案。