Commit
产品支持情况
功能说明
非细粒度通信时,每调用一次本接口,则通知服务端可以执行handleId对应的任务一次。细粒度通信时,每调用一次本接口,则通知服务端可以执行handleId对应的步长长度的子通信任务。
函数原型
__aicore__ inline void Commit(HcclHandle handleId)
参数说明
表 1 接口参数说明
对应通信任务的标识ID,只能使用Prepare原语接口的返回值。 using HcclHandle = int8_t; |
返回值说明
无
约束说明
- 调用本接口前确保已调用过InitV2和SetCcTilingV2接口。
- 入参handleId只能使用Prepare原语对应接口的返回值。
- 非细粒度通信时,本接口的调用次数应该与Prepare的repeat次数一致。细粒度通信时,本接口的调用次数应该与通信任务的总步骤数/步长*Prepare的repeat次数一致。
- 本接口在AIC核或者AIV核上调用必须与对应的Prepare接口的调用核保持一致。
调用示例
REGISTER_TILING_DEFAULT(ReduceScatterCustomTilingData); //ReduceScatterCustomTilingData为对应算子头文件定义的结构体
GET_TILING_DATA_WITH_STRUCT(ReduceScatterCustomTilingData, tilingData, tilingGM);
Hccl hccl;
GM_ADDR contextGM = AscendC::GetHcclContext<0>(); // AscendC自定义算子kernel中,通过此方式获取HCCL context
hccl.InitV2(contextGM, &tilingData);
auto ret = hccl.SetCcTilingV2(offsetof(ReduceScatterCustomTilingData, mc2CcTiling));
if (ret != HCCL_SUCCESS) {
return;
}
if (AscendC::g_coreType == AIC) {
HcclHandle handleId = hccl.ReduceScatter(sendBuf, recvBuf, 100, HcclDataType::HCCL_DATA_TYPE_INT8, HcclReduceOp::HCCL_REDUCE_SUM, 10);
for (uint8_t i=0; i<10; i++) {
hccl.Commit(handleId ); // 通知服务端可以执行上述的ReduceScatter任务
}
for (uint8_t i=0; i<10; i++) {
hccl.Wait(handleId); // 阻塞接口,需等待上述ReduceScatter任务执行完毕
}
hccl.Finalize(); // 后续无其他通信任务,通知服务端执行上述ReduceScatter任务之后即可以退出
}