123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- /*
- * Copyright (c) 2019 Intel Corporation.
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #include <sys/printk.h>
- #include <ctype.h>
- #include <logging/log.h>
- #include <sys/printk.h>
- #define HEXDUMP_BYTES_IN_LINE 8U
- void z_log_minimal_printk(const char *fmt, ...)
- {
- va_list ap;
- va_start(ap, fmt);
- vprintk(fmt, ap);
- va_end(ap);
- }
- void z_log_minimal_vprintk(const char *fmt, va_list ap)
- {
- vprintk(fmt, ap);
- }
- static void minimal_hexdump_line_print(const char *data, size_t length)
- {
- for (size_t i = 0U; i < HEXDUMP_BYTES_IN_LINE; i++) {
- if (i < length) {
- printk("%02x ", (unsigned char)data[i] & 0xFFu);
- } else {
- printk(" ");
- }
- }
- printk("|");
- for (size_t i = 0U; i < HEXDUMP_BYTES_IN_LINE; i++) {
- if (i < length) {
- unsigned char c = data[i];
- printk("%c", isprint((int)c) != 0 ? c : '.');
- } else {
- printk(" ");
- }
- }
- printk("\n");
- }
- void z_log_minimal_hexdump_print(int level, const void *data, size_t size)
- {
- const char *data_buffer = (const char *)data;
- while (size > 0U) {
- printk("%c: ", z_log_minimal_level_to_char(level));
- minimal_hexdump_line_print(data_buffer, size);
- if (size < HEXDUMP_BYTES_IN_LINE) {
- break;
- }
- size -= HEXDUMP_BYTES_IN_LINE;
- data_buffer += HEXDUMP_BYTES_IN_LINE;
- }
- }
|