Branch data Line data Source code
1 : : /* 2 : : * Copyright (c) 2019 Intel Corporation. 3 : : * 4 : : * SPDX-License-Identifier: Apache-2.0 5 : : */ 6 : : 7 : : #include <sys/printk.h> 8 : : #include <ctype.h> 9 : : #include <logging/log.h> 10 : : #include <sys/printk.h> 11 : : 12 : : #define HEXDUMP_BYTES_IN_LINE 8U 13 : : 14 : 0 : void z_log_minimal_printk(const char *fmt, ...) 15 : : { 16 : : va_list ap; 17 : : 18 : 0 : va_start(ap, fmt); 19 : 0 : vprintk(fmt, ap); 20 : 0 : va_end(ap); 21 : 0 : } 22 : : 23 : 0 : void z_log_minimal_vprintk(const char *fmt, va_list ap) 24 : : { 25 : 0 : vprintk(fmt, ap); 26 : 0 : } 27 : : 28 : 0 : static void minimal_hexdump_line_print(const char *data, size_t length) 29 : : { 30 [ # # ]: 0 : for (size_t i = 0U; i < HEXDUMP_BYTES_IN_LINE; i++) { 31 [ # # ]: 0 : if (i < length) { 32 : 0 : printk("%02x ", (unsigned char)data[i] & 0xFFu); 33 : : } else { 34 : 0 : printk(" "); 35 : : } 36 : : } 37 : : 38 : 0 : printk("|"); 39 : : 40 [ # # ]: 0 : for (size_t i = 0U; i < HEXDUMP_BYTES_IN_LINE; i++) { 41 [ # # ]: 0 : if (i < length) { 42 : 0 : unsigned char c = data[i]; 43 : : 44 [ # # ]: 0 : printk("%c", isprint((int)c) != 0 ? c : '.'); 45 : : } else { 46 : 0 : printk(" "); 47 : : } 48 : : } 49 : 0 : printk("\n"); 50 : 0 : } 51 : : 52 : 0 : void z_log_minimal_hexdump_print(int level, const void *data, size_t size) 53 : : { 54 : 0 : const char *data_buffer = (const char *)data; 55 [ # # ]: 0 : while (size > 0U) { 56 : 0 : printk("%c: ", z_log_minimal_level_to_char(level)); 57 : 0 : minimal_hexdump_line_print(data_buffer, size); 58 : : 59 [ # # ]: 0 : if (size < HEXDUMP_BYTES_IN_LINE) { 60 : 0 : break; 61 : : } 62 : : 63 : 0 : size -= HEXDUMP_BYTES_IN_LINE; 64 : 0 : data_buffer += HEXDUMP_BYTES_IN_LINE; 65 : : } 66 : 0 : }