238b786ce55cea5fa4912c795632e697456e3f5a
[platform/core/connectivity/zigbee-manager.git] / zigbee-client / include_private / zigbee_log.h
1 /*
2  * Copyright (c) 2016 Samsung Electronics Co., Ltd. All rights reserved.
3  *
4  * Contact: Suresh Kumar N (suresh.n@samsung.com)
5  *
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  */
18
19 #ifndef __ZIGBEE_LOG_H__
20 #define __ZIGBEE_LOG_H__
21
22 #include <glib.h>
23
24 #ifndef TIZEN_DEBUG_ENABLE
25 #define TIZEN_DEBUG_ENABLE
26 #endif
27
28 #ifndef ZIGBEE_LOG_TAG
29 #define ZIGBEE_LOG_TAG "UNKNOWN"
30 #endif
31
32 enum zigbee_log_type {
33         ZIGBEE_LOG_TYPE_MAIN = 0,
34         ZIGBEE_LOG_TYPE_RADIO,
35         ZIGBEE_LOG_TYPE_SYSTEM,
36         ZIGBEE_LOG_TYPE_TIME_CHECK
37 };
38
39 enum zigbee_log_priority {
40         ZIGBEE_LOG_UNKNOWN = 0,
41         ZIGBEE_LOG_DEFAULT,
42         ZIGBEE_LOG_VERBOSE,
43         ZIGBEE_LOG_DEBUG,
44         ZIGBEE_LOG_INFO,
45         ZIGBEE_LOG_WARN,
46         ZIGBEE_LOG_ERROR,
47         ZIGBEE_LOG_FATAL,
48         ZIGBEE_LOG_SILENT
49 };
50
51 void zigbee_log(enum zigbee_log_type type, enum zigbee_log_priority priority, const char *tag, const char *fmt, ...);
52
53 /* Logs would be available in system logs */
54 #define Z_LOGI(fmt, args...)  do { zigbee_log(ZIGBEE_LOG_TYPE_SYSTEM, ZIGBEE_LOG_INFO, ZIGBEE_LOG_TAG, "<%s:%d> " fmt "\n", __func__, __LINE__, ##args); } while (0)
55 #define Z_LOGM(fmt, args...)  do { zigbee_log(ZIGBEE_LOG_TYPE_SYSTEM, ZIGBEE_LOG_INFO, ZIGBEE_LOG_TAG, fmt "\n", ##args); } while (0)
56 #define Z_LOGD(fmt, args...)  do { zigbee_log(ZIGBEE_LOG_TYPE_SYSTEM, ZIGBEE_LOG_DEBUG, ZIGBEE_LOG_TAG, "<%s:%d> " fmt "\n", __func__, __LINE__, ##args); } while (0)
57 #define Z_LOGW(fmt, args...)  do { zigbee_log(ZIGBEE_LOG_TYPE_SYSTEM, ZIGBEE_LOG_WARN, ZIGBEE_LOG_TAG, "<%s:%d> " fmt "\n", __func__, __LINE__, ##args); } while (0)
58 #define Z_LOGE(fmt, args...)  do { zigbee_log(ZIGBEE_LOG_TYPE_SYSTEM, ZIGBEE_LOG_ERROR, ZIGBEE_LOG_TAG, "<%s:%d> " fmt "\n", __func__, __LINE__, ##args); } while (0)
59 #define Z_LOGF(fmt, args...)  do { zigbee_log(ZIGBEE_LOG_TYPE_SYSTEM, ZIGBEE_LOG_FATAL, ZIGBEE_LOG_TAG, "<%s:%d> " fmt "\n", __func__, __LINE__, ##args); } while (0)
60
61 #endif /* __ZIGBEE_LOG_H__ */