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

衡山派Luban-Lite SDK构建与开发命令详解:SCons与OneStep实战指南

衡山派Luban-Lite SDK构建与开发命令详解SCons与OneStep实战指南最近在用衡山派ArtInChip的开发板做项目发现他们的Luban-Lite SDK用起来挺顺手的特别是里面那套构建和开发命令把很多繁琐的步骤都简化了。不过刚开始接触时面对一堆命令也容易懵圈不知道从哪下手。今天我就结合自己的使用经验给大家详细拆解一下SDK里最核心的两套命令SCons构建系统命令和OneStep易用性命令集。无论你是刚拿到衡山派开发板还是想更高效地管理多项目配置这篇教程都能帮你快速上手少走弯路。咱们的目标是看完就能照着做把代码编译成能烧录的固件。1. 认识构建系统SCons在嵌入式开发里把一堆源代码、库文件变成最终能运行的二进制固件这个过程就叫“构建”。Luban-Lite SDK用的是SCons这个构建工具。它最大的好处是跨平台也就是说你在Windows电脑上用的命令和在Linux电脑上用的完全一样不用记两套东西。SCons命令是SDK构建的基础所有底层的编译、链接工作都由它来完成。下面咱们来看看最常用的几个SCons命令。1.1 第一步看看有哪些项目可选 (scons --list-def)刚打开SDK目录你可能会问“我该编译哪个” SDK里通常预置了针对不同开发板、不同存储介质比如Nor Flash或NAND Flash、不同软件框架比如裸机Bootloader或RT-Thread系统的多个项目模板。这时候就用scons --list-def命令。它会列出所有内置的项目配置。scons --list-def运行后你会看到类似下面的输出具体项目列表会根据你的SDK版本略有不同scons: Reading SConscript files ... Built-in configs: 0. d12x_demo68-nand_baremetal_bootloader 1. d12x_demo68-nand_rt-thread_helloworld 2. d12x_demo68-nor_baremetal_bootloader 3. d12x_demo68-nor_rt-thread_helloworld 4. d12x_hmi-nor_baremetal_bootloader 5. d12x_hmi-nor_rt-thread_helloworld 6. d13x_demo88-nand_baremetal_bootloader 7. d13x_demo88-nand_rt-thread_helloworld 8. d13x_demo88-nor_baremetal_bootloader 9. d13x_demo88-nor_rt-thread_helloworld 10. d13x_kunlunpi88-nor_baremetal_bootloader 11. d13x_kunlunpi88-nor_rt-thread_helloworld 12. d21x_demo128-nand_baremetal_bootloader 13. d21x_demo128-nand_rt-thread_helloworld 14. g73x_demo100-nor_baremetal_bootloader 15. g73x_demo100-nor_rt-thread_helloworld怎么看懂这个列表呢以d12x_demo68-nor_rt-thread_helloworld为例d12x: 芯片型号比如D12x系列。demo68: 开发板型号。nor: 存储介质是Nor Flash。rt-thread_helloworld: 基于RT-Thread实时操作系统的“Hello World”示例应用。你需要根据自己手里的开发板型号和想跑的程序来选择一个合适的项目。1.2 选定你的项目 (scons --apply-def)知道有哪些项目后就要告诉SCons“我接下来要操作的是这个项目”。这就是scons --apply-def命令的用途。你可以用项目的完整名称来指定scons --apply-defd12x_demo68-nor_rt-thread_helloworld_defconfig或者更简单点直接用前面列表里看到的索引号比如3scons --apply-def3执行成功后会看到类似Load config from target\configs\...的提示说明项目配置已经加载好了。这个操作相当于为后续的配置、编译命令设置好了“工作上下文”。注意每次新打开一个命令行终端进行开发时通常都需要先执行这一步来选定当前要操作的项目。1.3 配置项目 (scons --menuconfig)选好项目模板后你可能还想改点东西比如调整RT-Thread的内核功能、开启或关闭某个外设驱动、修改系统时钟等。这就需要用到配置界面。SCons通过scons --menuconfig命令调出我们熟悉的文本图形化配置菜单就是那个可以用方向键和回车操作的界面。scons --menuconfig这个命令会打开一个配置界面你可以在里面层层点选配置你的系统。配置完成后记得选择保存你的修改会被记录到项目的配置文件中。1.4 开始编译构建 (scons)配置搞定源代码也准备好了最关键的一步就是编译。最简单的编译命令就是scons这个命令会以简洁模式运行只显示主要的编译步骤和进度不会输出一大堆具体的编译器参数界面比较干净。如果你在调试想知道具体的编译命令、包含了哪些头文件路径、链接了哪些库可以加上--verbose参数scons --verbose这样所有编译细节都会打印出来方便你排查“为什么这个文件没编译”或者“链接时找不到某个函数”这类问题。1.5 清理编译产出 (scons --clean)有时候改动了代码但感觉编译结果不对劲或者想从头开始完整编译一次就需要清理之前编译生成的中间文件比如.o目标文件、.a库文件等。SCons提供了清理命令scons --clean或者更简短的写法scons -c执行后output目录下对应项目的编译中间文件会被清除。下次执行scons时所有源文件都会重新编译确保是最新的。2. 效率利器OneStep命令集虽然SCons命令功能完整但每次都要敲scons --apply-defxxx也挺麻烦的。衡山派的工程师们显然也想到了这点所以他们开发了一套叫做OneStep的易用性命令集。OneStep把那些常用的、带参数的SCons命令封装成了更简短的别名并且增加了一些提升开发效率的小工具用起来就像在Linux系统里操作一样顺手。2.1 如何启用OneStep在Windows上最简单。OneStep命令已经集成在SDK提供的win_cmd.bat或win_env.bat批处理脚本里了。你只需要双击运行这个批处理文件它就会打开一个配置好环境包括OneStep命令的命令行窗口。在Linux上需要手动把OneStep脚本“引入”到当前终端环境中。在SDK的根目录下执行source tools/onestep.sh执行后你就可以在当前这个终端窗口里使用所有OneStep命令了。为了方便我通常会把source /path/to/your/sdk/tools/onestep.sh这行命令加到Linux用户的~/.bashrc文件里这样每次打开终端都自动生效。2.2 OneStep命令全家福启用OneStep后输入h或者hmm命令就能看到所有可用的命令及其简要说明。$ h Luban-Lite SDK OneStep commands: hmm|h : Get this help. lunch [keyword] : Start with selected defconfig.e.g. lunch mmc menuconfig|me : Config application with menuconfig bm : Config bootloader with menuconfig km : Config application with menuconfig m|mb : Build bootloader application and generate final image ma : Build application only mu|ms : Build bootloader only c : Clean bootloader and application mc : Clean Rebuild all and generate final image croot|cr : cd to SDK root directory. cout|co : cd to build output directory. cbuild|cb : cd to build root directory. ctarget|ct : cd to target board directory. godir|gd [keyword] : Go/jump to selected directory. list : List all SDK defconfig. list_module : List all enabled modules. i : Get current projects information. buildall : Build all the *defconfig in target/configs rebuildall : Clean and build all the *defconfig in target/configs addboard|ab : Add new board *defconfig in target/configs aicupg : Burn image file to target board命令不少别担心咱们接下来就挑最常用的几个来讲覆盖从选项目到烧录的完整流程。2.3 核心开发流程命令实战假设我们现在要开始一个新的开发任务。1. 列出并选择项目 (listlunch)首先用list命令查看所有项目效果和scons --list-def一样。$ list假设我们想用索引为3的项目d12x_demo68-nor_rt-thread_helloworld。在OneStep里选择项目不用再敲长长的scons --apply-def直接用lunch命令后面跟索引号就行$ lunch 3如果你想用项目名称里的关键词来筛选也可以比如lunch nor它会列出所有包含“nor”的项目让你交互式选择。2. 查看当前项目信息 (i)选好项目后如果不确定当前环境是对应哪个板子、什么系统可以用i命令查看详细信息$ i scons: Reading SConscript files ... Target app: application/rt-thread/helloworld Target chip: d12x Target arch: riscv32 Target board: target/d12x/demo68-nor Target kernel: kernel/rt-thread Defconfig file: target/configs/d12x_demo68-nor_rt-thread_helloworld_defconfig Root directory: xxxxxxxxxxxxxx Out directory: output/d12x_demo68-nor_rt-thread_helloworld Toolchain: toolchain/bin\riscv64-unknown-elf-这个信息非常有用它确认了芯片架构是RISC-Vriscv32当前应用是RT-Thread的Hello World以及编译输出会放到哪个目录。3. 进入配置菜单 (me或menuconfig)要配置RT-Thread内核或应用就用me命令menuconfig的缩写$ me如果要配置Bootloader引导程序则用bm命令$ bm这两个命令分别对应了应用和Bootloader的配置比原始的scons --menuconfig更清晰。4. 一键编译 (m)配置保存好后最爽的时刻来了一键编译。OneStep的m命令或mb会帮你依次编译Bootloader和应用程序并把它们打包生成最终的可烧录镜像文件。$ m编译过程如果没问题最终的固件文件比如.bin或.img就会出现在i命令里显示的Out directory下面。5. 一键清理 (c)想重新编译时先用c命令清理$ c或者想一步到位完成“清理重新编译”可以用mc命令$ mc2.4 提升效率的辅助命令除了核心流程命令OneStep里还有一些能极大提升操作效率的“神器”。快速跳转目录SDK目录层次比较深经常要在根目录、输出目录、板级目录之间切换。croot或cr一秒跳回SDK根目录。cout或co跳转到当前项目的编译输出目录直接查看生成的固件。ctarget或ct跳转到当前目标板子的源码目录。godir或gd模糊搜索并跳转。比如gd rt-thread可以快速跳到RT-Thread相关的源码目录。批量操作buildall编译SDK里target/configs目录下的所有项目配置。适合在发布前做全面构建测试。rebuildall先清理再编译所有项目配置。烧录工具 (aicupg)这个命令会调用衡山派提供的烧录工具将编译好的镜像文件下载到开发板中。具体用法可能需要根据你的烧录器比如串口、DAP-Link等进行一些参数配置可以参考SDK中更详细的烧录文档。刚开始接触衡山派Luban-Lite SDK时你可以先从SCons的基础命令用起理解整个构建过程。等熟悉之后强烈建议切换到OneStep命令集它能让你每天的开发操作行云流水把精力更集中在代码逻辑本身而不是敲命令上。遇到不记得的命令随时h一下看看帮助很快就能上手。

