CANN/asc-devkit状态获取API

📅 2026/7/5 18:38:04 👁️ 阅读次数 📝 编程学习
CANN/asc-devkit状态获取API

asc_get_status

【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C++标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit

产品支持情况

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

功能说明

头文件路径:"c_api/sys_var/sys_var.h"

获取状态信息。

函数原型

__aicore__ inline int64_t asc_get_status()

参数说明

返回值说明

状态信息。各bit含义如下: | bit范围 | 含义 | | ----------- |:----| | 5 | 浮点运算溢出。SIMD指令int16_t和int32_t算术运算溢出也会上报到该位。 | | 6 | 浮点运算下溢(结果浮点数小于非规格化数能表示的最小值,则结果为0)。 | | 7 | 将任意浮点数转换为无符号整数时,输入为负数。 | | 8 | 从L0C到UB的数据搬运过程中发生溢出(float->half、int32_t->half)。 | | 9 | 从L0C到UB的数据搬运过程中发生下溢(float->half)。 | | 10 | CUBE累加运算溢出(可能是float、half、int32_t)。 | | 11 | CUBE累加运算下溢(可能是float、half)。 | | 13 | 标量指令输入为NaN/INF。 | | 14 | 向量指令输入为NaN/INF。 | | 15 | CUBE指令输入为NaN/INF。 | | 61 | 数据搬运类指令输入为NaN/INF | | 其它bit位 | 保留位。 |

流水类型

PIPE_S

约束说明

调用示例

int64_t status = asc_get_status(); printf("status is %x", status);// 需用%x将其打印成十六进制的数

【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C++标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考