net: mac802154: Avoid displaying misleading debug information

With DEBUG defined, any frame received will see its MHR fields (fc and
addresses, mainly) being printed in the kernel log buffer,
unconditionally. In most cases this is fine, but in some specific cases
(like Acknowledgment frames, where both the source and destination
addressing fields are omitted), it displays garbage which is
misleading.

Only print the addressing fields when they are present, which clarifies
the logs.

Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
Link: https://lore.kernel.org/r/20220905202724.1322046-1-miquel.raynal@bootlin.com
Signed-off-by: Stefan Schmidt <stefan@datenfreihafen.org>
This commit is contained in:
Miquel Raynal 2022-09-05 22:27:24 +02:00 committed by Stefan Schmidt
parent 0218277df5
commit 3a22550ab5

View File

@ -114,8 +114,10 @@ ieee802154_subif_frame(struct ieee802154_sub_if_data *sdata,
static void static void
ieee802154_print_addr(const char *name, const struct ieee802154_addr *addr) ieee802154_print_addr(const char *name, const struct ieee802154_addr *addr)
{ {
if (addr->mode == IEEE802154_ADDR_NONE) if (addr->mode == IEEE802154_ADDR_NONE) {
pr_debug("%s not present\n", name); pr_debug("%s not present\n", name);
return;
}
pr_debug("%s PAN ID: %04x\n", name, le16_to_cpu(addr->pan_id)); pr_debug("%s PAN ID: %04x\n", name, le16_to_cpu(addr->pan_id));
if (addr->mode == IEEE802154_ADDR_SHORT) { if (addr->mode == IEEE802154_ADDR_SHORT) {