Ziggo-CaaS-Switch软件配置教程

本文前言:

根据两份 software-build.md,在你"硬件部分已经完成配置"的前提下,软件部署可以按下面这套顺序做(硬件:https://blog.csdn.net/Rthan/article/details/160113548?spm=1001.2014.3001.5502)。 先确认板卡已经能正常启动 Linux,并且底层硬件接口已经可用,包括 TSN 相关网口、DMA/UIO、时钟/TSU、GCL/转发表对应驱动资源。两份软件都不是在仓库根目录编译,而是在各自的 Software 目录下:

  • 交换机软件目录:xx\Ziggo-CaaS-Switch-main\Ziggo-CaaS-Switch-main\Software\Time-Synchronization
  • 设备软件目录:xx\Ziggo-Device-main\Ziggo-Device-main\Software

另外,交换机文档里写"build 后有 time_sync_app 和 switch_config",但实际 CMakeLists.txt 生成的是 time_sync 和 switch_config。设备侧实际生成的是 time_sync 和 pkt_gen。

具体步骤:

1. 准备配置文件

两种设备都需要同一套调度结果导出的两个 JSON:

  • config.json:拓扑、节点类型、MAC、PTP 端口状态、链路、转发表

  • schedule.json:链路调度窗口、交换机计算窗口

仓库里有示例配置可参考:

  • 交换机示例:...\Software\Time-Synchronization\config\

  • 设备示例:...\Software\config\

你需要把 CNC/调度算法输出的 topology-config.json 和 topology-schedule.json 选定为本次实验使用版本。

2. 编译交换机软件

在交换机板上或你的目标 Linux 编译环境中进入:

bash 复制代码
cd /path/to/Ziggo-CaaS-Switch-main/Ziggo-CaaS-Switch-main/Software/Time-Synchronization
mkdir build
cd build
cmake ..
make

成功后应得到:

  • build/time_sync

  • build/switch_config

然后把配置文件复制到 build 目录,并固定命名为文档要求的名字:

bash 复制代码
cp ../config/<your-topology>-config.json ./config.json
cp ../config/<your-topology>-schedule.json ./schedule.json

3. 编译设备软件

进入设备软件目录:

bash 复制代码
cd /path/to/Ziggo-Device-main/Ziggo-Device-main/Software
mkdir build
cd build
cmake ..
make

成功后应得到:

  • build/time_sync

  • build/pkt_gen

同样把配置文件复制到 build 目录:

bash 复制代码
cp ../config/<your-topology>-config.json ./config.json
cp ../config/<your-topology>-schedule.json ./schedule.json

4. 板端部署与启动顺序

建议先把所有板子的可执行文件和对应 config.json、schedule.json 都放到各自板卡本地,再开始启动。运行顺序建议这样:

  1. 先启动所有交换机的时间同步

  2. 再下发交换机 GCL 和转发表

  3. 再启动设备的时间同步

  4. 最后启动设备发包

交换机启动

在交换机 build 目录下:

bash 复制代码
taskset -c 1 ./time_sync

文档明确建议把时间同步绑到一个 CPU 核上,避免内核错误或崩溃。日志级别可选:

bash 复制代码
taskset -c 1 ./time_sync -l w
taskset -c 1 ./time_sync -l i
taskset -c 1 ./time_sync -l t

其中 -l t 最详细。time_sync 需要持续运行,不是一次性程序。

时间同步起来后,再执行:

bash 复制代码
./switch_config

这一步负责把 GCL 和交换机转发表写进去。

设备启动

在设备 build 目录下先启动时间同步:

bash 复制代码
./time_sync

再启动关键业务流发包:

bash 复制代码
./pkt_gen

5. 联调时的推荐执行顺序

如果你现在是一个"交换机 + 多设备"的系统,建议按这个顺序上电后的软件部署:

  1. 每台交换机编译并准备好 build/time_sync、build/switch_config

  2. 每台设备编译并准备好 build/time_sync、build/pkt_gen

  3. 给所有节点放入与当前实验一致的 config.json / schedule.json

  4. 启动所有交换机 time_sync

  5. 观察同步日志,确认主从关系和邻居同步正常

  6. 执行所有交换机 switch_config

  7. 启动所有设备 time_sync

  8. 启动源设备 pkt_gen

  9. 在接收端或日志文件中分析时延/抖动

  10. 结果检查

设备侧文档给了两种分析方式。

如果直接在设备上分析,time_sync 运行过程中会生成:

  • build/packet_log.csv

  • build/critical_log.csv

如果要离线分析,则需要切到设备仓库的 offline_analyze 分支,对接另一台 Linux PC 抓包,再用:

bash 复制代码
python ./analyze_packet.py <capture-file> --step <interval>
相关推荐
s_w.h12 小时前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash
s_w.h2 天前
【 linux 】文件系统
linux·运维·服务器·算法·bash
zh路西法2 天前
【ROS一键编译脚本】基于colcon与catkin的辅助一键懒人脚本
linux·windows·bash
张小姐的猫2 天前
【Linux】多线程实战 —— 日志类 | 策略模式
linux·运维·服务器·c++·bash·策略模式
i7i8i9com2 天前
Hermes Agent 安装记录
开发语言·bash·hermes
IMPYLH3 天前
Linux 的 yes 命令
linux·运维·服务器·数据库·bash
诸神缄默不语3 天前
Linux shell脚本教程
linux·bash·shell·sh
承渊政道4 天前
【MySQL数据库学习】(MySQL库的操作和表的操作)
数据库·学习·mysql·ubuntu·bash·数据库架构·数据库系统
IMPYLH5 天前
Linux 常用命令列表
linux·运维·服务器·bash
承渊政道5 天前
【MySQL数据库学习】(MySQL数据库基础)
数据库·学习·mysql·ubuntu·bash·数据库架构·数据库系统