asc_sync_inter_wait
产 品 支 持 情 况
| 产 品 | 是 否 支 持 |
|---|---|
| √ | |
| √ | |
| √ |
功 能 说 明
核 间 同 步 寄 存 器 同 步 指 令,每 个flag_id均 分 配 有 计 数 器,执 行asc_sync_inter_arrive后 计 数 器 将 递 增;执 行asc_sync_inter_wait时 如 果 对 应 的 计 数 器 数 值 为0则 阻 塞;如 果 对 应 的 计 数 器 大 于0,则 计 数 器 减 一,同 时 后 续 指 令 开 始 执 行。
函 数 原 型
Text
```cpp
__aicore__ inline void asc_sync_inter_wait(pipe_t pipe, uint8_t flag_id)
__aicore__ inline void asc_sync_inter_wait(pipe_t pipe, int64_t flag_id)
```
参 数 说 明
| 参 数 名 | 输 入/输 出 | 描 述 |
|---|---|---|
| pipe | 输 入 | 需 要 执 行 同 步 指 令 的 流 水 类 型。 |
| flag_id | 输 入 | 事 件 标 号,取 值 范 围[0,15]。 |
返 回 值 说 明
无
流 水 类 型
PIPE_S
约 束 说 明
- flag_id的 取 值 范 围 为0至15,每 个flag_id的 计 数 器 范 围 为0至15。
- 必 须 保 证 每 个flag_id的 计 数 器 不 溢 出,否 则 将 引 发 异 常。
- 必 须 保 证 相 同 的ID在 同 一 时 间 仅 被 一 条 流 水 线 等 待。
调 用 示 例
C++
int64_t flag_id = 1;
asc_sync_inter_arrive(PIPE_S, flag_id);
asc_sync_inter_wait(PIPE_S, flag_id);