DA: Applying secure log
[platform/core/connectivity/net-config.git] / include / log.h
1 /*
2  * Network Configuration Module
3  *
4  * Copyright (c) 2000 - 2012 Samsung Electronics Co., Ltd. All rights reserved.
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
20 #ifndef __NETCONFIG_LOG_H__
21 #define __NETCONFIG_LOG_H__
22
23 #ifdef __cplusplus
24 extern "C" {
25 #endif
26
27 #include <dlog.h>
28 #include <string.h>
29
30 #define NETCONFIG_DEBUG_FILE (1)
31
32 #define NETCONFIG_TAG           "NETCONFIG"
33 #ifdef LOG_TAG
34 #undef LOG_TAG
35 #endif
36 #define LOG_TAG "NETCONFIG"
37
38 void            netconfig_log(const char *format, ...);
39 void            log_cleanup(void);
40
41 #define __LOG(level, format, arg...) \
42         do { \
43                 if (NETCONFIG_DEBUG_FILE) { \
44                         netconfig_log("%s(%d) "format"\n", __FUNCTION__, __LINE__,  ## arg); \
45                 } \
46                 SLOG(level, NETCONFIG_TAG, format, ## arg); \
47         } while (0)
48
49 #define DBG(format, arg...)     __LOG(LOG_DEBUG, format, ## arg)
50 #define INFO(format, arg...)    __LOG(LOG_INFO, format, ## arg)
51 #define WARN(format, arg...)    __LOG(LOG_WARN, format, ## arg)
52 #define ERR(format, arg...)     __LOG(LOG_ERROR, format, ## arg)
53
54 #ifdef __cplusplus
55 }
56 #endif
57
58 #endif /* __NETCONFIG_LOG_H__ */