跳到主要内容

主站对象字典 (Master OD)

符合 ETG.1510 标准的主站对象字典,提供主站身份信息、从站配置/状态/诊断数据,供外部诊断工具和 HMI 通过标准 SDO 接口访问。

通过 master.master_od() 访问。

ETG.1510 标准

主站对象字典按照 ETG.1510 规范实现,使用标准 CoE 索引约定。与从站 CoE 对象字典不同,这里是主站自身暴露的诊断对象。配合邮箱网关使用,可实现远程诊断工具对主站的标准访问。

对象索引总览

索引名称子索引数读写说明
0x1000Device Type0只读0x00001389 (EtherCAT Master)
0x1008Device Name0只读"Darra EtherCAT Master"
0x1009Hardware Version0只读x64
0x100ASoftware Version0只读SDK 版本号
0x1018Identity Object4只读主站身份信息(见下方子索引表)
0x8nnnConfiguration Data40只读第 n 个从站的配置数据
0x9nnnInformation Data32只读第 n 个从站的检测信息
0xAnnnDiagnosis Data19部分可写第 n 个从站的诊断数据
0xF002Detect Modules3只读从站扫描状态
0xF120Master Diag Data16只读主站诊断数据
0xF200Diag Interface Control16可写诊断接口控制
备注

nnn = 从站编号 (1-based),索引根据 master.slave_count() 动态生成。例如 3 个从站时,0x8001 ~ 0x80030x9001 ~ 0x90030xA001 ~ 0xA003 均可访问。

0x1018 — 主站身份 (Identity Object)

子索引名称类型说明
0Number of Entriesu84固定
1Vendor IDu320x00001164ETG 分配,固定值
2Product Codeu320x00000001固定值
3Revision Numberu32自动自动从 DLL 版本派生
4Serial Numberu32自动自增每个实例自动分配 0, 1, 2...

0x8nnn — 从站配置数据

每个从站对应一个 0x8nnn 对象,包含 ENI 中配置的静态信息。

子索引名称类型说明
0Number of Entriesu8固定 40
1Fixed Station Addressu16配置地址 (ConfigAddr)
2TypeString设备类型字符串
3NameString设备名称
4Device Typeu32设备类型编码
5Vendor IDu32厂商 ID
6Product Codeu32产品代码
7Revision Numberu32修订号
8Serial Numberu32序列号
33Mailbox Out Sizeu16SM0 邮箱输出大小
34Mailbox In Sizeu16SM1 邮箱输入大小
35Link Statusu8端口链路状态
36Link Presetu8端口链路预设
37Flagsu8从站标志
38Port Physicsu16端口物理类型
39Mailbox Protocolsu16支持的邮箱协议
40Diag History Supportedu8是否支持 0x10F3 诊断历史

0x9nnn — 从站检测信息

每个从站对应一个 0x9nnn 对象,包含运行时检测到的实际信息。

子索引名称类型说明
0Number of Entriesu8固定 32
1Station Addressu16实际配置地址
5Vendor IDu32检测到的厂商 ID
6Product Codeu32检测到的产品代码
7Revision Numberu32检测到的修订号
8Serial Numberu32检测到的序列号
32DL Statusu16DL Status 寄存器 (ESC 0x0110)

0xAnnn — 从站诊断数据

每个从站对应一个 0xAnnn 对象,包含实时诊断数据。每次读取时自动更新。

子索引名称类型读写说明
0Number of Entriesu8只读固定 19
1AL Statusu16只读当前 AL 状态
2AL Controlu16可写写入时同步到从站
3Last AL Status Codeu16只读最近一次 AL 错误码
4Link Conn. Statusu8只读端口链路连接状态
5Link Controlu8只读链路控制
6-9Fixed Addr Conn. Port 0-3u16只读各端口连接的从站配置地址
10-13Frame Error Port 0-3u32只读各端口帧错误计数
14Cyclic WC Error Counteru32只读周期性工作计数器错误
15Slave Not Present Counteru32只读从站不在线计数
16Abnormal State Change Counteru32只读异常状态变化计数
17Disable Auto Link Controlu8只读自动链路控制禁用标志
18Last CoE/SoE Protocol Erroru32只读最近一次协议错误码
19New Diag Messagesu8只读是否有新诊断消息

0xF120 — 主站诊断数据

