首页 程序笔记 使用Keil2Makefile脚本将Keil工程自动转化为Makefile工程

使用Keil2Makefile脚本将Keil工程自动转化为Makefile工程

概述

传统单片机开发环境是 Keil IDE,它为开发者提供了一套非常方便的开发环境,我们只需要进行很少的设置就可以完成单片机程序的编写、编译、烧录和调试。但 Keil 也有着过于陈旧、闭源和无法跨平台等缺点,用惯了 CLion、VSCode 等现代编译器很难再习惯 Keil;而且众多的开源软件都是使用开源编译链开发的,如果我们对开源编译链没有了解的话,很难上手众多的开源项目。

众多的原因使我们放弃了 Keil IDE,转向 GNU Arm Embedded Toolchain 配上现代编辑器的方案。但不可否认,自己配置开发环境并编写 Makefile 或者 CMake 并不是一件简单的事情。如果我们使用 HAL 库开发 STM32,我们可以使用 STM32CubeMX 配上 CLion 的方案,在 CubeMX 上进行图形化配置并生成 Makefile 工程,最后利用 CLion 对 CubeMX 的支持,直接进行一键配置和开发(更详细的各种方案的对比可以看我另一篇文章)。但如果使用固件库开发 STM32,现在我还没有找到非常方便的配置方案,所以我写了一个自动化的 Python 脚本 Keil2Makefile,可以自动读取 Keil 工程的配置来生成 Makefile,随后便可以轻松地抛弃 Keil 进行开发。

准备

  • Python:运行脚本
  • GNU Arm Embedded Toolchain:提供编译器、链接器
  • MinGW:提供 Make 指令
  • VSCode:代码编辑器

使用

