asc_sync_intra_wait
产 品 支 持 情 况
| 产 品 | 是 否 支 持 |
|---|---|
| √ |
功 能 说 明
block内 同 步 指 令,与asc_sync_intra_arrive配 合 使 用,是block内 不 同Core的 流 水 线 同 步 指 令,用 于 向 每 个Core的 同 步 寄 存 器 发 送 同 步 信 号。每 个sync_id对 应VECCORE与CUBECORE中 的 一 个 初 始 值 为0的 计 数 器。asc_sync_intra_arrive指 令 后 其 他CORE对 应 的 计 数 器 增 加1;执 行asc_sync_intra_wait时 如 果 对 应 的 计 数 器 数 值 为0则 阻 塞 不 执 行;如 果 对 应 的 计 数 器 大 于0,则 计 数 器 减 一,同 时 后 续 指 令 开 始 执 行。
函 数 原 型
Text
```cpp
__aicore__ inline void asc_sync_intra_wait(pipe_t pipe, uint8_t sync_id)
__aicore__ inline void asc_sync_intra_wait(pipe_t pipe, uint64_t sync_id)
```
参 数 说 明
| 参 数 名 | 输 入/输 出 | 描 述 |
|---|---|---|
| pipe | 输 入 | 该 指 令 的 执 行 流 水 线。 |
| sync_id | 输 入 | 事 件 标 号。 |
返 回 值 说 明
无
流 水 类 型
PIPE_S
约 束 说 明
- 需 要 保 证 每 一 个ID的4位 计 数 器 不 会 溢 出,否 则 会 出 现 异 常。
- 需 要 保 证 相 同 的ID只 会 被 一 个 流 水 线 控 制。
- 每 个ID对 应 一 个4位 计 数 器,特 定CORE的 同 步ID计 数 器 可 通 过 其 他CORE发 起 的asc_sync_intra_arrive递 增;也 可 通 过 本 身 发 起 的asc_sync_intra_wait递 减。
- 三 个CORE的ID映 射 规 则 如 下:
- ID为0
15的VECCORE0的asc_sync_intra_arrive指 令 会 被 映 射 到CUBECORE的015的ID。 - ID为0
15的VECCORE1的asc_sync_intra_arrive指 令 会 被 映 射 到CUBECORE的1631的ID。 - ID为0
15的CUBECORE的asc_sync_intra_arrive指 令 会 被 映 射 到VECCORE0的015的ID。 - ID为16
31的CUBECORE的asc_sync_intra_arrive指 令 会 被 映 射 到VECCORE1的015的ID。
- ID为0
调 用 示 例
C++
//设 置 同 步 指 令 事 件 标 号 为1
uint64_t sync_id = 1;
asc_sync_intra_arrive(PIPE_S, sync_id);
asc_sync_intra_wait(PIPE_S, sync_id);