CANN多线程Device管理
1_device_multi_thread【免费下载链接】runtime本项目提供CANN运行时组件和维测功能组件。项目地址: https://gitcode.com/cann/runtime描述本用例展示了多线程的场景如何管理Device主线程中设置Device设置资源限制另一个线程获取Device相关信息例如昇腾AI处理器版本、Device运行模式、Device资源限制后再根据Device资源限制下发和执行和函数任务线程结束时采用aclrtResetDeviceForce接口释放Device上的资源。产品支持情况本样例支持以下产品产品是否支持Atlas A3 训练系列产品/Atlas A3 推理系列产品√Atlas A2 训练系列产品/Atlas A2 推理系列产品√编译运行环境安装详情以及运行详情请见example目录下的README。运行步骤如下# ${install_root} 替换为 CANN 安装根目录默认安装在/usr/local/Ascend目录 source ${install_root}/cann/set_env.sh export ASCEND_INSTALL_PATH${install_root}/cann # ${ascend_name} 替换为昇腾AI处理器的型号可通过 npu-smi info 查看 Name 字段并去掉空格获得例如 ascend910b3 export SOC_VERSION${ascend_name} # 部分样例中涉及调用AscendC算子需配置AscendC编译器ascendc.cmake所在的路径如 ${install_root}/cann/aarch64-linux/tikcpp/ascendc_kernel_cmake # 可在CANN包安装路径下查找ascendc_kernel_cmake例如find ./ -name ascendc_kernel_cmake并将${cmake_path}替换为ascendc_kernel_cmake所在路径 export ASCENDC_CMAKE_DIR${cmake_path} # 编译运行 bash run.shCANN RUNTIME API在该sample中涉及的关键功能点及其关键接口如下所示初始化调用aclInit接口初始化AscendCL配置。调用aclFinalize接口实现AscendCL去初始化。Device管理调用aclrtSetDevice接口指定用于运算的Device。调用aclrtGetSocName接口查询当前运行环境的昇腾AI处理器版本。调用aclrtGetDeviceCount接口获取可用Device的数量。调用aclrtQueryDeviceStatus接口查询Device的状态。调用aclrtGetRunMode接口获取当前AI软件栈的运行模式。调用aclrtGetDeviceUtilizationRate接口查询Device上Cube、Vector、AI CPU等的利用率。调用aclrtDeviceGetStreamPriorityRange接口查询硬件支持的Stream最小、最大优先级。调用aclrtGetDeviceInfo接口获取指定Device的信息。调用aclrtResetDeviceForce接口强制复位当前运算的Device回收Device上的资源。调用aclrtSetDeviceResLimit接口设置当前进程的Device资源限制。调用aclrtGetDeviceResLimit接口获取当前进程的Device资源限制。调用aclrtResetDeviceResLimit接口重置当前进程的Device资源限制恢复默认配置。调用aclrtResetDeviceForce接口强制复位当前运算的Device回收Device上的资源。Stream管理调用aclrtCreateStream接口创建Stream。调用aclrtSynchronizeStream接口阻塞等待Stream上任务的完成。调用aclrtDestroyStream接口销毁Stream。内存管理调用aclrtMalloc接口申请Device上的内存。调用aclrtMallocHost接口申请Host上的内存。调用aclrtFree接口释放Device上的内存。调用aclrtFreeHost接口释放Host上的内存。数据传输调用aclrtMemcpy接口通过内存复制的方式实现数据传输。已知issue暂无【免费下载链接】runtime本项目提供CANN运行时组件和维测功能组件。项目地址: https://gitcode.com/cann/runtime创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2598672.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!