xref: /nrf52832-nimble/packages/NimBLE-latest/porting/nimble/include/modlog/modlog.h (revision 042d53a763ad75cb1465103098bb88c245d95138)
1*042d53a7SEvalZero /*
2*042d53a7SEvalZero  * Licensed to the Apache Software Foundation (ASF) under one
3*042d53a7SEvalZero  * or more contributor license agreements.  See the NOTICE file
4*042d53a7SEvalZero  * distributed with this work for additional information
5*042d53a7SEvalZero  * regarding copyright ownership.  The ASF licenses this file
6*042d53a7SEvalZero  * to you under the Apache License, Version 2.0 (the
7*042d53a7SEvalZero  * "License"); you may not use this file except in compliance
8*042d53a7SEvalZero  * with the License.  You may obtain a copy of the License at
9*042d53a7SEvalZero  *
10*042d53a7SEvalZero  *  http://www.apache.org/licenses/LICENSE-2.0
11*042d53a7SEvalZero  *
12*042d53a7SEvalZero  * Unless required by applicable law or agreed to in writing,
13*042d53a7SEvalZero  * software distributed under the License is distributed on an
14*042d53a7SEvalZero  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15*042d53a7SEvalZero  * KIND, either express or implied.  See the License for the
16*042d53a7SEvalZero  * specific language governing permissions and limitations
17*042d53a7SEvalZero  * under the License.
18*042d53a7SEvalZero  */
19*042d53a7SEvalZero 
20*042d53a7SEvalZero #ifndef H_MODLOG_
21*042d53a7SEvalZero #define H_MODLOG_
22*042d53a7SEvalZero 
23*042d53a7SEvalZero #include <stdint.h>
24*042d53a7SEvalZero #include "log/log.h"
25*042d53a7SEvalZero 
26*042d53a7SEvalZero extern void modlog_dummy(uint8_t level, const char *msg, ...);
27*042d53a7SEvalZero 
28*042d53a7SEvalZero #define MODLOG_MODULE_DFLT 255
29*042d53a7SEvalZero 
30*042d53a7SEvalZero #define MODLOG_LEVEL_ERROR    0
31*042d53a7SEvalZero #define MODLOG_LEVEL_WARING   1
32*042d53a7SEvalZero #define MODLOG_LEVEL_INFO     2
33*042d53a7SEvalZero #define MODLOG_LEVEL_LOG      3
34*042d53a7SEvalZero #define MODLOG_LEVEL_RAW      4
35*042d53a7SEvalZero #define MODLOG_LEVEL_CRITICAL 5
36*042d53a7SEvalZero 
37*042d53a7SEvalZero #define MODLOG_DEBUG(ml_mod_, ml_msg_, ...) \
38*042d53a7SEvalZero     modlog_dummy(MODLOG_LEVEL_LOG, (ml_msg_), ##__VA_ARGS__)
39*042d53a7SEvalZero 
40*042d53a7SEvalZero #define MODLOG_INFO(ml_mod_, ml_msg_, ...) \
41*042d53a7SEvalZero     modlog_dummy(MODLOG_LEVEL_INFO, (ml_msg_), ##__VA_ARGS__)
42*042d53a7SEvalZero 
43*042d53a7SEvalZero #define MODLOG_WARN(ml_mod_, ml_msg_, ...) \
44*042d53a7SEvalZero     modlog_dummy(MODLOG_LEVEL_WARING, (ml_msg_), ##__VA_ARGS__)
45*042d53a7SEvalZero 
46*042d53a7SEvalZero #define MODLOG_ERROR(ml_mod_, ml_msg_, ...) \
47*042d53a7SEvalZero     modlog_dummy(MODLOG_LEVEL_ERROR, (ml_msg_), ##__VA_ARGS__)
48*042d53a7SEvalZero 
49*042d53a7SEvalZero #define MODLOG_RAW(ml_mod_, ml_msg_, ...) \
50*042d53a7SEvalZero     modlog_dummy(MODLOG_LEVEL_RAW, (ml_msg_), ##__VA_ARGS__)
51*042d53a7SEvalZero 
52*042d53a7SEvalZero #define MODLOG_CRITICAL(ml_mod_, ml_msg_, ...) \
53*042d53a7SEvalZero     modlog_dummy(MODLOG_LEVEL_CRITICAL, (ml_msg_), ##__VA_ARGS__)
54*042d53a7SEvalZero 
55*042d53a7SEvalZero #define MODLOG(ml_lvl_, ml_mod_, ...) \
56*042d53a7SEvalZero     MODLOG_ ## ml_lvl_((ml_mod_), __VA_ARGS__)
57*042d53a7SEvalZero 
58*042d53a7SEvalZero #define MODLOG_DFLT(ml_lvl_, ...) \
59*042d53a7SEvalZero     MODLOG(ml_lvl_, LOG_MODULE_DEFAULT, __VA_ARGS__)
60*042d53a7SEvalZero 
61*042d53a7SEvalZero #endif
62