相关文章:

衡山派Luban-Lite SDK构建与开发命令详解:SCons与OneStep实战指南

衡山派Luban-Lite SDK构建与开发命令详解:SCons与OneStep实战指南 最近在用衡山派(ArtInChip)的开发板做项目,发现他们的Luban-Lite SDK用起来挺顺手的,特别是里面那套构建和开发命令,把很多繁琐的步骤都简…...

9. 基于TI MSPM0L1306的PWM输出详解与呼吸灯实战

9. 基于TI MSPM0L1306的PWM输出详解与呼吸灯实战 最近在玩TI的MSPM0L1306这块板子,发现它的PWM功能配置起来挺有意思的,尤其是配合官方的SysConfig图形化工具,比直接怼寄存器方便多了。很多刚开始接触这块板子的朋友可能会觉得PWM配置有点绕…...

Qwen2-VL-2B-Instruct与Matlab联动:科学计算可视化结果的自动解读

Qwen2-VL-2B-Instruct与Matlab联动:科学计算可视化结果的自动解读 每次做完仿真,看着屏幕上密密麻麻的曲线和三维图,你是不是也头疼怎么把它们变成报告里的文字?频谱图上的峰值、曲面图的拐点、时域波形的异常,这些关…...

触摸屏与多台PLC无线Profinet通信的配置与优化指南

