* Copyright (c) 2025 Huawei Technologies Co., Ltd.
* This program is free software, you can redistribute it and/or modify it under the terms and conditions of
* CANN Open Software License Agreement Version 2.0 (the "License").
* Please refer to the License for details. You may not use this file except in compliance with the License.
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED,
* INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
* See LICENSE in the root of the software repository for the full text of the License.
*/
* \file mc2_log.h
* \brief
*/
#ifndef MC2_LOG_H
#define MC2_LOG_H
#include <stdarg.h>
#include <stdio.h>
#include <sstream>
#include <string>
#include <vector>
#include "base/err_msg.h"
#include "log/log.h"
#include "securec.h"
#include "op_kernel/mc2_tiling_struct.h"
#include "tiling/tiling_api.h"
#if __has_include("error_manager/error_manager.h")
#include "error_manager/error_manager.h"
#else
#include "err_mgr.h"
#endif
#include "quant_batch_matmul_v3/op_kernel/arch35/quant_batch_matmul_v3_tiling_data.h"
#include "mat_mul_v3/op_kernel/arch35/mat_mul_tiling_data.h"
template <typename T>
std::string ConcatString(const T &arg) {
std::ostringstream oss;
oss << arg;
return oss.str();
}
template <typename T, typename... Ts>
std::string ConcatString(T arg, Ts... arg_left) {
std::ostringstream oss;
oss << arg;
oss << ConcatString(arg_left...);
return oss.str();
}
namespace Mc2Log {
void PrintMMV3TilingData(const std::string &opName, Mc2Tiling::MC2MatmulV3TilingData &tiling);
void PrintRCSTilingData(const std::string &opName, Mc2Tiling::RCSTiling& rcsTiling);
void PrintTileL2TilingData(const std::string &opName, Mc2Tiling::TileL2Tiling& tileL2Tiling);
void PrintMc2MsgData(const std::string &opName, Mc2Tiling::Mc2Msg& msg);
void PrintTCubeTilingData(const std::string &opName, ::TCubeTiling &tiling);
void PrintTCubeTilingWindowParam(const std::string &opName, DequantBmm::Mc2SlidingWindowParams &tiling);
void PrintTCubeTilingL2cache(const std::string &opName, DequantBmm::Mc2L2cacheTileParams &tiling);
void PrintTCubeTilingParams(const std::string &opName, DequantBmm::Mc2QuantBatchMatmulV3DataParams &tiling);
void PrintMMV3TilingData(const std::string &opName, Mc2MatMulV3TilingData &tiling);
}
struct ErrorResult {
operator bool() const { return false; }
operator ge::graphStatus() const { return ge::GRAPH_PARAM_INVALID; }
template <typename T>
operator std::unique_ptr<T>() const {
return nullptr;
}
template <typename T>
operator std::shared_ptr<T>() const {
return nullptr;
}
template <typename T>
operator T *() const {
return nullptr;
}
template <typename T>
operator std::vector<std::shared_ptr<T>>() const {
return {};
}
template <typename T>
operator std::vector<T>() const {
return {};
}
operator std::string() const { return ""; }
template <typename T>
operator T() const {
return T();
}
};
inline std::vector<char> CreateErrorMsg(const char *format, ...)
__attribute__((format(printf, 1, 2)));
inline std::vector<char> CreateErrorMsg();
inline std::vector<char> CreateErrorMsg(const char *format, ...){
va_list args;
va_start(args, format);
va_list args_copy;
va_copy(args_copy, args);
const size_t len = 4095;
va_end(args_copy);
std::vector<char> msg(len + 1U, '\0');
const auto ret = vsnprintf_s(msg.data(), len + 1U, len, format, args);
va_end(args);
return (ret > 0) ? msg : std::vector<char>{};
}
inline std::vector<char> CreateErrorMsg() { return {}; }
inline const char *ConvertStringToCstr(const std::string &str) { return str.c_str(); }
#if !defined(__ANDROID__) && !defined(ANDROID)
#define OPS_ERR_IF(COND, LOG_FUNC, EXPR) \
if (__builtin_expect(COND, 0)) { \
LOG_FUNC; \
EXPR; \
}
#define OPS_CHECK(COND, LOG_FUNC, EXPR) \
if (COND) { \
LOG_FUNC; \
EXPR; \
}
#define OPS_LOG_FULL(LEVEL, OPS_DESC, ...)
#define OPS_LOG_E(opName, ...) \
D_OP_LOGE(Ops::Base::GetOpInfo(opName), __VA_ARGS__)
#define OPS_LOG_W(opName, ...) \
D_OP_LOGW(Ops::Base::GetOpInfo(opName), __VA_ARGS__)
#define OPS_LOG_I(opName, ...) \
D_OP_LOGI(Ops::Base::GetOpInfo(opName), __VA_ARGS__)
#define OPS_LOG_D(opName, ...) \
D_OP_LOGD(Ops::Base::GetOpInfo(opName), __VA_ARGS__)
#define OP_LOGE_IF(condition, returnValue, opName, fmt, ...) \
static_assert(std::is_same<bool, std::decay<decltype(condition)>::type>::value, "condition should be bool"); \
do { \
if (unlikely(condition)) { \
OP_LOGE(Ops::Base::GetOpInfo(opName), fmt, ##__VA_ARGS__); \
return returnValue; \
} \
} while (0)
#define CUBE_INNER_ERR_REPORT(op_name, err_msg, ...) \
do { \
D_OP_LOGE(op_name, err_msg, ##__VA_ARGS__); \
REPORT_INNER_ERR_MSG("E69999", "op[%s], " err_msg, \
ConvertStringToCstr(Ops::Base::GetOpInfo(op_name)), \
##__VA_ARGS__); \
} while (0)
#define OP_LOGI_IF_RETURN(condition, returnValue, opName, fmt, ...) \
static_assert(std::is_same<bool, std::decay<decltype(condition)>::type>::value, "condition should be bool"); \
do { \
if (unlikely(condition)) { \
OP_LOGI(Ops::Base::GetOpInfo(opName), fmt, ##__VA_ARGS__); \
return returnValue; \
} \
} while (0)
#define GE_ASSERT(exp, ...) \
do { \
if (!(exp)) { \
auto msg = CreateErrorMsg(__VA_ARGS__); \
if (msg.empty()) { \
REPORT_INNER_ERR_MSG("E19999", "Assert %s failed", #exp); \
return ge::FAILED; \
} else { \
REPORT_INNER_ERR_MSG("E19999", "%s", msg.data()); \
return ge::FAILED; \
} \
return ::ErrorResult(); \
} \
} while (false)
#define CUBE_CALL_ERR_REPORT(op_name, err_msg, ...)
namespace ops {
#define OPS_CHECK_NULL_WITH_CONTEXT(context, ptr) \
if ((ptr) == nullptr) { \
const char *name = ((context)->GetNodeName() == nullptr) \
? "nil" \
: (context)->GetNodeName(); \
OP_LOGE_WITHOUT_REPORT(name, "%s is nullptr!", #ptr); \
REPORT_INNER_ERR_MSG("EZ9999", "op[%s], %s is nullptr!", name, #ptr); \
return ge::GRAPH_FAILED; \
}
#define OPS_CHECK_NULL_WITH_CONTEXT_RET(context, ptr, ret) \
if ((ptr) == nullptr) { \
const char *name = ((context)->GetNodeName() == nullptr) \
? "nil" \
: (context)->GetNodeName(); \
OP_LOGE_WITHOUT_REPORT(name, "%s is nullptr!", #ptr); \
REPORT_INNER_ERR_MSG("EZ9999", "op[%s], %s is nullptr!", name, #ptr); \
return ret; \
}
}
#define GE_ASSERT_SUCCESS(v, ...) GE_ASSERT(((v) == ge::SUCCESS), __VA_ARGS__)
#define GE_ASSERT_NOTNULL(v, ...) GE_ASSERT(((v) != nullptr), __VA_ARGS__)
#define GE_ASSERT_GRAPH_SUCCESS(v, ...) GE_ASSERT(((v) == 0), __VA_ARGS__)
#define GE_ASSERT_TRUE(v, ...) GE_ASSERT((v), __VA_ARGS__)
#define GE_ASSERT_EQ(x, y) \
do { \
const auto &xv = (x); \
const auto &yv = (y); \
if (xv != yv) { \
std::stringstream ss; \
ss << "Assert (" << #x << " == " << #y << \
")failed, expect " << yv << " actual " << xv; \
REPORT_INNER_ERR_MSG("E19999", "%s", ss.str().c_str()); \
return ::ErrorResult(); \
} \
} while (0)
#define VECTOR_INFER_SHAPE_INNER_ERR_REPORT(op_name, err_msg) \
do { \
OP_LOGE_WITHOUT_REPORT(op_name, "%s", ConvertStringToCstr(err_msg)); \
std::string errorStr = "E89999"; \
REPORT_INNER_ERR_MSG(errorStr.c_str(), "%s", \
ConcatString("op[", op_name, "],", err_msg).c_str()); \
} while (0)
#define OPS_REPORT_VECTOR_INNER_ERR(opName, ...) OPS_LOG_E(opName, ##__VA_ARGS__)
#define OPS_REPORT_CUBE_INNER_ERR(opName, ...) OPS_LOG_E(opName, ##__VA_ARGS__)
namespace optiling {
#define VECTOR_INNER_ERR_REPORT_TILING(op_name, err_msg, ...) \
do { \
OP_LOGE_WITHOUT_REPORT(op_name, err_msg, ##__VA_ARGS__); \
REPORT_INNER_ERR_MSG("E89999", "op[%s], " err_msg, \
ConvertStringToCstr(Ops::Base::GetOpInfo(op_name)), \
##__VA_ARGS__); \
} while (0)
#define OP_TILING_CHECK(cond, log_func, expr) \
do { \
if (cond) { \
log_func; \
expr; \
} \
} while (0)
}
#else
#define OPS_ERR_IF(COND, LOG_FUNC, EXPR)
#define OPS_CHECK(COND, LOG_FUNC, EXPR)
#define OPS_LOG_FULL(LEVEL, OPS_DESC, ...)
#define OPS_LOG_E(opName, ...)
#define OPS_LOG_W(opName, ...)
#define OPS_LOG_I(opName, ...)
#define OPS_LOG_D(opName, ...)
#define CUBE_INNER_ERR_REPORT(op_name, err_msg, ...)
#define VECTOR_INFER_SHAPE_INNER_ERR_REPORT(opName, err_msg)
#define GE_ASSERT_SUCCESS(v, ...)
#define GE_ASSERT_NOTNULL(v, ...)
#define OPS_REPORT_VECTOR_INNER_ERR(opName, ...)
#define OPS_REPORT_CUBE_INNER_ERR(opName, ...)
#define CUBE_CALL_ERR_REPORT(op_name, err_msg, ...)
namespace optiling {
#define VECTOR_INNER_ERR_REPORT_TILING(opName, err_msg, ...)
#define OP_TILING_CHECK(cond, log_func, expr)
}
#endif
#endif