blob: 1fb240c2c10d441ed61430c71ead6a4303f3e9ef [file] [log] [blame]
/* See Project CHIP LICENSE file for licensing information. */
#include <platform/logging/LogV.h>
#include <lib/core/CHIPConfig.h>
#include <platform/CHIPDeviceConfig.h>
#if CHIP_DEVICE_CONFIG_ENABLE_THREAD
#include <openthread/platform/logging.h>
#endif
#include "ti_drivers_config.h"
#include <ti/drivers/UART.h>
#include <stdio.h>
UART_Handle sDebugUartHandle;
char sDebugUartBuffer[CHIP_CONFIG_LOG_MESSAGE_MAX_SIZE];
#if MATTER_CC13X2_26X2_PLATFORM_LOG_ENABLED
extern "C" int cc13x2_26x2LogInit(void)
{
UART_Params uartParams;
UART_init();
UART_Params_init(&uartParams);
// Most params can be default because we only send data, we don't receive
uartParams.baudRate = 115200;
// unclear why the UART driver sticks in writing sometimes
uartParams.writeTimeout = 10000; // ticks
sDebugUartHandle = UART_open(CONFIG_UART_DEBUG, &uartParams);
return 0;
}
extern "C" void cc13x2_26x2VLog(const char * msg, va_list v)
{
int ret;
ret = vsnprintf(sDebugUartBuffer, sizeof(sDebugUartBuffer), msg, v);
if (0 < ret)
{
// PuTTY likes \r\n
size_t len = (ret + 2U) < sizeof(sDebugUartBuffer) ? (ret + 2) : sizeof(sDebugUartBuffer);
sDebugUartBuffer[len - 2] = '\r';
sDebugUartBuffer[len - 1] = '\n';
UART_write(sDebugUartHandle, sDebugUartBuffer, len);
}
}
#else
/* log functins defined somewhere else */
extern "C" int cc13x2_26x2LogInit(void);
extern "C" void cc13x2_26x2VLog(const char * msg, va_list v);
#endif // MATTER_CC13X2_26X2_PLATFORM_LOG_ENABLED
namespace chip {
namespace DeviceLayer {
/**
* Called whenever a log message is emitted.
*
* Can be overridden by the device logging file
*/
void __attribute__((weak)) OnLogOutput(void) {}
} // namespace DeviceLayer
} // namespace chip
namespace chip {
namespace Logging {
namespace Platform {
void LogV(const char * module, uint8_t category, const char * msg, va_list v)
{
(void) module;
(void) category;
cc13x2_26x2VLog(msg, v);
chip::DeviceLayer::OnLogOutput();
}
} // namespace Platform
} // namespace Logging
} // namespace chip
#if CHIP_SYSTEM_CONFIG_USE_LWIP
/**
* LwIP log output function.
*/
extern "C" void LwIPLog(const char * msg, ...)
{
va_list v;
va_start(v, msg);
cc13x2_26x2VLog(msg, v);
chip::DeviceLayer::OnLogOutput();
va_end(v);
}
#endif // #if CHIP_SYSTEM_CONFIG_USE_LWIP
/**
* Platform log output function.
*/
extern "C" void cc13x2_26x2Log(const char * msg, ...)
{
va_list v;
va_start(v, msg);
cc13x2_26x2VLog(msg, v);
chip::DeviceLayer::OnLogOutput();
va_end(v);
}
#if CHIP_DEVICE_CONFIG_ENABLE_THREAD
extern "C" void otPlatLog(otLogLevel aLogLevel, otLogRegion aLogRegion, const char * aFormat, ...)
{
va_list v;
(void) aLogLevel;
(void) aLogRegion;
va_start(v, aFormat);
cc13x2_26x2VLog(aFormat, v);
chip::DeviceLayer::OnLogOutput();
va_end(v);
}
#endif // CHIP_DEVICE_CONFIG_ENABLE_THREAD