Skip to content
版 本

asc_sync_block_arrive

产 品 支 持 情 况

产 品是 否 支 持
Atlas A3 训 练 系 列 产 品/Atlas A3 推 理 系 列 产 品
Atlas A2 训 练 系 列 产 品/Atlas A2 推 理 系 列 产 品
Ascend 950PR/Ascend 950DT

功 能 说 明

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);

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