1. 无线Profinet通信的基础认知 第一次接触工业无线通信时,我和很多工程师一样充满疑虑——用无线方式传输Profinet协议真的靠谱吗?经过三年在汽车焊装车间的实战验证,我可以负责任地说:现代工业级无线方案完全能满足绝大多数场景…...

Stable Diffusion XL实战:从零开始构建个性化AI绘画模型的完整指南

1. 环境准备与基础配置 第一次接触Stable Diffusion XL(SDXL)模型训练时,最让人头疼的就是环境配置。记得去年我在公司服务器上部署时,光是CUDA版本不兼容就折腾了整整两天。不过现在流程已经简化很多,跟着我的步骤走&…...

DeEAR镜像开箱即用教程:免conda/pip依赖,直接运行app.py启动情感分析Web服务

DeEAR镜像开箱即用教程:免conda/pip依赖,直接运行app.py启动情感分析Web服务 1. 什么是DeEAR语音情感分析系统 DeEAR(Deep Emotional Expressiveness Recognition)是一个基于wav2vec2的深度语音情感表达分析系统。它能自动识别语…...

阿里通义AI PPT隐藏技巧:万字文档自动提炼14页精华幻灯(含内容优化指南)

阿里通义AI PPT隐藏技巧:万字文档自动提炼14页精华幻灯(含内容优化指南) 在信息爆炸的时代,研究人员、企业高管和学术工作者常常需要处理动辄数万字的技术文档、行业报告或学术论文。将这些庞杂内容转化为简洁有力的演示文稿&…...

NSSM在Win10中的高效服务部署与疑难排错全攻略

