FetchEventID
功能说明
根据HardEvent(硬件类型的同步事件)获取相应可用的TEventID,此接口不会申请TEventID,仅提供可用的TEventID。
函数原型
1 2 3 | template <HardEvent evt> __aicore__ inline TEventID TPipe::FetchEventID() __aicore__ inline TEventID TPipe::FetchEventID(HardEvent evt) |
参数说明
参数名称 |
输入/输出 |
含义 |
---|---|---|
evt |
输入 |
HardEvent类型,硬件同步类型。 该类型的具体说明请参考SetFlag/WaitFlag(ISASI)中同步类型的说明。 |
支持的型号
注意事项
相比于AllocEventID,FetchEventID适用于临时使用ID的场景,获取ID后,不会对ID进行占用。在一些复杂的使用场景下,需要开发者自行保证使用正确。比如相同流水连续调用SetFlag/WaitFlag,如果两次传入的ID都是使用FetchEventID获取的,因为两者ID相同会出现程序卡死等未定义行为,这时推荐用户使用AllocEventID。
返回值
TEventID
调用示例
1 2 3 | AscendC::TEventID eventIdVToS = GetTPipePtr()->FetchEventID(AscendC::HardEvent::V_S); //需要插scalar等vector的同步,申请对应的HardEvent的ID AscendC::SetFlag<AscendC::HardEvent::V_S>(eventIdVToS); AscendC::WaitFlag<AscendC::HardEvent::V_S>(eventIdVToS); |
父主题: TPipe