首先在 Github(https://github.com/Qrpucp/Keil2Makefile) 或 Gitee(https://gitee.com/qrpucp/Keil2Makefile) 上下载 Keil2Makefile 脚本,下载完成后将整个文件夹复制至 Keil 工程的根目录。

随后在 VSCode 中打开终端,在该目录下运行命令

cd Keil2Makefile/Source/  python Keil2Makefile.py


成功运行后可以看到一系列提示,此时在根目录下已经自动生成了 Makefile 文件。
我们回到原来的目录进行编译,运行命令 cd …/… make。

如果不出问题的话,随着一系列文件的编译,最后我们可以看到成功编译出来的 elf、hex 和 bin 文件。

用户配置

Config/Config.yml 为用户配置文件,在这个文件中可以进行一系列的配置,默认配置如下:

  • debug_build
    0:debug 模式
    1:release 模式
  • optimization:编译器优化选项
  • generate_mode
    force_regenerate:强制重新生成 Makefile,所有配置均进行更新
    auto_detect:若不存在 Makefile,则创建 Makefile;如果已存在 Makefile,则只会进行必要参数的更新
  • auto_add_file:[ 该功能还未实现 ]
    0:不自动添加文件
    1:自动添加 C 语言文件
  • build_dir:输出文件目录
  • modify_asm
    0:不修改汇编语言文件后缀名
    1:修改汇编语言文件后缀名

注意事项

虽然 Keil2Makefile 脚本可以自动化生成 Makefile,但因工程的不同,仍不能保证可以直接成功编译,事实上,脚本不可能完成所有转换工作,下面我将解释无法编译的某些情况和解决方法。

1.汇编文件

最难解决的就是汇编语言文件的问题,Keil 使用的编译器和 GNU 的编译器能够识别的汇编语言格式不一样,甚至连后缀名都不同,Keil 能识别的后缀名是 .asm,而 GNU 编译器能识别的后缀名是.s。我们需要手动替换每一个汇编语言文件,Keil2Makefile 脚本可以预先储存 STM32 的启动文件,实现自动替换的功能,但我们在工程中经常还会用到别的汇编语言文件,比如 UCOS 就包含了很多汇编语言文件,这些文件脚本不可能实现自动替换,只能我们手动去寻找并替换。不过一般大型工程都会为每一种编译器提供对应的汇编语言文件,我们不用担心不支持 GNU 编译器的问题。

2.重复定义

每种编译器都会自带一些变量类型的定义,如果这些定义和原来代码中的定义重复了,则删除掉原代码中的定义即可。

3. C/C++混合编程

如果工程里既有 C 语言代码又有 C++ 代码,那么需要使用 g++ 进行链接,且在 C 语言文件中需要在首尾加上如下的预编译指令。

#ifdef __cplusplus
 extern C {
#endif
     
//code

#ifdef __cplusplus
}
#endif

4. printf 重定向

在 GNU 编译器中,printf函数的重定向方法与 Keil 编译器不同,关于这个问题网络上有大量的解决方法,我就不重复说明了。

5. 编译器关键词

armcc 中的关键词__asm{NOP;}在GNU编译器中需要替换为 NOP,align(8)需要替换为__attribute((aligned(8)))。除此之外还有许多的关键词需要替换,可以编译报错后再进行替换。如果想要工程同时支持 Keil 编译器和 GNU 编译器,则可以使用条件编译指令判断编译器类型来选择使用哪一种关键词。

说明

Keil2Makefile 脚本通过读取 Keil 工程的配置文件来自动生成 Makefile,因为 Keil 的配置文件多种多样,我仅在自己能找到的工程上进行了测试,并不能保证该脚本对所有 Keil 工程都适用,如果使用该脚本报了错,可以私信找我解决。

该脚本目前支持的单片机型号很少,主要是因为每一个型号的单片机都需要一个链接脚本和启动文件,我现在并没有一种规则可以自动生成它们,只是通过CubeMX 生成后预先保存并在需要的时候进行替换,所以如果该脚本不支持你所使用的单片机型号,只需要使用 CubeMX 生成,然后复制到自己的工程中就可以了,也可以找我在脚本中支持该型号。

我会一直跟进并完善该脚本。

原文链接(感谢原作者):https://blog.csdn.net/weixin_45467056/article/details/123564509

3

站心网

概述 传统单片机开发环境是 Keil IDE,它为开发者提供了一套非常方便的开发环境,我们只需要进行很少的设置..

为您推荐

使用 html2canvas 实现截图功能

html2canvas 是一个开源的 JavaScript 库,用于将网页上的 HTML 元素渲染成图像。它通过遍历页面的 DOM 树和计算样式,然后将其绘制到 <canvas> 元素上,最终生成图片。该库不依赖服务器端,而是通过浏览器端的 Java..

使用SuperWebSocket实现Web消息推送

在大部分Web系统中,我们可能遇到需要向客户端推送消息的需求。SuperWebSocket第三方库能让我们轻松的完成任务。SuperWebSocket第三方库可以从网上下载,不过通过Visual Studio Nuget安装更快。引用SuperWebSocket相..

基于Dapper的开源Lambda扩展,且支持分库分表自动生成实体之基础

LnskyDB是基于Dapper的Lambda扩展,支持按时间分库分表,也可以自定义分库分表方法.而且可以T4生成实体类免去手写实体类的烦恼.文档地址:https://liningit.github.io/LnskyDB/开源地址:https://github.com/liningit/Ln..

.NET C# 使用Hook钩子实现全局监听键盘和鼠标

C# 是一种面向对象的编程语言,具有丰富的类库和工具支持,适用于各种类型的应用程序开发。Windows 提供了一种称为"钩子"(Hook)的机制,允许拦截并处理系统级别的事件,如键盘按键和鼠标移动。通过结合 C# 和 Hook..

C#使用 Attribute 实现 AOP 功能

在 C# 中,通过自定义 Attribute 并结合一些技术(如动态代理、反射等)可以实现 AOP(面向切面编程)。AOP 通常用于日志记录、性能监控、权限验证等横切关注点。以下是一个使用 C# Attribute 实现 AOP 功能的示例。..

ABP.Net Core使用教程(一)启动模版项目

只需要简单的3步:1,到官网下载模版项目 https://aspnetboilerplate.com/Templates2,用VS2017打开,将Web.Host设置为启动项3,在程序包管理器控制台(Nuget控制台)里设定默认项目为EntityFrameworkCore,执行命令..

C#中的线程安全的集合ConcurrentQueue使用示例

在多线程编程中,如何安全地在不同线程之间共享数据是一个非常重要的问题。C# 为我们提供了一些专门设计的线程安全集合,其中之一就是 ConcurrentQueue<T>。它是一种先进先出(FIFO)的数据结构,专门为多线程环境设..

CSS砌体布局示例和使用场景

CSS砌体布局(Masonry Layout)CSS砌体布局是一种网页布局技术,它的灵感来源于砖石墙的排列方式,类似于“拼图”或“拼砖”的效果。在砌体布局中,元素的排列并不完全遵循传统的网格布局规则,..

使用CSS columns-visibility实现砌体布局

CSS的 columns 属性(如 columns、column-count 和 column-width)通常用于多列文本布局,而不是直接用于砌体布局。然而,结合 columns 和 visibility 属性,可以在某些情况下实现类似砌体布局的效果,虽然它并不完..

使用System.Linq.Dynamic.Core扩展库动态构建 LINQ 查询

System.Linq.Dynamic.Core 是一个扩展库,用于在运行时动态构建 LINQ 查询,支持字符串形式的表达式解析和动态查询操作。它是 .NET 的一个强大工具,适合处理需要灵活定义查询逻辑的场景,例如动态过滤、排序、投影..

小米开源智能家居平台 ha_xiaomi_home 使用示例

小米近期在 GitHub 上开源了名为“ha_xiaomi_home”的项目,即 Home Assistant 米家集成组件。该组件由小米官方支持,旨在让用户在 Home Assistant 中集成和控制小米 IoT 智能设备。主要特点:官方支持:..

C#13新特性 使用System.Threading.Lock简化线程同步

C# 13 引入了新的线程同步类型 System.Threading.Lock,它通过作用域管理的方式简化了锁的使用,使代码更加清晰可靠。本文将全面介绍 System.Threading.Lock 的功能、适用场景,并提供完整的运行示例程序。1. 什么是..

微软官方Microsoft.Extensions.AI库使用示例

Microsoft.Extensions.AI 库介绍Microsoft.Extensions.AI 是一个扩展库,用于在 .NET 应用程序中轻松集成人工智能(AI)服务,例如 OpenAI、Azure OpenAI 和其他支持文本生成或语言模型的 API。通过与 Microsoft.Ext..

.Net Core中Dapper的使用详解

1.安装Dapper这里直接使用Nuget安装。安装版本是1.50.5安装完成之后,发现Nuget下已经有了Dapper。2.创建DapperHelper接下来创建一个DapperHelper帮助类,来进行读取数据库连接字符串,打开数据库等操作。public cla..

最新CentOS7安装搭建shadowsocks服务端+客户端使用图文教程

使用的CentOS版本是7.9,其他版本也可以。超级推荐的是搭建shadowsocks服务端,安装配置都很简单,几分钟就搞定,客户端支持PC移动端,下面是安装shadowsocks的过程,只要复制粘贴命令就行了,文件夹路径都不需要改..

ASP.NET 使用Entity Framework (EF) 创建迁移修改SQLite数据库表结构

在 ASP.NET 中,使用 Entity Framework (EF) 创建并连接 SQLite 数据库是一种轻量级、高效的数据库管理方式。以下是详细步骤:安装必要的 NuGet 包安装EntityFrameworkCore.Sqlite包:Install-Package Microsoft.Ent..

使用shields.io来实时显示GitHub项目star、watch和fork的数量

如何获取GitHub repo实时的star,watch和fork数量呢?这里推荐一个Shields.io工具,可以实时生成GitHub徽章,同时显示star数。显示效果如下:什么是 Shields.io?Shields.io 是一个开源项目,用于生成各种类型的徽章..

.NET 开源 ORM FreeSql 使用教程

什么是 FreeSql?FreeSql 是一个高性能、灵活且易用的 .NET 开源 ORM(对象关系映射工具),提供数据库操作的强大功能,包括实体类映射、链式查询、表达式树支持、数据库迁移等。它可以帮助开发者快速、高效地操作数..

SQL Server EF使用Sequence全局自增ID

在使用 Entity Framework (EF) 时,如果需要在 SQL Server 中实现一个 全局自增 ID,可以通过以下方法来实现。全局自增 ID 的需求通常是为了在多表之间实现唯一性递增 ID。实现方式 1:使用 SQL Server 的 SequenceS..

.NET9 开始删除内置的 Swagger 支持 可使用Scalar.AspNetCore替代

Microsoft 已决定从 .NET 9 中删除内置的 Swagger 支持 (Swashbuckle)。为什么 Swagger (Swashbuckle) 被删除?ASP.NET Core 团队已决定从 .NET 9 中删除内置的 Swagger 支持 (Swashbuckle),原因如下:维护问..

发表回复

返回顶部