1. NSSM:让任何程序在Win10中“乖乖”当服务 如果你在Windows 10上跑过一些自己写的脚本、Python应用或者Node.js服务,肯定遇到过这样的烦恼:电脑一锁屏或者注销,程序就断了;想让它在后台默默运行,还得一直…...

CASE_04 基于FPGA的智能电梯控制系统设计与实现

1. 智能电梯控制系统的FPGA实现价值 第一次接触电梯控制系统设计时,我被传统PLC方案的布线复杂度震惊了——密密麻麻的继电器和控制柜,调试时需要拿着图纸逐个点位测试。直到尝试用FPGA实现六层电梯控制器,才发现硬件可编程技术的魅力&#x…...

RK3568 MIPI摄像头开发实战:V4L2多平面格式的坑与填坑指南

RK3568 MIPI摄像头开发实战:V4L2多平面格式的坑与填坑指南 在嵌入式视觉系统开发中,RK3568凭借其强大的视频处理能力和丰富的接口支持,成为MIPI摄像头开发的理想平台。然而,当开发者真正着手实现V4L2多平面格式的视频采集时&#…...

万象熔炉 | Anything XL企业应用:隐私敏感场景下本地AI绘图合规实践

万象熔炉 | Anything XL企业应用:隐私敏感场景下本地AI绘图合规实践 1. 项目背景与核心价值 在当今企业环境中,数据安全和隐私保护已经成为不可忽视的重要议题。特别是在金融、医疗、法律等敏感行业,使用云端AI绘图服务存在数据泄露风险&am…...

量子态探秘:从纯态到混合态的本质解析

1. 量子态的基本概念:从硬币到量子比特 想象你手里有一枚硬币。在经典世界里,它要么正面朝上,要么反面朝上,没有中间状态。但量子世界完全不同——量子比特可以同时处于"正面"和"反面"的叠加状态,…...

NB-IOT开发实战|基于STM32的AT指令状态机优化设计与实现

1. NB-IOT开发中的AT指令痛点解析 第一次接触NB-IOT模块开发时,我被AT指令的响应处理折磨得不轻。最典型的场景就是发送AT指令后,代码里写满了delay_ms(100)这样的延时等待。实测发现这种写法存在三个致命问题: 首先,延时值很难确…...

吊打 IDM、迅雷?高中生开发,新一代智能下载神器!

戳下方名片,关注并星标!回复“1024”获取2TB学习资源!👉体系化学习:运维工程师打怪升级进阶之路 4.0— 特色专栏 —MySQL/PostgreSQL/MongoDBElasticSearch/Hadoop/RedisKubernetes/Docker/DevOpsKafka/RabbitMQ/Zo…...

南北阁Nanbeige 4.1-3B行业应用:微信小程序开发中的智能客服与内容生成

南北阁Nanbeige 4.1-3B行业应用:微信小程序开发中的智能客服与内容生成 最近在捣鼓一个微信小程序项目,团队就两个人,既要管前端界面,又要管后端逻辑,最头疼的是内容运营和用户服务。每天回复重复的咨询问题、绞尽脑汁…...

STM32F103C8T6定时器实战:5分钟搞定TIM2中断配置(附OLED显示效果)

STM32F103C8T6定时器实战:5分钟搞定TIM2中断配置(附OLED显示效果) 刚拿到STM32开发板时,定时器配置总是让人望而生畏。那些复杂的寄存器、晦涩的术语,还有永远理不清的时钟树...但今天我要分享的是一种极简配置法&…...

从焊接到调试:用JTAG拯救硬件开发的完整指南(STM32实例)

从焊接到调试:用JTAG拯救硬件开发的完整指南(STM32实例) 当你第一次拿到一块空白的STM32开发板时,那种既兴奋又忐忑的感觉我至今记忆犹新。作为硬件开发者,我们常常会遇到这样的困境:电路板焊接好了&#x…...

ASN.1调试秘籍:利用asn1c生成的代码快速定位编解码问题(附内存诊断技巧)

ASN.1调试实战:从内存模型到跨平台问题定位 在通信协议和文件格式的世界里,ASN.1就像一位沉默的翻译官,负责将结构化数据转换为紧凑的二进制流。但当这位翻译官突然"口齿不清"时,开发者往往需要面对各种令人头疼的编解码…...

用树莓派Pico和MicroPython玩转OLED显示:从I2C连接到动态内容展示

树莓派Pico与MicroPython实战:OLED屏幕的I2C驱动与动态内容开发指南 1. 硬件准备与环境搭建 要让树莓派Pico驱动OLED屏幕,首先需要准备以下硬件组件: 树莓派Pico开发板(RP2040芯片)SSD1306驱动的0.96寸OLED屏幕&…...

