zephyr/subsys/net/lib/openthread/platform/logging.c
Kamil Sroka 83b2218ab5 subsys: net: lib: Add OpenThread platform
OpenThread requires platform definition with standarized API
so we have to add wrappers to make it compatible with Zephyr.
OpenThread is based on autoconf, this requires
more specific CMakeLists.txt which allows to clone specific
commit or point to local copy of openthread.

Signed-off-by: Kamil Sroka <kamil.sroka@nordicsemi.no>
2018-01-29 22:42:03 -05:00

57 lines
1.0 KiB
C

/*
* Copyright (c) 2018 Nordic Semiconductor ASA
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <kernel.h>
#include <stdarg.h>
#include <stdio.h>
#include <openthread/platform/logging.h>
#define SYS_LOG_DOMAIN "openthread"
#define SYS_LOG_LEVEL 4
#include <logging/sys_log.h>
#include "platform-zephyr.h"
#define LOG_PARSE_BUFFER_SIZE 128
void otPlatLog(otLogLevel aLogLevel, otLogRegion aLogRegion,
const char *aFormat, ...)
{
ARG_UNUSED(aLogRegion);
char logString[LOG_PARSE_BUFFER_SIZE + 1];
u16_t length = 0;
/* Parse user string. */
va_list paramList;
va_start(paramList, aFormat);
length += vsnprintf(&logString[length],
(LOG_PARSE_BUFFER_SIZE - length),
aFormat, paramList);
va_end(paramList);
switch (aLogLevel) {
case OT_LOG_LEVEL_CRIT:
SYS_LOG_ERR("%s", logString);
break;
case OT_LOG_LEVEL_WARN:
SYS_LOG_WRN("%s", logString);
break;
case OT_LOG_LEVEL_INFO:
SYS_LOG_INF("%s", logString);
break;
case OT_LOG_LEVEL_DEBG:
SYS_LOG_DBG("%s", logString);
break;
default:
break;
}
}