printf
函数功能
基于算子工程开发的算子,可以使用该接口实现NPU域上板调试场景下的格式化输出功能。算子执行结束之后,待输出内容会被解析并打印在屏幕上。
在算子kernel侧实现代码中需要输出日志信息的地方调用printf接口打印相关内容。样例如下:
#include "kernel_operator.h" using namespace AscendC; // 调用前需要引用AscendC命名空间 // NPU域支持如下调用方式 printf("fmt string %d\n", 0x123); PRINTF("fmt string %d\n", 0x123); AscendC::printf("fmt string %d\n", 0x123); AscendC::PRINTF("fmt string %d\n", 0x123);

printf(PRINTF)接口打印功能会对算子实际运行的性能带来一定影响,通常在调测阶段使用。开发者可以按需通过如下方式关闭打印功能。
- 自定义算子工程
- Kernel直调工程
函数原型
void printf(__gm__ const char* fmt, Args&&... args);
void PRINTF(__gm__ const char* fmt, Args&&... args);
参数说明
参数名 |
输入/输出 |
描述 |
---|---|---|
fmt |
输入 |
格式控制字符串,包含两种类型的对象:普通字符和转换说明。
|
args |
输入 |
附加参数,个数和类型可变的输出列表:根据不同的fmt字符串,函数可能需要一系列的附加参数,每个参数包含了一个要被插入的值,替换了fmt参数中指定的每个%标签。参数的个数应与%标签的个数相同。 |
返回值
无
支持的型号
Atlas A2训练系列产品
Atlas推理系列产品AI Core
注意事项
- 该功能仅在如下场景支持:
- 基于Kernel Launch算子工程,通过基础调用(Kernel Launch)方式调用算子。
- 通过单算子API执行的方式开发单算子调用应用。
- 间接调用单算子API(aclnnxxx)接口:Pytorch框架单算子直调的场景。
- 本接口不支持打印除换行符之外的其他转义字符。
- 程序中调用printf/PRINTF接口使用的空间+调用DumpTensor接口使用的空间+DumpAccChkPoint接口使用的空间+assert接口使用的空间+框架dump功能所使用的空间,每个核上不可超过1M。请开发者自行控制待打印的内容数据量,超出则不会打印。
- 在NPU域调用接口时,不要包含C标准库头文件stdio.h和cstdio,防止printf和系统符号冲突。
调用示例
#include "kernel_operator.h" using namespace AscendC; // 调用前需要引用AscendC命名空间 // 整型打印: printf("fmt string %d\n", 0x123); PRINTF("fmt string %d\n", 0x123); // 指针打印: int *a; printf("TEST %p\n", a); PRINTF("TEST %p\n", a); 程序运行时打印效果如下: fmt string 291 fmt string 291 TEST 0x12c08001a000 TEST 0x12c08001a000
父主题: 调测接口