Skip to content
版 本

asc_sync_intra_wait

产 品 支 持 情 况

产 品是 否 支 持
Ascend 950PR/Ascend 950DT

功 能 说 明

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为015的VECCORE0的asc_sync_intra_arrive指 令 会 被 映 射 到CUBECORE的015的ID。
    • ID为015的VECCORE1的asc_sync_intra_arrive指 令 会 被 映 射 到CUBECORE的1631的ID。
    • ID为015的CUBECORE的asc_sync_intra_arrive指 令 会 被 映 射 到VECCORE0的015的ID。
    • ID为1631的CUBECORE的asc_sync_intra_arrive指 令 会 被 映 射 到VECCORE1的015的ID。

调 用 示 例

C++
//设 置 同 步 指 令 事 件 标 号 为1
uint64_t sync_id = 1;
asc_sync_intra_arrive(PIPE_S, sync_id);
asc_sync_intra_wait(PIPE_S, sync_id);

免 责 声 明:本 站 内 容 由 asc-devkit 仓 master 分 支 自 动 编 译 生 成,属 于 持 续 开 发 版 本,可 能 存 在 缺 陷,仅 供 预 览 与 参 考。如 需 稳 定 及 商 用 资 料,请 查 阅 官 方 昇 腾 社 区