我正在开发一种嵌入式软件,可以在两到三个不同的微控制器系列上运行。现在我们有makefile来读取配置开关并进行编译。
对于开发人员和非开发人员来说,使用编译开关和构建配置保持更新的过程变得越来越乏味。我知道Linux内核使用ncurses来生成编译配置。我正在寻找一个类似的工具,但跨平台。它应该在Windows和Linux上运行。我知道这仍然无法解决问题,但它对非开发人员更有吸引力,我也可以快速共享我的.config文件或将其与现有文件进行比较。配置将按特定顺序排列,这里的diff工具将有所帮助。
任何人都可以分享他们在类似项目维护或参考项目(多个微型嵌入式和通用代码库)方面的经验。只想了解最佳实践。
PS:语言使用C,8/16位微处理器,没有操作系统只是基于计时器的批处理调度程序(裸机)
答案 0 :(得分:1)
如果您没有找到任何其他内容,GNU autotools可以让事情变得更容易。
答案 1 :(得分:1)
我有一个微控制器,但有几个项目是从相同的源代码编译而来的。我认为我的情景与你的相似,至少在某种程度上如此。我的解决方案也受到Linux内核的启发。
config.h
需要访问某些配置参数的所有源代码只包含一个名为config.h
的头文件。
config.h
只包含一行:
#include <config/project.h>
project.h
我有几个配置头文件,每个项目一个。 project.h
由宏定义组成,其值为true
,false
或常量:
#define CONFIG_FOO true
#define CONFIG_BAR false
#define CONFIG_TIME 100
check.c
此文件检查配置参数的正确性: - 即使未对该项目使用或有意义,也必须定义所有参数 - 发出不需要的参数组合信号 - 参数值受到约束。
#if !defined(CONFIG_FOO)
#error CONFIG_FOO not defined
#endif
#if !defined(CONFIG_BAR)
#error CONFIG_BAR not defined
#endif
#if !defined(CONFIG_TIME)
#error CONFIG_TIME not defined
#endif
#if !(CONFIG_FOO ^ CONFIG_BAR)
#error either CONFIG_FOO or CONFIG_BAR should be se
#endif
#if CONFIG_TIME > 250
#error CONFIG_TIME too big
#endif
Makefile
通过指示编译器输出预处理器宏,可以(使用sed
表达式)为Makefile
提供给定项目提供的相同参数值。
答案 2 :(得分:1)
当我进行多平台开发时,我使用了像in my answer here.这样的解决方案为每个平台都有一个特定的“platform_XXX.h”,并将条件编译限制为单个主“platform.h”。选择正确子文件的文件。