1a34a8711Sopenharmony_ci/* 2a34a8711Sopenharmony_ci * Copyright (C) 2021 Huawei Device Co., Ltd. 3a34a8711Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4a34a8711Sopenharmony_ci * you may not use this file except in compliance with the License. 5a34a8711Sopenharmony_ci * You may obtain a copy of the License at 6a34a8711Sopenharmony_ci * 7a34a8711Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8a34a8711Sopenharmony_ci * 9a34a8711Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10a34a8711Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11a34a8711Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12a34a8711Sopenharmony_ci * See the License for the specific language governing permissions and 13a34a8711Sopenharmony_ci * limitations under the License. 14a34a8711Sopenharmony_ci */ 15a34a8711Sopenharmony_ci 16a34a8711Sopenharmony_ci#ifndef OHOS_IPC_RPC_LOG_H 17a34a8711Sopenharmony_ci#define OHOS_IPC_RPC_LOG_H 18a34a8711Sopenharmony_ci 19a34a8711Sopenharmony_ci#include <stdio.h> 20a34a8711Sopenharmony_ci#include <stdbool.h> 21a34a8711Sopenharmony_ci 22a34a8711Sopenharmony_ci#ifndef IPCRPC_DEBUG 23a34a8711Sopenharmony_ci#if defined(__LITEOS_M__) 24a34a8711Sopenharmony_ci#define IPCRPC_PRINTF 25a34a8711Sopenharmony_ci#include "log.h" 26a34a8711Sopenharmony_ci#else 27a34a8711Sopenharmony_ci#include "hilog/log.h" 28a34a8711Sopenharmony_ci#endif 29a34a8711Sopenharmony_ci#endif 30a34a8711Sopenharmony_ci 31a34a8711Sopenharmony_ci#ifdef __cplusplus 32a34a8711Sopenharmony_ciextern "C" { 33a34a8711Sopenharmony_ci#endif 34a34a8711Sopenharmony_ci 35a34a8711Sopenharmony_ci#ifndef IPCRPC_DEBUG 36a34a8711Sopenharmony_ci#if defined(__LITEOS_M__) 37a34a8711Sopenharmony_ci#define RPC_LOG_DEBUG(fmt, ...) HILOG_DEBUG(HILOG_MODULE_SOFTBUS, fmt, ##__VA_ARGS__) 38a34a8711Sopenharmony_ci#define RPC_LOG_INFO(fmt, ...) HILOG_INFO(HILOG_MODULE_SOFTBUS, fmt, ##__VA_ARGS__) 39a34a8711Sopenharmony_ci#define RPC_LOG_WARN(fmt, ...) HILOG_WARN(HILOG_MODULE_SOFTBUS, fmt, ##__VA_ARGS__) 40a34a8711Sopenharmony_ci#define RPC_LOG_ERROR(fmt, ...) HILOG_ERROR(HILOG_MODULE_SOFTBUS, fmt, ##__VA_ARGS__) 41a34a8711Sopenharmony_ci#else 42a34a8711Sopenharmony_ci#undef LOG_DOMAIN 43a34a8711Sopenharmony_ci#undef LOG_TAG 44a34a8711Sopenharmony_ci#define LOG_DOMAIN 0xD001518 45a34a8711Sopenharmony_ci#define LOG_TAG "IPCRPC" 46a34a8711Sopenharmony_ci 47a34a8711Sopenharmony_ci#define RPC_LOG_DEBUG(fmt, ...) HILOG_DEBUG(LOG_CORE, fmt, ##__VA_ARGS__) 48a34a8711Sopenharmony_ci#define RPC_LOG_INFO(fmt, ...) HILOG_INFO(LOG_CORE, fmt, ##__VA_ARGS__) 49a34a8711Sopenharmony_ci#define RPC_LOG_WARN(fmt, ...) HILOG_WARN(LOG_CORE, fmt, ##__VA_ARGS__) 50a34a8711Sopenharmony_ci#define RPC_LOG_ERROR(fmt, ...) HILOG_ERROR(LOG_CORE, fmt, ##__VA_ARGS__) 51a34a8711Sopenharmony_ci#endif 52a34a8711Sopenharmony_ci#else 53a34a8711Sopenharmony_cienum { 54a34a8711Sopenharmony_ci RPC_LOG_LEVEL_DEBUG = 0, 55a34a8711Sopenharmony_ci RPC_LOG_LEVEL_INFO, 56a34a8711Sopenharmony_ci RPC_LOG_LEVEL_WARNING, 57a34a8711Sopenharmony_ci RPC_LOG_LEVEL_ERROR 58a34a8711Sopenharmony_ci}; 59a34a8711Sopenharmony_ci 60a34a8711Sopenharmony_ci#define RPC_LOG_LEVEL RPC_LOG_LEVEL_INFO 61a34a8711Sopenharmony_ci 62a34a8711Sopenharmony_ci#define LOG_DBG(fmt, ...) do { \ 63a34a8711Sopenharmony_ci if (RPC_LOG_LEVEL_DEBUG >= RPC_LOG_LEVEL) { \ 64a34a8711Sopenharmony_ci printf("DEBUG: " fmt "\n", ##__VA_ARGS__); \ 65a34a8711Sopenharmony_ci } \ 66a34a8711Sopenharmony_ci} while (0) 67a34a8711Sopenharmony_ci 68a34a8711Sopenharmony_ci#define LOG_INFO(fmt, ...) do { \ 69a34a8711Sopenharmony_ci if (RPC_LOG_LEVEL_INFO >= RPC_LOG_LEVEL) { \ 70a34a8711Sopenharmony_ci printf("INFO: " fmt "\n", ##__VA_ARGS__); \ 71a34a8711Sopenharmony_ci } \ 72a34a8711Sopenharmony_ci} while (0) 73a34a8711Sopenharmony_ci 74a34a8711Sopenharmony_ci#define LOG_WARN(fmt, ...) do { \ 75a34a8711Sopenharmony_ci if (RPC_LOG_LEVEL_WARNING >= RPC_LOG_LEVEL) { \ 76a34a8711Sopenharmony_ci printf("WARN: " fmt "\n", ##__VA_ARGS__); \ 77a34a8711Sopenharmony_ci } \ 78a34a8711Sopenharmony_ci} while (0) 79a34a8711Sopenharmony_ci 80a34a8711Sopenharmony_ci#define LOG_ERR(fmt, ...) do { \ 81a34a8711Sopenharmony_ci if (RPC_LOG_LEVEL_ERROR >= RPC_LOG_LEVEL) { \ 82a34a8711Sopenharmony_ci printf("ERROR: " fmt "\n", ##__VA_ARGS__); \ 83a34a8711Sopenharmony_ci } \ 84a34a8711Sopenharmony_ci} while (0) 85a34a8711Sopenharmony_ci#endif 86a34a8711Sopenharmony_ci 87a34a8711Sopenharmony_ci#if defined(__LITEOS_M__) 88a34a8711Sopenharmony_ci#define RPC_HILOG_ID HILOG_MODULE_SOFTBUS 89a34a8711Sopenharmony_ci#else 90a34a8711Sopenharmony_ci#define RPC_HILOG_ID LOG_CORE 91a34a8711Sopenharmony_ci#endif 92a34a8711Sopenharmony_ci 93a34a8711Sopenharmony_citypedef enum { 94a34a8711Sopenharmony_ci RPC_LOG_DBG, 95a34a8711Sopenharmony_ci RPC_LOG_INFO, 96a34a8711Sopenharmony_ci RPC_LOG_WARN, 97a34a8711Sopenharmony_ci RPC_LOG_ERROR, 98a34a8711Sopenharmony_ci RPC_LOG_LEVEL_MAX, 99a34a8711Sopenharmony_ci} RpcLogLevel; 100a34a8711Sopenharmony_ci 101a34a8711Sopenharmony_citypedef enum { 102a34a8711Sopenharmony_ci RPC_LOG_IPC, 103a34a8711Sopenharmony_ci RPC_LOG_RPC, 104a34a8711Sopenharmony_ci RPC_LOG_SER, 105a34a8711Sopenharmony_ci RPC_LOG_MODULE_MAX, 106a34a8711Sopenharmony_ci} RpcLogModule; 107a34a8711Sopenharmony_ci 108a34a8711Sopenharmony_civoid RpcLog(RpcLogModule module, RpcLogLevel level, const char *fmt, ...); 109a34a8711Sopenharmony_ci 110a34a8711Sopenharmony_ci#ifdef __cplusplus 111a34a8711Sopenharmony_ci} 112a34a8711Sopenharmony_ci#endif /* __cplusplus */ 113a34a8711Sopenharmony_ci#endif /* OHOS_IPC_RPC_LOG_H */