RegisterFormatErrorMessage
函数功能
按照规定的json格式,调用本接口给CANN注册预定义的错误码信息后,再调用ReportPredefinedErrMsg接口上报错误码。
函数原型
int32_t RegisterFormatErrorMessage(const char *error_msg, size_t error_msg_len)
同时为了方便使用,封装了宏REG_FORMAT_ERROR_MSG,用户可直接使用该宏注册,该宏直接定义静态变量注册,进程加载时就会完成注册。
#define REG_FORMAT_ERROR_MSG(error_msg, error_msg_len) \
REG_FORMAT_ERROR_MSG_UNIQ_HELPER((error_msg), (error_msg_len), __COUNTER__)
#define REG_FORMAT_ERROR_MSG_UNIQ_HELPER(error_msg, error_msg_len, counter) \
REG_FORMAT_ERROR_MSG_UNIQ((error_msg), (error_msg_len), counter)
#define REG_FORMAT_ERROR_MSG_UNIQ(error_msg, error_msg_len, counter) \
static const auto register_error_msg_##counter ATTRIBUTE_USED = []() -> int32_t { \
return error_message::RegisterFormatErrorMessage((error_msg), (error_msg_len)); \
}()
参数说明
|
参数名 |
输入/输出 |
说明 |
|---|---|---|
|
error_msg |
输入 |
错误码信息,可一次注册多个错误码。 错误码信息需按json格式组织,示例请参见调用示例。 |
|
error_msg_len |
输入 |
error_msg长度,不包含末尾的'\0'。 |
返回值
- 0:成功。
- -1:失败。
调用示例
error_msg错误码信息需按照json格式组织,error_info_list是一个包含错误信息对象的数组,至少需要包含一个元素,其中各字段含义如下:
- errClass:错误分类。
- errTitle:错误标题。
- ErrCode:错误码。注意不要与当前已有的错误码重复,已有的错误码请参见《故障处理》中的“错误码参考”。
- ErrMessage:错误消息,可以包含格式化占位符(%s)。
- Arglist:参数列表,用于说明ErrMessage中占位符对应的参数,参数列表长度与ErrMessage里格式化占位符个数必须相等。
- suggestion:建议信息,包含:
- Possible Cause:可能的原因。
- Solution:解决方法。
#include <string>
#include "base/err_msg.h"
const std::string error_msg = R"(
{
"error_info_list":
[
{
"errClass": "GE Errors",
"errTitle": "Invalid_Dynamic_Shape_Argument",
"ErrCode": "E10018",
"ErrMessage": "Value [%s] for shape [%s] is invalid. When [--dynamic_batch_size] is included, only batch size N can be -1 in [--input_shape].",
"Arglist": "shape,index",
"suggestion": {
"Possible Cause": "When [--dynamic_batch_size] is included, only batch size N can be -1 in the shape.",
"Solution": "Try again with a valid [--input_shape] argument. Make sure that non-batch size axes are not -1."
}
},
{
"errClass": "GE Errors",
"errTitle": "Invalid_--input_shape_Argument",
"ErrCode": "E10019",
"ErrMessage": "When [--dynamic_image_size] is included, only the height and width axes can be -1 in [--input_shape].",
"Arglist": "",
"suggestion": {
"Possible Cause": "When [--dynamic_image_size] is included, only the height and width axes can be -1 in the shape.",
"Solution": "Try again with a valid [--input_shape] argument. Make sure that axes other than height and width are not -1."
}
}
]
}
)";
REG_FORMAT_ERROR_MSG(error_msg.c_str(), error_msg.size());
父主题: 错误上报接口