You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
57 lines
1.2 KiB
57 lines
1.2 KiB
/* |
|
* Copyright (c) 2018 Nordic Semiconductor ASA |
|
* Copyright (c) 2022 Marcin Niestroj |
|
* |
|
* SPDX-License-Identifier: Apache-2.0 |
|
*/ |
|
|
|
#include <zephyr/logging/log.h> |
|
LOG_MODULE_REGISTER(mbedtls, CONFIG_MBEDTLS_LOG_LEVEL); |
|
|
|
#include "zephyr_mbedtls_priv.h" |
|
|
|
void zephyr_mbedtls_debug(void *ctx, int level, const char *file, int line, const char *str) |
|
{ |
|
const char *p, *basename = file; |
|
int str_len; |
|
|
|
ARG_UNUSED(ctx); |
|
|
|
if (!file || !str) { |
|
return; |
|
} |
|
|
|
/* Extract basename from file */ |
|
if (IS_ENABLED(CONFIG_MBEDTLS_DEBUG_EXTRACT_BASENAME_AT_RUNTIME)) { |
|
for (p = basename = file; *p != '\0'; p++) { |
|
if (*p == '/' || *p == '\\') { |
|
basename = p + 1; |
|
} |
|
} |
|
} |
|
|
|
str_len = strlen(str); |
|
|
|
if (IS_ENABLED(CONFIG_MBEDTLS_DEBUG_STRIP_NEWLINE)) { |
|
/* Remove newline only when it exists */ |
|
if (str_len > 0 && str[str_len - 1] == '\n') { |
|
str_len--; |
|
} |
|
} |
|
|
|
switch (level) { |
|
case 0: |
|
case 1: |
|
LOG_ERR("%s:%04d: %.*s", basename, line, str_len, str); |
|
break; |
|
case 2: |
|
LOG_WRN("%s:%04d: %.*s", basename, line, str_len, str); |
|
break; |
|
case 3: |
|
LOG_INF("%s:%04d: %.*s", basename, line, str_len, str); |
|
break; |
|
default: |
|
LOG_DBG("%s:%04d: %.*s", basename, line, str_len, str); |
|
break; |
|
} |
|
}
|
|
|