立创 桌宠2.0 MP3播放器DIY:TD5580A解码+LTK5128D运放+IP5305电源方案全解析

立创 桌宠2.0 MP3播放器DIY:TD5580A解码LTK5128D运放IP5305电源方案全解析 最近有不少朋友在问,想自己动手做一个桌面小音箱或者MP3播放器,有没有一个从芯片选型到电路设计都讲得比较明白的方案?正好,我之前用立创EDA设…...

立创SBUS转UART转换器设计:基于STM32G070的ROS与MCU双模协议转换模块

立创SBUS转UART转换器设计:基于STM32G070的ROS与MCU双模协议转换模块 最近在玩机器人项目,想把航模遥控器接到自己的ROS小车或者STM32主板上,发现遥控器输出的SBUS信号直接连上去根本没法用。网上找了一圈,要么是成品模块太贵&…...

立创开源:基于MPU6050与HC-08蓝牙的智能遥控平衡小车项目全解析

立创开源:基于MPU6050与HC-08蓝牙的智能遥控平衡小车项目全解析 大家好,最近在立创开源平台看到一个挺有意思的项目——一个能自己保持平衡,还能用手机遥控的小车。很多刚接触嵌入式或者PID控制的朋友可能会觉得这玩意儿很复杂,不…...

CCMusic音乐风格识别效果展示:高清频谱图+Top-5概率柱状图实拍

CCMusic音乐风格识别效果展示:高清频谱图Top-5概率柱状图实拍 安全声明:本文仅展示技术实现效果,所有案例均为公开音频样本分析,不涉及任何版权内容和个人数据。 1. 项目概览:当音乐遇见计算机视觉 CCMusic Audio Gen…...

C语言文件读写操作代码解析:为Ostrakon-VL-8B模型权重加载提供思路

C语言文件读写操作代码解析:为Ostrakon-VL-8B模型权重加载提供思路 你是不是也好奇,那些动辄几十个G的AI模型文件,比如Ostrakon-VL-8B,到底是怎么从硬盘里被“搬”到电脑内存,再“送”到GPU显存里去的?虽然…...

M2LOrder开源模型生态:97个.opt文件结构解析+SDGB游戏数据来源揭秘

M2LOrder开源模型生态:97个.opt文件结构解析SDGB游戏数据来源揭秘 1. 项目概述 M2LOrder是一个基于.opt模型文件的情绪识别与情感分析开源服务,提供HTTP API和WebUI两种访问方式。这个项目最特别的地方在于它拥有97个不同的.opt模型文件,总…...

Halcon实战:NURBS样条曲线拟合在工业检测中的高效应用与gen_contour_nurbs_xld解析

1. NURBS样条曲线在工业检测中的核心价值 在工业视觉检测领域,轮廓拟合精度直接决定产品质量判定的准确性。传统多边形逼近方法在处理复杂曲面时往往需要大量线段才能达到理想效果,而NURBS(非均匀有理B样条)通过控制点、权重和节点…...

信息获取自由解决方案:bypass-paywalls-chrome-clean实战指南

信息获取自由解决方案:bypass-paywalls-chrome-clean实战指南 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 在信息爆炸的数字时代,付费墙已成为获取优质内容…...

Qwen3-14B应用场景拓展:支持JSON Schema输出,便于前端直接解析结构化响应

Qwen3-14B应用场景拓展:支持JSON Schema输出,便于前端直接解析结构化响应 1. 模型概述 Qwen3-14b_int4_awq是基于Qwen3-14b模型的int4量化版本,采用AngelSlim技术进行压缩优化。这个版本特别适合需要高效文本生成能力的应用场景&#xff0c…...

夜莺监控短信告警实战:5分钟搞定阿里云短信接口对接(附Python脚本)

企业级夜莺监控短信告警实战:从阿里云API对接到底层原理全解析 凌晨三点,服务器CPU飙升至95%——当这种紧急情况发生时,仅靠邮件或IM工具通知显然不够。作为运维负责人,我曾经历过因告警延迟导致业务中断的惨痛教训,直…...

Mockito实战:5个Spring Boot单元测试中常见的坑与解决方案

Mockito实战:Spring Boot单元测试中5个高频陷阱与工程化解决方案 在Spring Boot项目中使用Mockito进行单元测试时,即使经验丰富的开发者也会遇到各种"暗坑"。这些陷阱往往导致测试结果与预期不符,甚至引发生产环境才暴露的问题。本…...