子索引名称类型说明
0Number of Entriesu8固定 16
1Cyclic Lost Framesu32周期性丢帧率 (百分比 x 100)
2Acyclic Lost Framesu32非周期性丢帧率
3Cyclic Frames/Secondu32每秒周期帧数
4Acyclic Frames/Secondu32每秒非周期帧数
16Master Stateu16主站当前 EtherCAT 状态

0xF200 — 诊断接口控制

子索引名称类型读写说明
0Number of Entriesu8只读固定 16
16Reset Diag Infou8可写写入 1 复位所有诊断计数器

方法

vendor_id() / product_code() / revision_number() / serial_number()

pub fn vendor_id(&self) -> u32
pub fn product_code(&self) -> u32
pub fn revision_number(&self) -> u32
pub fn serial_number(&self) -> u32

主站身份信息便捷访问 (对应 0x1018:01..04).

read_object()

pub fn read_object(&self, index: u16, subindex: u8) -> Option<Vec<u8>>

读取主站对象字典中指定索引的数据。

参数:

  • index — 对象索引(如 0x10180x80010xA001
  • subindex — 子索引

返回值:

  • Option<Vec<u8>> — 读取的原始数据,未知对象返回 None

write_object()

pub fn write_object(&self, index: u16, subindex: u8, data: &[u8]) -> bool

写入主站对象字典。仅部分对象支持写入(见上方各对象表格的读写列)。

参数:

  • index — 对象索引
  • subindex — 子索引
  • data — 要写入的数据

返回值:

  • bool — 写入成功返回 true

object_name()

pub fn object_name(&self, index: u16) -> &str

获取对象的名称。未知索引返回 "Unknown"

subindex_count()

pub fn subindex_count(&self, index: u16) -> u8

获取对象的子索引数量。

supported_object_indices()

pub fn supported_object_indices(&self) -> Vec<u16>

获取当前支持的所有对象索引列表(固定索引 + 按从站数量动态生成的 0x8nnn/0x9nnn/0xAnnn)。

完整示例

let od = master.master_od();

// 遍历所有从站的诊断数据
for i in 1..=master.slave_count() {
let cfg_idx = 0x8000 | i;
let diag_idx = 0xA000 | i;

// 读取从站名称
let name = od.read_object(cfg_idx, 3)
.map(|d| String::from_utf8_lossy(&d).to_string())
.unwrap_or_else(|| "N/A".to_string());

// 读取 AL Status 和错误码
let al_status = od.read_object(diag_idx, 1)
.map(|d| u16::from_le_bytes([d[0], d[1]]))
.unwrap_or(0);

let al_code = od.read_object(diag_idx, 3)
.map(|d| u16::from_le_bytes([d[0], d[1]]))
.unwrap_or(0);

// 读取各端口帧错误计数
let mut port_errors = [0u32; 4];
for p in 0..4u8 {
if let Some(err) = od.read_object(diag_idx, 10 + p) {
if err.len() >= 4 {
port_errors[p as usize] = u32::from_le_bytes([err[0], err[1], err[2], err[3]]);
}
}
}

println!("从站{} [{}]: AL=0x{:04X}, Code=0x{:04X}, Errors={:?}",
i, name, al_status, al_code, port_errors);
}

// 复位所有诊断
od.write_object(0xF200, 16, &[1]);

命名映射 (与其它语言 SDK)

Rust SDK 没有完全对齐 C# / Java 的某些方法名, 而是按 Rust 风格统一:

其它语言Rust 等价
get_object_dictionary_indices()supported_object_indices()
get_object_description(index)object_name(index) + subindex_count(index)
get_entry_description(index, sub)暂未单独暴露 — 通过 CoEInstance::read_diagnostic_metaOdList::find 间接获取
sdo_read_ex / sdo_write_ex暂未提供 — 通过 CoEInstance::sdo_read / sdo_write (默认无 ex 扩展选项); 启用 complete_access 即等价
read_multiple_async暂未提供 native 异步聚合 — Rust 风格用 CoEInstance::read_multiple 同步 + tokio::task::spawn_blocking 包装异步; 或用 CoEInstance::sdo_read_blocking 数组 + JoinHandle::join() 自行并发

如需上述 API, 可 fork 仓库自行加 thin wrapper, 或在 CoEInstance 上手动组合现有方法。