assert
产品支持情况
|
产品 |
是否支持 |
|---|---|
|
|
√ |
|
|
√ |
|
|
√ |
|
|
√ |
|
|
x |
|
|
x |
功能说明
为了避免部分场景下和标准的assert接口产生冲突,assert(expr, __gm__ const char *fmt, Args&&... args)接口将被废弃,并将在后续版本移除。请不要使用该接口,可使用ascendc_assert的对应接口作为替代。
基于算子工程开发的算子,可以使用该接口实现CPU/NPU域assert断言功能。算子执行中,如果assert内部条件判断不为真,则输出assert条件并将输入的信息格式化打印在屏幕上。
1 2 3 |
int assertFlag = 10; assert(assertFlag == 10); |
- 自定义算子工程
- Kernel直调工程
- 修改cmake目录下的npu_lib.cmake文件,在ascendc_compile_definitions命令中增加ASCENDC_DUMP=0宏定义来关闭NPU侧ASCENDC_DUMP开关。示例如下:
1 2 3 4
// 关闭所有算子的打印功能 ascendc_compile_definitions(ascendc_kernels_${RUN_MODE} PRIVATE ASCENDC_DUMP=0 )
- 修改cmake目录下的cpu_lib.cmake文件,在target_compile_definitions命令中增加ASCENDC_DUMP=0宏定义来关闭CPU侧ASCENDC_DUMP开关。示例如下:
1 2 3
target_compile_definitions(ascendc_kernels_${RUN_MODE} PRIVATE ASCENDC_DUMP=0 )
- 修改cmake目录下的npu_lib.cmake文件,在ascendc_compile_definitions命令中增加ASCENDC_DUMP=0宏定义来关闭NPU侧ASCENDC_DUMP开关。示例如下:
1 2 |
DumpHead: AIV-0, CoreType=AIV, block dim=8, total_block_num=8, block_remain_len=696, block_initial_space=1024, rsv=0, magic=5aa5bccd [ASSERT][CANN_VERSION : XXX.XX][TimeStamp : 20240807140556417] /home/.../add_custom.cpp:44: Assertion `assertFlag != 10' |
1 2 |
DumpHead: AIV-0, CoreType=AIV, block dim=8, total_block_num=8, block_remain_len=696, block_initial_space=1024, rsv=0, magic=5aa5bccd [ASSERT]/home/.../add_custom.cpp:44: Assertion `assertFlag != 10' |
函数原型
1 2 |
assert(expr) assert(expr, __gm__ const char *fmt, Args&&... args) // 该接口已废弃,请使用ascendc_assert作为替代 |
参数说明
|
参数名 |
输入/输出 |
描述 |
|---|---|---|
|
expr |
输入 |
assert断言是否终止程序的条件。为true则程序继续执行,为false则终止程序。 |
|
fmt |
输入 |
格式控制字符串,包含两种类型的对象:普通字符和转换说明。
注意:
|
|
args |
输入 |
附加参数,个数和类型可变的参数列表:根据不同的fmt字符串,函数可能需要一系列的附加参数,每个参数包含了一个要被插入的值,替换了fmt参数中指定的每个%标签。参数的个数应与%标签的个数相同。 |
返回值说明
无
约束说明
- 该功能仅在如下场景支持:
- 间接调用单算子API(aclnnxxx)接口:Pytorch框架单算子直调的场景。
- Kernel开发不要包含系统的assert.h,会导致宏定义冲突。
- 该接口调用形式与C语言一致,不需要使用AscendC命名空间。
- 该接口不支持打印除换行符之外的其他转义字符。
- 该接口不支持simulator仿真模式。
- 该接口使用Dump功能,所有使用Dump功能的接口在每个核上Dump的数据总量不可超过1M。请开发者自行控制待打印的内容数据量,超出则不会打印。
- 该接口使用空间每个核上不可超过1k。请开发者自行控制待打印的内容数据量,超出则不会打印。
调用示例
1 2 3 |
int assertFlag = 10; // 断言条件 assert(assertFlag != 10); |
程序运行时会触发assert,打印效果如下:
1
|
[ASSERT] /home/.../add_custom.cpp:44: Assertion `assertFlag != 10' |