Select one of the symbols to view example projects that use it.
 
Outline
#include "utils/includes.h"
#include "utils/common.h"
#include "utils/wpa_debug.h"
_wpa_snprintf_hex(char *, size_t, const u8 *, size_t, int, int)
wpa_snprintf_hex_uppercase(char *, size_t, const u8 *, size_t)
wpa_snprintf_hex(char *, size_t, const u8 *, size_t)
Files
ESP-IDF
components
app_trace
app_update
bootloader_support
bt
cmock
console
cxx
driver
efuse
esp_adc
esp_app_format
esp_bootloader_format
esp_coex
esp_common
esp_driver_ana_cmpr
esp_driver_cam
esp_driver_dac
esp_driver_gpio
esp_driver_gptimer
esp_driver_i2c
esp_driver_i2s
esp_driver_jpeg
esp_driver_ledc
esp_driver_mcpwm
esp_driver_parlio
esp_driver_pcnt
esp_driver_rmt
esp_driver_sdio
esp_driver_sdm
esp_driver_sdmmc
esp_driver_sdspi
esp_driver_spi
esp_driver_tsens
esp_driver_uart
esp_driver_usb_serial_jtag
esp_eth
esp_event
esp_gdbstub
esp_hid
esp_http_client
esp_http_server
esp_https_ota
esp_https_server
esp_hw_support
esp_lcd
esp_local_ctrl
esp_mm
esp_netif
esp_partition
esp_phy
esp_pm
esp_psram
esp_ringbuf
esp_rom
esp_security
esp_system
esp_timer
esp_vfs_console
esp_wifi
esp-tls
espcoredump
hal
heap
http_parser
ieee802154
log
mqtt
newlib
nvs_flash
nvs_sec_provider
openthread
perfmon
protobuf-c
protocomm
pthread
rt
sdmmc
soc
spi_flash
spiffs
tcp_transport
ulp
unity
vfs
wear_levelling
wifi_provisioning
wpa_supplicant
esp_supplicant
include
port
src
ap
common
crypto
drivers
eap_common
eap_peer
eap_server
eapol_auth
rsn_supp
tls
utils
wps
xtensa
examples
lwIP
FreeRTOS
cJSON
mbedTLS
SourceVuESP-IDF Framework and ExamplesESP-IDFcomponents/wpa_supplicant/src/utils/wpa_debug.c
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* * wpa_supplicant/hostapd / Debug prints * Copyright (c) 2002-2013, Jouni Malinen <j@w1.fi> * * This software may be distributed under the terms of the BSD license. * See README for more details. *//* ... */ #ifdef ESP_SUPPLICANT #include "utils/includes.h" #include "utils/common.h" #include "utils/wpa_debug.h" static inline int _wpa_snprintf_hex(char *buf, size_t buf_size, const u8 *data, size_t len, int uppercase, int whitespace) { size_t i; char *pos = buf, *end = buf + buf_size; int ret; static const char *fmt_upper = "%02X"; static const char *fmt_lower = "%02x"; static const char *fmt_upper_ws = "%02X "; static const char *fmt_lower_ws = "%02x "; const char *fmt = uppercase ? (whitespace ? fmt_upper_ws : fmt_upper) : (whitespace ? fmt_lower_ws : fmt_lower); if (buf_size == 0) return 0; for (i = 0; i < len; i++) { ret = snprintf(pos, end - pos, fmt, data[i]); if (ret < 0 || ret >= end - pos) { end[-1] = '\0'; return pos - buf; }{...} pos += ret; }{...} end[-1]='\0'; return pos - buf; }{ ... } int wpa_snprintf_hex_uppercase(char *buf, size_t buf_size, const u8 *data, size_t len) { return _wpa_snprintf_hex(buf, buf_size, data, len, 1, 0); }{ ... } int wpa_snprintf_hex(char *buf, size_t buf_size, const u8 *data, size_t len) { return _wpa_snprintf_hex(buf, buf_size, data, len, 0, 0); }{ ... } #ifdef DEBUG_PRINT void wpa_dump_mem(char* desc, uint8_t *addr, uint16_t len) { char output[50]; wpa_printf(MSG_DEBUG, "%s", desc); if (addr){ uint16_t i=0; for (i = 0; i < len / 16; i++) { _wpa_snprintf_hex(output, 50, addr + i * 16, 16, 0, 1); wpa_printf(MSG_DEBUG, "%s", output); }{...} if (len % 16) { int bytes_printed = (len / 16) * 16; _wpa_snprintf_hex(output, 50, addr + bytes_printed, len - bytes_printed, 0, 1); wpa_printf(MSG_DEBUG, "%s", output); }{...} }{...} }{...} void wpa_debug_print_timestamp(void) { #ifdef DEBUG_PRINT struct os_time tv; os_get_time(&tv); wpa_printf(MSG_DEBUG, "%ld.%06u: ", (long) tv.sec, (unsigned int) tv.usec);/* ... */ #endif }{...} void wpa_hexdump(int level, const char *title, const u8 *buf, size_t len) { #ifdef DEBUG_PRINT size_t i; char output[50]; if (level < MSG_ERROR) return; wpa_printf(level, "%s - hexdump(len=%lu):", title, (unsigned long) len); if (buf == NULL) { wpa_printf(level, " [NULL]"); }{...} else { for (i = 0; i < len / 16; i++) { _wpa_snprintf_hex(output, 50, buf + i * 16, 16, 0, 1); wpa_printf(level, "%s", output); }{...} if (len % 16) { int bytes_printed = (len / 16) * 16; _wpa_snprintf_hex(output, 50, buf + bytes_printed, len - bytes_printed, 0, 1); wpa_printf(level, "%s", output); }{...} }{...} /* ... */#endif }{...} void wpa_hexdump_key(int level, const char *title, const u8 *buf, size_t len) { wpa_hexdump(level, title, buf, len); }{...} /* ... */#endif /* ... */ #endif // ESP_SUPPLICANT
Details