asc_sync_block_arrive
产 品 支 持 情 况
| 产 品 | 是 否 支 持 |
|---|---|
| √ | |
| √ | |
| √ |
功 能 说 明
和asc_sync_block_wait配 合 使 用(通 过flag_id关 联),用 于 向 核 间 同 步 寄 存 器 发 送 同 步 信 号,标 识 当 前pipeline已 到 达flag_id对 应 的 同 步 点。每 个flag_id对 应 一 个 初 始 值 为0的 计 数 器,执 行asc_sync_block_arrive后flag_id对 应 的 计 数 器 增 加1;执 行asc_sync_block_wait时 如 果 对 应 的 计 数 器 数 值 为0则 阻 塞 不 执 行;如 果 对 应 的 计 数 器 大 于0,则 计 数 器 减 一,同 时 后 续 指 令 开 始 执 行。
函 数 原 型
Text
```cpp
aicore inline void asc_sync_block_arrive(pipe_t pipe, int64_t flag_id) ```
参 数 说 明
| 参 数 名 | 输 入/输 出 | 描 述 |
|---|---|---|
| pipe | 输 入 | 设 置 这 条 指 令 所 在 的 流 水 类 型。 |
| flag_id | 输 入 | 事 件 标 号,用 于 标 识 同 一 组 同 步 信 号。取 值 范 围 为[0,15]。 |
返 回 值 说 明
无
流 水 类 型
PIPE_S
约 束 说 明
- 使 用 该 同 步 接 口 时,需 要 按 照 如 下 规 则 设 置Kernel类 型:
- 在 纯Vector/Cube场 景 下,需 设 置Kernel类 型 为KERNEL_TYPE_MIX_AIV_1_0或KERNEL_TYPE_MIX_AIC_1_0。
- 对 于Vector和Cube混 合 场 景,需 根 据 实 际 情 况 灵 活 配 置Kernel类 型。
- 不 建 议 开 发 者 同 时 使 用 该 接 口 和Matmul高 阶API,否 则 会 有flag_id冲 突 的 风 险。
- 同 一flag_id的 计 数 器 最 多 设 置15次。
调 用 示 例
C++
// Host侧 调 用 接 口aclrtGetHardwareSyncAddr获 取 核 间 同 步 基 地 址ffts_addr
uint64_t config = *(__gm__ uint64_t*)ffts_addr;
asc_set_ffts_base_addr(config);
int64_t flag_id = 1;
asc_sync_block_arrive(PIPE_S, flag_id);
asc_sync_block_wait(PIPE_S, flag_id);
C++
// 在 Ascend 950PR/Ascend 950DT 产 品 上,无 需 进 行 核 间 同 步 基 地 址ffts_addr的 设 置
int64_t flag_id = 1;
asc_sync_block_arrive(PIPE_S, flag_id);
asc_sync_block_wait(PIPE_S, flag_id);