xref: /aosp_15_r20/external/ot-br-posix/src/common/logging.cpp (revision 4a64e381480ef79f0532b2421e44e6ee336b8e0d)
1*4a64e381SAndroid Build Coastguard Worker /*
2*4a64e381SAndroid Build Coastguard Worker  *    Copyright (c) 2017, The OpenThread Authors.
3*4a64e381SAndroid Build Coastguard Worker  *    All rights reserved.
4*4a64e381SAndroid Build Coastguard Worker  *
5*4a64e381SAndroid Build Coastguard Worker  *    Redistribution and use in source and binary forms, with or without
6*4a64e381SAndroid Build Coastguard Worker  *    modification, are permitted provided that the following conditions are met:
7*4a64e381SAndroid Build Coastguard Worker  *    1. Redistributions of source code must retain the above copyright
8*4a64e381SAndroid Build Coastguard Worker  *       notice, this list of conditions and the following disclaimer.
9*4a64e381SAndroid Build Coastguard Worker  *    2. Redistributions in binary form must reproduce the above copyright
10*4a64e381SAndroid Build Coastguard Worker  *       notice, this list of conditions and the following disclaimer in the
11*4a64e381SAndroid Build Coastguard Worker  *       documentation and/or other materials provided with the distribution.
12*4a64e381SAndroid Build Coastguard Worker  *    3. Neither the name of the copyright holder nor the
13*4a64e381SAndroid Build Coastguard Worker  *       names of its contributors may be used to endorse or promote products
14*4a64e381SAndroid Build Coastguard Worker  *       derived from this software without specific prior written permission.
15*4a64e381SAndroid Build Coastguard Worker  *
16*4a64e381SAndroid Build Coastguard Worker  *    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17*4a64e381SAndroid Build Coastguard Worker  *    AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*4a64e381SAndroid Build Coastguard Worker  *    IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*4a64e381SAndroid Build Coastguard Worker  *    ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20*4a64e381SAndroid Build Coastguard Worker  *    LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21*4a64e381SAndroid Build Coastguard Worker  *    CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22*4a64e381SAndroid Build Coastguard Worker  *    SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23*4a64e381SAndroid Build Coastguard Worker  *    INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24*4a64e381SAndroid Build Coastguard Worker  *    CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25*4a64e381SAndroid Build Coastguard Worker  *    ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26*4a64e381SAndroid Build Coastguard Worker  *    POSSIBILITY OF SUCH DAMAGE.
27*4a64e381SAndroid Build Coastguard Worker  */
28*4a64e381SAndroid Build Coastguard Worker 
29*4a64e381SAndroid Build Coastguard Worker #define OTBR_LOG_TAG "LOG"
30*4a64e381SAndroid Build Coastguard Worker 
31*4a64e381SAndroid Build Coastguard Worker #ifndef OTBR_SYSLOG_FACILITY_ID
32*4a64e381SAndroid Build Coastguard Worker #define OTBR_SYSLOG_FACILITY_ID LOG_USER
33*4a64e381SAndroid Build Coastguard Worker #endif
34*4a64e381SAndroid Build Coastguard Worker 
35*4a64e381SAndroid Build Coastguard Worker #include "common/logging.hpp"
36*4a64e381SAndroid Build Coastguard Worker 
37*4a64e381SAndroid Build Coastguard Worker #include <assert.h>
38*4a64e381SAndroid Build Coastguard Worker #include <errno.h>
39*4a64e381SAndroid Build Coastguard Worker #include <stdarg.h>
40*4a64e381SAndroid Build Coastguard Worker #include <stdint.h>
41*4a64e381SAndroid Build Coastguard Worker #include <stdio.h>
42*4a64e381SAndroid Build Coastguard Worker #include <stdlib.h>
43*4a64e381SAndroid Build Coastguard Worker #include <string.h>
44*4a64e381SAndroid Build Coastguard Worker #include <sys/time.h>
45*4a64e381SAndroid Build Coastguard Worker #include <syslog.h>
46*4a64e381SAndroid Build Coastguard Worker 
47*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_PLATFORM_ANDROID
48*4a64e381SAndroid Build Coastguard Worker #include <log/log.h>
49*4a64e381SAndroid Build Coastguard Worker #endif
50*4a64e381SAndroid Build Coastguard Worker 
51*4a64e381SAndroid Build Coastguard Worker #include <sstream>
52*4a64e381SAndroid Build Coastguard Worker 
53*4a64e381SAndroid Build Coastguard Worker #include "common/code_utils.hpp"
54*4a64e381SAndroid Build Coastguard Worker #include "common/time.hpp"
55*4a64e381SAndroid Build Coastguard Worker 
56*4a64e381SAndroid Build Coastguard Worker static otbrLogLevel sLevel            = OTBR_LOG_INFO;
57*4a64e381SAndroid Build Coastguard Worker static const char   sLevelString[][8] = {
58*4a64e381SAndroid Build Coastguard Worker       "[EMERG]", "[ALERT]", "[CRIT]", "[ERR ]", "[WARN]", "[NOTE]", "[INFO]", "[DEBG]",
59*4a64e381SAndroid Build Coastguard Worker };
60*4a64e381SAndroid Build Coastguard Worker static bool sSyslogDisabled = false;
61*4a64e381SAndroid Build Coastguard Worker 
62*4a64e381SAndroid Build Coastguard Worker static otbrLogLevel sDefaultLevel = OTBR_LOG_INFO;
63*4a64e381SAndroid Build Coastguard Worker 
64*4a64e381SAndroid Build Coastguard Worker /** Get the current debug log level */
otbrLogGetLevel(void)65*4a64e381SAndroid Build Coastguard Worker otbrLogLevel otbrLogGetLevel(void)
66*4a64e381SAndroid Build Coastguard Worker {
67*4a64e381SAndroid Build Coastguard Worker     return sLevel;
68*4a64e381SAndroid Build Coastguard Worker }
69*4a64e381SAndroid Build Coastguard Worker 
70*4a64e381SAndroid Build Coastguard Worker /** Get the default log level */
otbrLogGetDefaultLevel(void)71*4a64e381SAndroid Build Coastguard Worker otbrLogLevel otbrLogGetDefaultLevel(void)
72*4a64e381SAndroid Build Coastguard Worker {
73*4a64e381SAndroid Build Coastguard Worker     return sDefaultLevel;
74*4a64e381SAndroid Build Coastguard Worker }
75*4a64e381SAndroid Build Coastguard Worker 
76*4a64e381SAndroid Build Coastguard Worker /**
77*4a64e381SAndroid Build Coastguard Worker  * Set current log level.
78*4a64e381SAndroid Build Coastguard Worker  */
otbrLogSetLevel(otbrLogLevel aLevel)79*4a64e381SAndroid Build Coastguard Worker void otbrLogSetLevel(otbrLogLevel aLevel)
80*4a64e381SAndroid Build Coastguard Worker {
81*4a64e381SAndroid Build Coastguard Worker     assert(aLevel >= OTBR_LOG_EMERG && aLevel <= OTBR_LOG_DEBUG);
82*4a64e381SAndroid Build Coastguard Worker     sLevel = aLevel;
83*4a64e381SAndroid Build Coastguard Worker }
84*4a64e381SAndroid Build Coastguard Worker 
85*4a64e381SAndroid Build Coastguard Worker /** Enable/disable logging with syslog */
otbrLogSyslogSetEnabled(bool aEnabled)86*4a64e381SAndroid Build Coastguard Worker void otbrLogSyslogSetEnabled(bool aEnabled)
87*4a64e381SAndroid Build Coastguard Worker {
88*4a64e381SAndroid Build Coastguard Worker     sSyslogDisabled = !aEnabled;
89*4a64e381SAndroid Build Coastguard Worker }
90*4a64e381SAndroid Build Coastguard Worker 
91*4a64e381SAndroid Build Coastguard Worker /** Initialize logging */
otbrLogInit(const char * aProgramName,otbrLogLevel aLevel,bool aPrintStderr,bool aSyslogDisable)92*4a64e381SAndroid Build Coastguard Worker void otbrLogInit(const char *aProgramName, otbrLogLevel aLevel, bool aPrintStderr, bool aSyslogDisable)
93*4a64e381SAndroid Build Coastguard Worker {
94*4a64e381SAndroid Build Coastguard Worker     assert(aLevel >= OTBR_LOG_EMERG && aLevel <= OTBR_LOG_DEBUG);
95*4a64e381SAndroid Build Coastguard Worker     otbrLogSyslogSetEnabled(!aSyslogDisable);
96*4a64e381SAndroid Build Coastguard Worker 
97*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_PLATFORM_ANDROID
98*4a64e381SAndroid Build Coastguard Worker     OTBR_UNUSED_VARIABLE(aProgramName);
99*4a64e381SAndroid Build Coastguard Worker #else
100*4a64e381SAndroid Build Coastguard Worker     assert(aProgramName != nullptr);
101*4a64e381SAndroid Build Coastguard Worker 
102*4a64e381SAndroid Build Coastguard Worker     if (!sSyslogDisabled)
103*4a64e381SAndroid Build Coastguard Worker     {
104*4a64e381SAndroid Build Coastguard Worker         const char *ident;
105*4a64e381SAndroid Build Coastguard Worker 
106*4a64e381SAndroid Build Coastguard Worker         ident = strrchr(aProgramName, '/');
107*4a64e381SAndroid Build Coastguard Worker         ident = (ident != nullptr) ? ident + 1 : aProgramName;
108*4a64e381SAndroid Build Coastguard Worker 
109*4a64e381SAndroid Build Coastguard Worker         openlog(ident, (LOG_CONS | LOG_PID) | (aPrintStderr ? LOG_PERROR : 0), OTBR_SYSLOG_FACILITY_ID);
110*4a64e381SAndroid Build Coastguard Worker     }
111*4a64e381SAndroid Build Coastguard Worker #endif
112*4a64e381SAndroid Build Coastguard Worker 
113*4a64e381SAndroid Build Coastguard Worker     sLevel        = aLevel;
114*4a64e381SAndroid Build Coastguard Worker     sDefaultLevel = sLevel;
115*4a64e381SAndroid Build Coastguard Worker }
116*4a64e381SAndroid Build Coastguard Worker 
GetPrefix(const char * aLogTag)117*4a64e381SAndroid Build Coastguard Worker static const char *GetPrefix(const char *aLogTag)
118*4a64e381SAndroid Build Coastguard Worker {
119*4a64e381SAndroid Build Coastguard Worker     // Log prefix format : -xxx-----
120*4a64e381SAndroid Build Coastguard Worker     const uint8_t kMaxTagSize = 7;
121*4a64e381SAndroid Build Coastguard Worker     const uint8_t kBufferSize = kMaxTagSize + 3;
122*4a64e381SAndroid Build Coastguard Worker     static char   prefix[kBufferSize];
123*4a64e381SAndroid Build Coastguard Worker     uint8_t       tagLength = strlen(aLogTag) > kMaxTagSize ? kMaxTagSize : strlen(aLogTag);
124*4a64e381SAndroid Build Coastguard Worker     int           index     = 0;
125*4a64e381SAndroid Build Coastguard Worker 
126*4a64e381SAndroid Build Coastguard Worker     if (strlen(aLogTag) > 0)
127*4a64e381SAndroid Build Coastguard Worker     {
128*4a64e381SAndroid Build Coastguard Worker         prefix[0] = '-';
129*4a64e381SAndroid Build Coastguard Worker         memcpy(&prefix[1], aLogTag, tagLength);
130*4a64e381SAndroid Build Coastguard Worker 
131*4a64e381SAndroid Build Coastguard Worker         index = tagLength + 1;
132*4a64e381SAndroid Build Coastguard Worker 
133*4a64e381SAndroid Build Coastguard Worker         memset(&prefix[index], '-', kMaxTagSize - tagLength + 1);
134*4a64e381SAndroid Build Coastguard Worker         index += kMaxTagSize - tagLength + 1;
135*4a64e381SAndroid Build Coastguard Worker     }
136*4a64e381SAndroid Build Coastguard Worker 
137*4a64e381SAndroid Build Coastguard Worker     prefix[index++] = '\0';
138*4a64e381SAndroid Build Coastguard Worker 
139*4a64e381SAndroid Build Coastguard Worker     return prefix;
140*4a64e381SAndroid Build Coastguard Worker }
141*4a64e381SAndroid Build Coastguard Worker 
142*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_PLATFORM_ANDROID
ConvertToAndroidLogPriority(otbrLogLevel aLevel)143*4a64e381SAndroid Build Coastguard Worker static android_LogPriority ConvertToAndroidLogPriority(otbrLogLevel aLevel)
144*4a64e381SAndroid Build Coastguard Worker {
145*4a64e381SAndroid Build Coastguard Worker     android_LogPriority priority;
146*4a64e381SAndroid Build Coastguard Worker 
147*4a64e381SAndroid Build Coastguard Worker     switch (aLevel)
148*4a64e381SAndroid Build Coastguard Worker     {
149*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_EMERG:
150*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_ALERT:
151*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_CRIT:
152*4a64e381SAndroid Build Coastguard Worker         priority = ANDROID_LOG_FATAL;
153*4a64e381SAndroid Build Coastguard Worker         break;
154*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_ERR:
155*4a64e381SAndroid Build Coastguard Worker         priority = ANDROID_LOG_ERROR;
156*4a64e381SAndroid Build Coastguard Worker         break;
157*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_WARNING:
158*4a64e381SAndroid Build Coastguard Worker         priority = ANDROID_LOG_WARN;
159*4a64e381SAndroid Build Coastguard Worker         break;
160*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_NOTICE:
161*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_INFO:
162*4a64e381SAndroid Build Coastguard Worker         priority = ANDROID_LOG_INFO;
163*4a64e381SAndroid Build Coastguard Worker         break;
164*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_DEBUG:
165*4a64e381SAndroid Build Coastguard Worker     default:
166*4a64e381SAndroid Build Coastguard Worker         priority = ANDROID_LOG_DEBUG;
167*4a64e381SAndroid Build Coastguard Worker         break;
168*4a64e381SAndroid Build Coastguard Worker     }
169*4a64e381SAndroid Build Coastguard Worker 
170*4a64e381SAndroid Build Coastguard Worker     return priority;
171*4a64e381SAndroid Build Coastguard Worker }
172*4a64e381SAndroid Build Coastguard Worker #endif
173*4a64e381SAndroid Build Coastguard Worker 
174*4a64e381SAndroid Build Coastguard Worker /** log to the syslog or standard out */
otbrLog(otbrLogLevel aLevel,const char * aLogTag,const char * aFormat,...)175*4a64e381SAndroid Build Coastguard Worker void otbrLog(otbrLogLevel aLevel, const char *aLogTag, const char *aFormat, ...)
176*4a64e381SAndroid Build Coastguard Worker {
177*4a64e381SAndroid Build Coastguard Worker     const uint16_t kBufferSize = 1024;
178*4a64e381SAndroid Build Coastguard Worker     va_list        ap;
179*4a64e381SAndroid Build Coastguard Worker     char           buffer[kBufferSize];
180*4a64e381SAndroid Build Coastguard Worker 
181*4a64e381SAndroid Build Coastguard Worker     va_start(ap, aFormat);
182*4a64e381SAndroid Build Coastguard Worker 
183*4a64e381SAndroid Build Coastguard Worker     if ((aLevel <= sLevel) && (vsnprintf(buffer, sizeof(buffer), aFormat, ap) > 0))
184*4a64e381SAndroid Build Coastguard Worker     {
185*4a64e381SAndroid Build Coastguard Worker         if (sSyslogDisabled)
186*4a64e381SAndroid Build Coastguard Worker         {
187*4a64e381SAndroid Build Coastguard Worker             printf("%s%s: %s\n", sLevelString[aLevel], GetPrefix(aLogTag), buffer);
188*4a64e381SAndroid Build Coastguard Worker         }
189*4a64e381SAndroid Build Coastguard Worker         else
190*4a64e381SAndroid Build Coastguard Worker         {
191*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_PLATFORM_ANDROID
192*4a64e381SAndroid Build Coastguard Worker             __android_log_print(ConvertToAndroidLogPriority(aLevel), LOG_TAG, "%s%s: %s", sLevelString[aLevel],
193*4a64e381SAndroid Build Coastguard Worker                                 GetPrefix(aLogTag), buffer);
194*4a64e381SAndroid Build Coastguard Worker #else
195*4a64e381SAndroid Build Coastguard Worker             syslog(static_cast<int>(aLevel), "%s%s: %s", sLevelString[aLevel], GetPrefix(aLogTag), buffer);
196*4a64e381SAndroid Build Coastguard Worker #endif
197*4a64e381SAndroid Build Coastguard Worker         }
198*4a64e381SAndroid Build Coastguard Worker     }
199*4a64e381SAndroid Build Coastguard Worker 
200*4a64e381SAndroid Build Coastguard Worker     va_end(ap);
201*4a64e381SAndroid Build Coastguard Worker 
202*4a64e381SAndroid Build Coastguard Worker     return;
203*4a64e381SAndroid Build Coastguard Worker }
204*4a64e381SAndroid Build Coastguard Worker 
205*4a64e381SAndroid Build Coastguard Worker /** log to the syslog or standard out */
otbrLogv(otbrLogLevel aLevel,const char * aFormat,va_list aArgList)206*4a64e381SAndroid Build Coastguard Worker void otbrLogv(otbrLogLevel aLevel, const char *aFormat, va_list aArgList)
207*4a64e381SAndroid Build Coastguard Worker {
208*4a64e381SAndroid Build Coastguard Worker     assert(aFormat);
209*4a64e381SAndroid Build Coastguard Worker 
210*4a64e381SAndroid Build Coastguard Worker     if (aLevel <= sLevel)
211*4a64e381SAndroid Build Coastguard Worker     {
212*4a64e381SAndroid Build Coastguard Worker         otbrLogvNoFilter(aLevel, aFormat, aArgList);
213*4a64e381SAndroid Build Coastguard Worker     }
214*4a64e381SAndroid Build Coastguard Worker }
215*4a64e381SAndroid Build Coastguard Worker 
216*4a64e381SAndroid Build Coastguard Worker /** log to the syslog or standard out */
otbrLogvNoFilter(otbrLogLevel aLevel,const char * aFormat,va_list aArgList)217*4a64e381SAndroid Build Coastguard Worker void otbrLogvNoFilter(otbrLogLevel aLevel, const char *aFormat, va_list aArgList)
218*4a64e381SAndroid Build Coastguard Worker {
219*4a64e381SAndroid Build Coastguard Worker     if (sSyslogDisabled)
220*4a64e381SAndroid Build Coastguard Worker     {
221*4a64e381SAndroid Build Coastguard Worker         vprintf(aFormat, aArgList);
222*4a64e381SAndroid Build Coastguard Worker         printf("\n");
223*4a64e381SAndroid Build Coastguard Worker     }
224*4a64e381SAndroid Build Coastguard Worker     else
225*4a64e381SAndroid Build Coastguard Worker     {
226*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_PLATFORM_ANDROID
227*4a64e381SAndroid Build Coastguard Worker         __android_log_vprint(ConvertToAndroidLogPriority(aLevel), LOG_TAG, aFormat, aArgList);
228*4a64e381SAndroid Build Coastguard Worker #else
229*4a64e381SAndroid Build Coastguard Worker         vsyslog(static_cast<int>(aLevel), aFormat, aArgList);
230*4a64e381SAndroid Build Coastguard Worker #endif
231*4a64e381SAndroid Build Coastguard Worker     }
232*4a64e381SAndroid Build Coastguard Worker }
233*4a64e381SAndroid Build Coastguard Worker 
234*4a64e381SAndroid Build Coastguard Worker /** Hex dump data to the log */
otbrDump(otbrLogLevel aLevel,const char * aLogTag,const char * aPrefix,const void * aMemory,size_t aSize)235*4a64e381SAndroid Build Coastguard Worker void otbrDump(otbrLogLevel aLevel, const char *aLogTag, const char *aPrefix, const void *aMemory, size_t aSize)
236*4a64e381SAndroid Build Coastguard Worker {
237*4a64e381SAndroid Build Coastguard Worker     static const char kHexChars[] = "0123456789abcdef";
238*4a64e381SAndroid Build Coastguard Worker     assert(aPrefix && (aMemory || aSize == 0));
239*4a64e381SAndroid Build Coastguard Worker     const uint8_t *pEnd;
240*4a64e381SAndroid Build Coastguard Worker     const uint8_t *p8;
241*4a64e381SAndroid Build Coastguard Worker     int            addr;
242*4a64e381SAndroid Build Coastguard Worker 
243*4a64e381SAndroid Build Coastguard Worker     if (aLevel >= sLevel)
244*4a64e381SAndroid Build Coastguard Worker     {
245*4a64e381SAndroid Build Coastguard Worker         return;
246*4a64e381SAndroid Build Coastguard Worker     }
247*4a64e381SAndroid Build Coastguard Worker 
248*4a64e381SAndroid Build Coastguard Worker     /* break hex dumps into 16byte lines
249*4a64e381SAndroid Build Coastguard Worker      * In the form ADDR: XX XX XX XX ...
250*4a64e381SAndroid Build Coastguard Worker      */
251*4a64e381SAndroid Build Coastguard Worker 
252*4a64e381SAndroid Build Coastguard Worker     // we pre-increment... so subtract
253*4a64e381SAndroid Build Coastguard Worker     addr = -16;
254*4a64e381SAndroid Build Coastguard Worker 
255*4a64e381SAndroid Build Coastguard Worker     while (aSize > 0)
256*4a64e381SAndroid Build Coastguard Worker     {
257*4a64e381SAndroid Build Coastguard Worker         size_t this_size;
258*4a64e381SAndroid Build Coastguard Worker         char   hex[16 * 3 + 1];
259*4a64e381SAndroid Build Coastguard Worker 
260*4a64e381SAndroid Build Coastguard Worker         addr = addr + 16;
261*4a64e381SAndroid Build Coastguard Worker         p8   = (const uint8_t *)(aMemory) + addr;
262*4a64e381SAndroid Build Coastguard Worker 
263*4a64e381SAndroid Build Coastguard Worker         /* truncate line to max 16 bytes */
264*4a64e381SAndroid Build Coastguard Worker         this_size = aSize;
265*4a64e381SAndroid Build Coastguard Worker         if (this_size > 16)
266*4a64e381SAndroid Build Coastguard Worker         {
267*4a64e381SAndroid Build Coastguard Worker             this_size = 16;
268*4a64e381SAndroid Build Coastguard Worker         }
269*4a64e381SAndroid Build Coastguard Worker         aSize = aSize - this_size;
270*4a64e381SAndroid Build Coastguard Worker 
271*4a64e381SAndroid Build Coastguard Worker         char *ch = hex - 1;
272*4a64e381SAndroid Build Coastguard Worker 
273*4a64e381SAndroid Build Coastguard Worker         for (pEnd = p8 + this_size; p8 < pEnd; p8++)
274*4a64e381SAndroid Build Coastguard Worker         {
275*4a64e381SAndroid Build Coastguard Worker             *++ch = kHexChars[(*p8) >> 4];
276*4a64e381SAndroid Build Coastguard Worker             *++ch = kHexChars[(*p8) & 0x0f];
277*4a64e381SAndroid Build Coastguard Worker             *++ch = ' ';
278*4a64e381SAndroid Build Coastguard Worker         }
279*4a64e381SAndroid Build Coastguard Worker         *ch = 0;
280*4a64e381SAndroid Build Coastguard Worker 
281*4a64e381SAndroid Build Coastguard Worker         otbrLog(aLevel, aLogTag, "%s: %04x: %s", aPrefix, addr, hex);
282*4a64e381SAndroid Build Coastguard Worker     }
283*4a64e381SAndroid Build Coastguard Worker }
284*4a64e381SAndroid Build Coastguard Worker 
otbrErrorString(otbrError aError)285*4a64e381SAndroid Build Coastguard Worker const char *otbrErrorString(otbrError aError)
286*4a64e381SAndroid Build Coastguard Worker {
287*4a64e381SAndroid Build Coastguard Worker     const char *error;
288*4a64e381SAndroid Build Coastguard Worker 
289*4a64e381SAndroid Build Coastguard Worker     switch (aError)
290*4a64e381SAndroid Build Coastguard Worker     {
291*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_NONE:
292*4a64e381SAndroid Build Coastguard Worker         error = "OK";
293*4a64e381SAndroid Build Coastguard Worker         break;
294*4a64e381SAndroid Build Coastguard Worker 
295*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_ERRNO:
296*4a64e381SAndroid Build Coastguard Worker         error = strerror(errno);
297*4a64e381SAndroid Build Coastguard Worker         break;
298*4a64e381SAndroid Build Coastguard Worker 
299*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_DBUS:
300*4a64e381SAndroid Build Coastguard Worker         error = "DBUS error";
301*4a64e381SAndroid Build Coastguard Worker         break;
302*4a64e381SAndroid Build Coastguard Worker 
303*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_MDNS:
304*4a64e381SAndroid Build Coastguard Worker         error = "MDNS error";
305*4a64e381SAndroid Build Coastguard Worker         break;
306*4a64e381SAndroid Build Coastguard Worker 
307*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_OPENTHREAD:
308*4a64e381SAndroid Build Coastguard Worker         error = "OpenThread error";
309*4a64e381SAndroid Build Coastguard Worker         break;
310*4a64e381SAndroid Build Coastguard Worker 
311*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_NOT_FOUND:
312*4a64e381SAndroid Build Coastguard Worker         error = "Not found";
313*4a64e381SAndroid Build Coastguard Worker         break;
314*4a64e381SAndroid Build Coastguard Worker 
315*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_PARSE:
316*4a64e381SAndroid Build Coastguard Worker         error = "Parse error";
317*4a64e381SAndroid Build Coastguard Worker         break;
318*4a64e381SAndroid Build Coastguard Worker 
319*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_NOT_IMPLEMENTED:
320*4a64e381SAndroid Build Coastguard Worker         error = "Not implemented";
321*4a64e381SAndroid Build Coastguard Worker         break;
322*4a64e381SAndroid Build Coastguard Worker 
323*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_INVALID_ARGS:
324*4a64e381SAndroid Build Coastguard Worker         error = "Invalid arguments";
325*4a64e381SAndroid Build Coastguard Worker         break;
326*4a64e381SAndroid Build Coastguard Worker 
327*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_DUPLICATED:
328*4a64e381SAndroid Build Coastguard Worker         error = "Duplicated";
329*4a64e381SAndroid Build Coastguard Worker         break;
330*4a64e381SAndroid Build Coastguard Worker 
331*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_ABORTED:
332*4a64e381SAndroid Build Coastguard Worker         error = "Aborted";
333*4a64e381SAndroid Build Coastguard Worker         break;
334*4a64e381SAndroid Build Coastguard Worker 
335*4a64e381SAndroid Build Coastguard Worker     case OTBR_ERROR_INVALID_STATE:
336*4a64e381SAndroid Build Coastguard Worker         error = "Invalid state";
337*4a64e381SAndroid Build Coastguard Worker         break;
338*4a64e381SAndroid Build Coastguard Worker 
339*4a64e381SAndroid Build Coastguard Worker     default:
340*4a64e381SAndroid Build Coastguard Worker         error = "Unknown";
341*4a64e381SAndroid Build Coastguard Worker     }
342*4a64e381SAndroid Build Coastguard Worker 
343*4a64e381SAndroid Build Coastguard Worker     return error;
344*4a64e381SAndroid Build Coastguard Worker }
345*4a64e381SAndroid Build Coastguard Worker 
otbrLogDeinit(void)346*4a64e381SAndroid Build Coastguard Worker void otbrLogDeinit(void)
347*4a64e381SAndroid Build Coastguard Worker {
348*4a64e381SAndroid Build Coastguard Worker     closelog();
349*4a64e381SAndroid Build Coastguard Worker }
350*4a64e381SAndroid Build Coastguard Worker 
ConvertToOtLogLevel(otbrLogLevel aLevel)351*4a64e381SAndroid Build Coastguard Worker otLogLevel ConvertToOtLogLevel(otbrLogLevel aLevel)
352*4a64e381SAndroid Build Coastguard Worker {
353*4a64e381SAndroid Build Coastguard Worker     otLogLevel level;
354*4a64e381SAndroid Build Coastguard Worker 
355*4a64e381SAndroid Build Coastguard Worker     switch (aLevel)
356*4a64e381SAndroid Build Coastguard Worker     {
357*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_EMERG:
358*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_ALERT:
359*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_CRIT:
360*4a64e381SAndroid Build Coastguard Worker         level = OT_LOG_LEVEL_CRIT;
361*4a64e381SAndroid Build Coastguard Worker         break;
362*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_ERR:
363*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_WARNING:
364*4a64e381SAndroid Build Coastguard Worker         level = OT_LOG_LEVEL_WARN;
365*4a64e381SAndroid Build Coastguard Worker         break;
366*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_NOTICE:
367*4a64e381SAndroid Build Coastguard Worker         level = OT_LOG_LEVEL_NOTE;
368*4a64e381SAndroid Build Coastguard Worker         break;
369*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_INFO:
370*4a64e381SAndroid Build Coastguard Worker         level = OT_LOG_LEVEL_INFO;
371*4a64e381SAndroid Build Coastguard Worker         break;
372*4a64e381SAndroid Build Coastguard Worker     case OTBR_LOG_DEBUG:
373*4a64e381SAndroid Build Coastguard Worker     default:
374*4a64e381SAndroid Build Coastguard Worker         level = OT_LOG_LEVEL_DEBG;
375*4a64e381SAndroid Build Coastguard Worker         break;
376*4a64e381SAndroid Build Coastguard Worker     }
377*4a64e381SAndroid Build Coastguard Worker 
378*4a64e381SAndroid Build Coastguard Worker     return level;
379*4a64e381SAndroid Build Coastguard Worker }
380