PolarSSL项目中tf-psa-crypto组件的构建目录管理优化
2025-06-05 07:47:08作者:彭桢灵Jeremy
在PolarSSL项目的tf-psa-crypto组件开发过程中,团队发现了一个可以优化构建流程的机会。目前,使用CMake进行构建的组件需要自行管理构建目录,这导致每个组件脚本中都包含了重复的目录管理代码。
现状分析
当前tf-psa-crypto组件中的CMake构建流程需要每个组件脚本处理以下操作:
- 创建构建目录
- 进入该目录执行构建
- 测试完成后返回原目录
- 清理构建目录
这种模式在组件较少时是可行的,但随着更多组件从mbedtls迁移到tf-psa-crypto,这种重复代码会变得难以维护。更重要的是,tf-psa-crypto组件几乎全部采用CMake进行构建,且推荐使用out-of-source构建方式(即在源代码目录外构建)。
优化方案
项目团队提出将构建目录的管理逻辑从各个组件脚本中提取出来,统一由核心脚本all-core.sh处理。这样做的优势包括:
- 代码复用:避免在每个组件中重复相同的目录管理代码
- 一致性:确保所有组件使用相同的目录管理策略
- 可维护性:目录管理逻辑变更只需修改一处
- 简洁性:组件脚本只需关注实际的构建和测试逻辑
优化后的组件脚本将简化为仅包含构建和测试命令,例如:
component_test_cmake_tf_psa_crypto_out_of_source() {
msg "build: cmake tf-psa-crypto 'out-of-source' build"
cmake -D CMAKE_BUILD_TYPE:String=Check -D GEN_FILES=ON "$TF_PSA_CRYPTO_ROOT_DIR"
make
msg "test: cmake tf-psa-crypto 'out-of-source' build"
make test
}
技术背景
CMake的out-of-source构建是一种推荐做法,它有多个优点:
- 保持源代码目录清洁
- 支持同时进行多种构建配置
- 便于清理构建产物
- 避免构建产物污染版本控制系统
在PolarSSL项目中,早期版本由于CMake兼容性问题(特别是Ubuntu 16.04上的旧版CMake)需要特殊处理out-of-source构建。但随着项目发展,这些问题可能已经得到解决,使得统一管理构建目录成为可能。
实施影响
这一优化主要影响tf-psa-crypto组件,不会改变mbedtls组件的现有行为。对于开发者来说,迁移到tf-psa-crypto的组件将获得更简单的脚本编写体验,同时保持构建过程的可靠性。
该优化是PolarSSL项目持续改进构建系统的一部分,旨在为开发者提供更高效、更一致的开发体验,同时保持项目的稳定性和可维护性。
登录后查看全文
热门项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
FreeSql功能强大的对象关系映射(O/RM)组件,支持 .NET Core 2.1+、.NET Framework 4.0+、Xamarin 以及 AOT。C#00
项目优选
收起
deepin linux kernel
C
27
14
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
657
4.26 K
Ascend Extension for PyTorch
Python
502
606
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
939
862
Oohos_react_native
React Native鸿蒙化仓库
JavaScript
334
378
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
390
284
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
123
195
openGauss kernel ~ openGauss is an open source relational database management system
C++
180
258
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.54 K
891
昇腾LLM分布式训练框架
Python
142
168