SCons

什么是构建工具(系统)

构建工具(software construction tool)是一种软件,它可以**根据一定的规则或指令,将源代码编译成可执行的二进制程序。**这是构建工具最基本也最重要的功能。

实际上构建工具的功能不止于此,通过这些规则有一定的语法,并组织成文件。这些文件用来控制构建工具的行为,在完成软件构建之外,也可以做其它事情。

目前最流行的构建工具是GNU Make。很多知名开源软件,如Linux内核就采用Make构建。
Make通过读取Makefile文件来检测文件的组织结构和依赖关系,并完成Makefile中所指定的命令。

由于历史原因,Makefile的语法比较混乱,不利于初学者学习。此外在Windows平台上使用Make也不方便,需要安装Cygwin环境。为了克服Make的种种缺点,人们开发了其它构建工具,如CMake和SCons等。

RT-Thread构建工具

RT-Thread早期使用Make/Makefile构建。从RT-Thread0.3.0开始,RT-Thread开发团队逐渐引入了SCons构建系统,引入SCons唯一的目的是:使大家从复杂的Makefile配置、IDE配置中脱离出来,把精力集中在RT-Thread功能开发上。

有些读者可能会有些疑惑,这里介绍的构建工具与IDE有什么不同呢?
IDE通过图形化界面的操作来完成构建。大部分IDE会根据用户所添加的源码生成类似Makefile或Sconscript的脚本文件,在底层调用类似Make或SCons的工具来构建源码。

SCons简介

SCons是一套由Python语言编写的开源构建系统,类似于GNU Make。
它采用不同于通常Makefile文件的形式,而是使用SConstruct和SConscript
这些文件也是Python脚本,能够使用标准的Python语法来编写。所以在Sconstruct和SConscript文件中可以调用Python标准库进行各类复杂的处理,而不局限于Makefile设定的规则。

RT-Thread中Scons的脚本构建

SCons使用SConscript和SConstruct文件来组织源码结构并进行构建,
SConstruct是scons构建的主脚本,SConScript存放在源代码的子目录下,通常放在项目的子目录,以达到分层构建的目的。

一个项目(BSP)只有一个SConstruct,但是会有多个SConscript。
一般情况下,每个存放有源代码的子目录下都会放置一个SConscript。

/-- rtconfig.py    ---- 控制SCons构建的配置文件,存放了如工具链,构建参数等配置。-- SConscript-- SConstruct    ---- SCons的入口脚本,初始化了SCons构建rt-thread所需的必要环境-- Kconfig        ---- 顶层Kconfig文件,menuconfig的入口Kconfig文件-- rt-thread/--- src/---- SConscript   ---- 各级源码的scons子脚本,控制当前级别下的源码构建行为---- Kconfig      ---- 各级源码的Kconfig子脚本,存放当前级别下的配置项---- **.c

为了方便开发者使用SCons,RT-Thread搭建了如上所示的构建框架,
其中包括了一份SCons的入口脚本(SConstruct),以及分散在各级源码的SCons子脚本(Sconscript),还有一份便于配置构建行为的配置脚本(rtconfig.py)。
同时,RT-Thread也在SCons标准接口的基础上,提供了一组用于组织源码工程的扩展接口。开发者在使用时,可以借助RT-Thread提供的扩展接口,更方便的完成源码的组织与配置。

在这里插入图片描述
为了使RT-Thread更好的支持多种编译器,以及方便的调整构建参数,为每个BSP单独创建了一个名为rtconfig.py的配置文件。

因此每一个 RT-Thread BSP 目录下都会存在下面三个文件:rtconfig.py、SConstruct 和 SConscript,它们控制 BSP 的构建。一个 BSP 中只有一个 SConstruct 文件,但是却会有多个 SConscript 文件,可以说 SConscript 文件是组织源码的主力军。

SCons基本命令

RT-Thread构建系统支持多种编译器。
目前支持的编译器包括ARM GCC、MDK、IQR、VisualStudio、Visual DSP。主流的 ARM Cortex M0、M3、M4 平台,基本上 ARM GCC、MDK、IAR 都是支持的。有一些 BSP 可能仅支持一种,读者可以阅读该 BSP 目录下的 rtconfig.py 里的 CROSS_TOOL 选项查看当前支持的编译器。

打开Env工具,如果是ARM平台的芯片,输入scons命令直接编译BSP,这时候默认使用的是ARM GCC编译器。

如果用户要使用其它的BSP已经支持的编译器编译工程,或者BSP为非ARM平台的芯片,那么不能直接使用scons命令编译工程,需要自己安装对应的编译器,并且指定使用的编译器路径。

在编译工程前,可以在Env命令行界面使用下面的2个命令指定编译器为MDK和编译器路径为MDK的安装路径:

set RTT_CC=keil
set RTT_EXEC_PATH=C:/Keilv5

再例如

set RTT_CC=gcc
set RTT_EXEC_PATH=D:\software\RaspberryPi-Pico\gcc\2020-q4-major\bin

scons

在Env命令行窗口进入要编译的BSP工程目录,然后使用此命令可以直接编译工程。
如果执行过 scons 命令后修改了一些源文件,再次执行 scons 命令时,则 SCons 会进行增量编译,仅编译修改过的源文件并链接

