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