1 /*
2  * Copyright (c) 2021-2024 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 #ifndef STORAGE_SERVICE_UTILS_LOG_H
16 #define STORAGE_SERVICE_UTILS_LOG_H
17 
18 #include "hilog/log.h"
19 
20 namespace OHOS {
21 static constexpr OHOS::HiviewDFX::HiLogLabel KLOG_LABEL = { LOG_KMSG, LOG_DOMAIN, STORAGE_LOG_TAG};
22 
23 #if defined KMSG_LOG
24 #define LOGF(fmt, ...) \
25     ((void)HILOG_IMPL(LOG_CORE, LOG_FATAL, LOG_DOMAIN, STORAGE_LOG_TAG, \
26     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)); \
27     OHOS::HiviewDFX::HiLog::Fatal(OHOS::KLOG_LABEL, "[%{public}s:%{public}d] " fmt, \
28                             __FUNCTION__, __LINE__, ##__VA_ARGS__)
29 #define LOGI(fmt, ...) \
30     ((void)HILOG_IMPL(LOG_CORE, LOG_INFO, LOG_DOMAIN, STORAGE_LOG_TAG, \
31     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)); \
32     OHOS::HiviewDFX::HiLog::Info(OHOS::KLOG_LABEL, "[%{public}s:%{public}d] " fmt, \
33                             __FUNCTION__, __LINE__, ##__VA_ARGS__)
34 #define LOGW(fmt, ...) \
35     ((void)HILOG_IMPL(LOG_CORE, LOG_WARN, LOG_DOMAIN, STORAGE_LOG_TAG, \
36     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)); \
37     OHOS::HiviewDFX::HiLog::Warn(OHOS::KLOG_LABEL, "[%{public}s:%{public}d] " fmt, \
38                             __FUNCTION__, __LINE__, ##__VA_ARGS__)
39 #define LOGD(fmt, ...) \
40     ((void)HILOG_IMPL(LOG_CORE, LOG_DEBUG, LOG_DOMAIN, STORAGE_LOG_TAG, \
41     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)); \
42     OHOS::HiviewDFX::HiLog::Debug(OHOS::KLOG_LABEL, "[%{public}s:%{public}d] " fmt, \
43                             __FUNCTION__, __LINE__, ##__VA_ARGS__)
44 #define LOGE(fmt, ...) \
45     ((void)HILOG_IMPL(LOG_CORE, LOG_ERROR, LOG_DOMAIN, STORAGE_LOG_TAG, \
46     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)); \
47     OHOS::HiviewDFX::HiLog::Error(OHOS::KLOG_LABEL, "[%{public}s:%{public}d] " fmt, \
48                             __FUNCTION__, __LINE__, ##__VA_ARGS__)
49 #else
50 #define LOGF(fmt, ...) \
51     ((void)HILOG_IMPL(LOG_CORE, LOG_FATAL, LOG_DOMAIN, STORAGE_LOG_TAG, \
52     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__))
53 #define LOGI(fmt, ...) \
54     ((void)HILOG_IMPL(LOG_CORE, LOG_INFO, LOG_DOMAIN, STORAGE_LOG_TAG, \
55     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__))
56 #define LOGW(fmt, ...) \
57     ((void)HILOG_IMPL(LOG_CORE, LOG_WARN, LOG_DOMAIN, STORAGE_LOG_TAG, \
58     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__))
59 #define LOGD(fmt, ...) \
60     ((void)HILOG_IMPL(LOG_CORE, LOG_DEBUG, LOG_DOMAIN, STORAGE_LOG_TAG, \
61     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__))
62 #define LOGE(fmt, ...) \
63     ((void)HILOG_IMPL(LOG_CORE, LOG_ERROR, LOG_DOMAIN, STORAGE_LOG_TAG, \
64     "[%{public}s:%{public}d] " fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__))
65 #endif
66 } // OHOS
67 
68 #endif // STORAGE_SERVICE_UTILS_LOG_H
69