scons --target=XXX

如果使用MDK/IAR来进行项目开发,在生成MDK或者IAR工程前,需要检查rtconfig.py文件中EXEC_PATH变量所保存的对应IDE的安装路径是否正确:
在这里插入图片描述
当修改rtconfig.h打开或者关闭某些组件时,需要使用以下命令中的其中一种重新生成对应的定制化的工程,然后在 MDK/IAR 进行编译下载:

scons --target=iar
scons --target=mdk4
scons --target=mdk5

scons --dist

搭建项目框架,使用此命令会在BSP目录下生成dist目录,这便是开发项目的目录结构,包含了RTT源码以及BSP相关工程,不相关的BSP文件夹及libcpu都会被移除,并且可以随意拷贝此工程到任何目录下使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/179720.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Kafka 的应用场景

Kafka 是一个开源的分布式流式平台,它可以处理大量的实时数据,并提供高吞吐量,低延迟,高可靠性和高可扩展性。 Kafka 最初是为分布式系统中海量日志处理而设计的。它可以通过持久化功能将消息保存到磁盘,并让消费者按…

移远EC600U-CN开发板 11.15

制作一个简单UI: 1."端口设置"模块 *效果图 *代码 def backEvent(evt): #返回主界面code evt.get_code() if code lv.EVENT.CLICKED:lv.scr_load(mainInterface)def popUpEvent(evt): #弹窗提醒code evt.get_code()if code lv.EVENT.CL…

JavaScript数据存储

原始类型:存储在栈内存中,每次开辟的空间大小是固定 引用类型(对象、函数、数组):存储在堆内存中,开辟的空间大小根据数据的大小决定 // 声明变量会在栈内存中开辟空间 // 创建对象在堆内存中开辟空间&…

Django——模板层、模型层

模板层 一. 模版语法 {{ }}: 变量相关 {% %}: 逻辑相关 1. 注释是代码的母亲 {# ... #} 2. 基本数据类型传值 int1 123 float1 11.11 str1 我也想奔现 bool1 True list1 [小红, 姗姗, 花花, 茹茹] tuple1 (111, 222, 333, 444) dict1 {username: jason, age: 18, i…

ERP和MES对接都有什么方式

万界星空科技MES生产管理系统的应用比较广,在和ERP连接时,必须先掌握什么模块是和MES业务流程有关的。 通过详细介绍ERP和MES对接方式的不同特点、应用场景和操作方法,可帮助企业更好地实现信息集成,提升生产效率和质量&#xff…

Donut 中,video组件层级失效、同层渲染失效、z-index设置无效解决办法

微信小程序转安卓之后,z-index设置的层级关系失效,video组件总是处在最上层解决办法: 很重要的设置! 同层渲染要开 xweb,project.miniapp.json中勾选此设置 感谢腾讯官方大佬 黄嘉敏

11111

#include <iostream> #include <vector> #include <queue> #include <algorithm>using namespace std;// 边的结构体 struct Edge {int src, dest, weight;// 按照权重进行排序bool operator<(const Edge& other) const {return weight < ot…

闲聊从零开发一个2D数字人流程实战

.2D数字人技术 百度&#xff0c;腾讯&#xff0c;等大厂都有自己的数字平台制作&#xff08;套壳&#xff1a;api后台转发vue前端&#xff09;&#xff0c;国外也有出名的heygen&#xff08;非常厉害一个&#xff09;通过开源项目组合实现&#xff0c;再打通每个项目已api的形…

Redis概述

Redis是一款NoSql(非关系型)数据库&#xff0c;实现了主从同步。 使用场景&#xff1a; 对数据高并发的读写。 海量数据的读写。 对数据的可扩展性的。 NoSql数据库举例&#xff1a; Memcache&#xff1a;数据都在内存中&#xff0c;但是数据不持久化&#xff0c;而且只支…

ChatGPT助力高效办公——神奇的效率工具Airy

Airy是一款免费而又强大的高效办公软件&#xff0c;用户可以通过快捷键和丰富的内置插件&#xff0c;充分发挥GPT-3.5模型的强大功能&#xff0c;轻松实现搜索、翻译、文本生成与写作、文本概括与总结&#xff0c;同时还可以作为一款日程提醒工作&#xff0c;记录和提醒每天要做…

python之 flask 框架(2)项目拆分的 执行逻辑

项目的结构图 app.py # 导入__init__.py 比较特殊 from APP import create_appapp create_app() if __name__ __main__:app.run(debugTrue)init.py # __inti__.py # 初始化文件&#xff0c;创建Flask应用 from flask import Flask from .views import bluedef create_ap…

基于MS16F3211芯片的触摸控制灯的状态变化和亮度控制(11.15)

1.任务所需实现基本功能 关机状态时白灯亮蓝灯灭&#xff0c;此时长按按键无反应&#xff0c;白灯亮度降低的状态&#xff0c;蓝灯保持灭的状态。点按按键一次&#xff0c;白灯熄灭&#xff0c;蓝灯亮此时W引脚控制的灯亮。继续点按按键。蓝灯亮&#xff0c;此时W引脚控制的灯…