3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2025-01-23 20:54:14 +01:00

monitor: Fix encrypted key data pretty printing

If key data is encrypted then print only hexdump. If not pass it to
print_ie (key data may contains other IE elements).
This commit is contained in:
Ravi kumar Veeramally 2015-03-17 16:32:45 +02:00 committed by Denis Kenzior
parent c573abf3f3
commit 8e6bd7d613

View File

@ -3260,13 +3260,13 @@ void nlmon_print_pae(struct nlmon *nlmon, const struct timeval *tv,
print_attr(1, "Secure: %s", ek->secure ? "true" : "false"); print_attr(1, "Secure: %s", ek->secure ? "true" : "false");
print_attr(1, "Error: %s", ek->error ? "true" : "false"); print_attr(1, "Error: %s", ek->error ? "true" : "false");
print_attr(1, "Request: %s", ek->request ? "true" : "false"); print_attr(1, "Request: %s", ek->request ? "true" : "false");
print_attr(1, "Encrypted Ket Data: %s", print_attr(1, "Encrypted Key Data: %s",
ek->encrypted_key_data ? "true" : "false"); ek->encrypted_key_data ? "true" : "false");
print_attr(1, "SMK Message: %s", ek->smk_message ? "true" : "false"); print_attr(1, "SMK Message: %s", ek->smk_message ? "true" : "false");
print_attr(1, "Key Descriptor Version: %d (%02x)", print_attr(1, "Key Descriptor Version: %d (%02x)",
ek->key_descriptor_version, ek->key_descriptor_version,
ek->key_descriptor_version); ek->key_descriptor_version);
print_attr(1, "Ket Type: %s", ek->key_type ? "true" : "false"); print_attr(1, "Key Type: %s", ek->key_type ? "true" : "false");
print_attr(1, "Install: %s", ek->install ? "true" : "false"); print_attr(1, "Install: %s", ek->install ? "true" : "false");
print_attr(1, "Key ACK: %s", ek->key_ack ? "true" : "false"); print_attr(1, "Key ACK: %s", ek->key_ack ? "true" : "false");
print_attr(1, "Key Length: %d", L_BE16_TO_CPU(ek->key_length)); print_attr(1, "Key Length: %d", L_BE16_TO_CPU(ek->key_length));
@ -3280,15 +3280,15 @@ void nlmon_print_pae(struct nlmon *nlmon, const struct timeval *tv,
print_hexdump(2, ek->key_rsc, 8); print_hexdump(2, ek->key_rsc, 8);
print_attr(1, "Key MIC Data"); print_attr(1, "Key MIC Data");
print_hexdump(2, ek->key_mic_data, 16); print_hexdump(2, ek->key_mic_data, 16);
print_attr(1, "Key Data: len %d", L_BE16_TO_CPU(ek->key_data_len));
print_hexdump(2, ek->key_data, L_BE16_TO_CPU(ek->key_data_len));
if (ek->key_data[0] == IE_TYPE_RSN) if (ek->encrypted_key_data) {
print_ie_vendor(1, "RSN", ek->key_data + 2, print_attr(1, "Key Data: len %d",
L_BE16_TO_CPU(ek->key_data_len) - 2); L_BE16_TO_CPU(ek->key_data_len));
else if (ek->key_data[0] == IE_TYPE_VENDOR_SPECIFIC) print_hexdump(2, ek->key_data, L_BE16_TO_CPU(ek->key_data_len));
print_ie_vendor(1, "Vendor Specific", ek->key_data + 2, return;
L_BE16_TO_CPU(ek->key_data_len) - 2); }
print_ie(1, "Key Data", ek->key_data, L_BE16_TO_CPU(ek->key_data_len));
} }
static bool pae_receive(struct l_io *io, void *user_data) static bool pae_receive(struct l_io *io, void *user_data)