2_multi_stream
描述
本样例展示了多个Stream之间流间任务同步功能。
支持的产品型号
- Atlas A3 训练系列产品/Atlas A3 推理系列产品
- Atlas A2 训练系列产品/Atlas 800I A2 推理产品/A200I A2 Box 异构组件
- Atlas 200I/500 A2 推理产品
- Atlas 推理系列产品
- Atlas 训练系列产品
编译运行
环境安装详情以及运行详情请见example目录下的README。
CANN RUNTIME API
在该Sample中,涉及的关键功能点及其关键接口,如下所示:
- 初始化
- 调用aclInit接口初始化AscendCL配置。
- 调用aclFinalize接口实现AscendCL去初始化。
- Device管理
- 调用aclrtSetDevice接口指定用于运算的Device。
- 调用aclrtResetDeviceForce接口强制复位当前运算的Device,回收Device上的资源。
- Context管理
- 调用aclrtCreateContext接口创建Context。
- 调用aclrtDestroyContext接口销毁Context。
- Stream管理
- 调用aclrtCreateStream接口创建Stream。
- 调用aclrtSynchronizeStream可以阻塞等待Stream上任务的完成。
- 调用aclrtSetStreamFailureMode可以设置Stream执行任务遇到错误的操作,默认为遇错继续,可以设置为遇错即停。
- 调用aclrtDestroyStreamForce接口强制销毁Stream,丢弃所有任务。
- 调用aclrtSynchronizeStreamWithTimeout接口进行超时等待,如果超过指定时间会抛弃任务。
- Event管理
- 调用aclrtCreateEvent接口创建Event。
- 调用aclrtRecordEvent接口记录Event。
- 调用aclrtStreamWaitEvent接口阻塞指定Stream等待Event完成。
- 调用aclrtResetEvent复位Event。
- 调用aclrtSynchronizeEvent接口阻塞等待Event完成。
- 调用aclrtSynchronizeEventWithTimeout接口进行超时等待,如果超过指定时间会抛弃任务。
- notify管理
- 调用aclrtCreateNotify接口创建Notify。
- 调用aclrtRecordNotify接口记录Notify。
- 调用aclrtWaitAndResetNotify接口阻塞等待Notify并重置。
- 调用aclrtDestroyNotify接口销毁Notify。
- 内存管理
- 调用aclrtMalloc接口申请Device上的内存。
- 调用aclrtFree接口释放Device上的内存。
- 数据传输
- 调用aclrtMemcpy接口通过内存复制的方式实现数据传输。
已知issue
暂无