SiliconCompiler workflow

文章目录

  • [它和你现在做的 CI/CD 有什么关系?](#它和你现在做的 CI/CD 有什么关系?)
  • [-1 这个项目的目录](#-1 这个项目的目录)
    • [2 .github/workflows/(GitHub Actions CI/CD 配置)](#2 .github/workflows/(GitHub Actions CI/CD 配置))
      • [3 它有哪些 workflow?](#3 它有哪些 workflow?)
        • [4 daily_ci.yml 重点是什么?](#4 daily_ci.yml 重点是什么?)
        • [5 python_ci.yml 又是什么?](#5 python_ci.yml 又是什么?)
  • [-2 SiliconCompiler CI/CD 分层设计](#-2 SiliconCompiler CI/CD 分层设计)
  • [-3 SiliconCompiler CI 分为两类:](#-3 SiliconCompiler CI 分为两类:)
    • [1. 快速 CI(每次提交)](#1. 快速 CI(每次提交))
    • [2. 慢速 CI(定时)](#2. 慢速 CI(定时))

SiliconCompiler 是一个开源的模块化硬件构建系统。
SiliconCompiler = 用 Python 统一调度各种 EDA 工具,把芯片/硬件设计流程自动化的开源框架。

它和你现在做的 CI/CD 有什么关系?

我现在做的Gitee Go Demo是:

复制代码
提交代码 → 运行 Python 脚本 → 上传制品 → 发布

SiliconCompiler 做的是更复杂的:

复制代码
提交硬件/EDA代码
→ 安装依赖
→ 多系统、多 Python 版本测试
→ 调用 EDA/仿真工具
→ 跑测试集
→ 跑设计案例
→ 保存日志、覆盖率、artifact

-1 这个项目的目录

复制代码
siliconcompiler/      项目核心源码
tests/                自动化测试代码
examples/             示例设计/示例项目
docs/                 文档
.github/workflows/    GitHub Actions CI/CD 配置
pyproject.toml        Python 项目配置

2 .github/workflows/(GitHub Actions CI/CD 配置)

3 它有哪些 workflow?



SiliconCompiler 不是只有一条 CI,而是把不同目的拆成多条 workflow:快速测试、每日测试、工具测试、镜像构建、代码检查、发布构建。

4 daily_ci.yml 重点是什么?

这个 daily_ci.yml 名字叫 Daily CI Tests。它有三种触发方式:手动触发、被其他 workflow 调用、定时触发;定时规则是每天运行一次。

它的结构如下:

复制代码
Daily CI Tests
├── docker_image
│   └── 准备工具容器
├── cache
│   └── 安装依赖、生成缓存、上传 artifact
├── daily_tests_job
│   └── 多 Python 版本运行完整测试
└── gallery
    └── 跑设计样例/benchmark

优点:

5 python_ci.yml 又是什么?

python_ci.yml 更像普通项目里的基础 CI。它在 push 到 main 或 test/** 分支、Pull Request、手动触发时运行。它会在多个 Python 版本和多个操作系统上测试,包括 Ubuntu、Windows、macOS,并运行 pytest。

复制代码
python_ci.yml = 快速基础验证
daily_ci.yml = 每日完整验证

-2 SiliconCompiler CI/CD 分层设计

SiliconCompiler 的 CI 不是一条流水线,而是:

复制代码
CI/CD 体系(多层)
├── 快速 CI(python_ci.yml)
├── 每日 CI(daily_ci.yml)
├── 工具链 CI(tools_ci.yml)
├── 环境构建(docker_image.yml)
├── 代码规范(lint.yml)
└── 发布 CI(wheels.yml)

不同目的 → 不同 workflow

为什么要分这么多 CI?

我现在的 Demo 是:

复制代码
一条流水线 → 做所有事

每一层是干什么的?

python_ci.yml(快速 CI)

复制代码
每次提交 / PR → 快速验证

daily_ci.yml(每日 CI)

复制代码
每天跑一次"完整验证"


不是每次提交都跑

docker_image.yml(环境构建)

复制代码
构建运行环境(工具链)

很重要因为:EDA / 算法 → 依赖复杂环境

tools_ci.yml(工具验证)

复制代码
验证工具是否正常

lint.yml(代码规范)

复制代码
检查代码风格

wheels.yml(发布)

复制代码
打包 + 发布 Python 包

-3 SiliconCompiler CI 分为两类:

1. 快速 CI(每次提交)

复制代码
python_ci.yml

快速反馈

2. 慢速 CI(定时)

复制代码
daily_ci.yml

深度验证

相关推荐
吃好睡好便好7 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅7 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
x_yeyue9 小时前
三角形数
笔记·算法·数论·组合数学
念何架构之路10 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星10 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
失去的青春---夕阳下的奔跑11 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光11 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩12 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_6294947312 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表
ʚ希希ɞ ྀ13 小时前
单词拆分----dp
算法