From 66657a57069225fb05ede9a5fd61736862c2a997 Mon Sep 17 00:00:00 2001 From: Andrew Zaborowski Date: Wed, 18 Mar 2020 15:45:31 +0100 Subject: [PATCH] p2putil: Tolerate GO Neg Response with empty Channel List Work around a parse error in GO Negotiation with some P2P devices. --- src/p2putil.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/p2putil.c b/src/p2putil.c index 02c02b4d..58a75a11 100644 --- a/src/p2putil.c +++ b/src/p2putil.c @@ -193,7 +193,12 @@ static bool extract_p2p_channel_list(const uint8_t *attr, size_t len, { struct p2p_channel_list_attr *out = data; - if (len < 6) + /* + * Some devices reply with an empty Channel Entry List inside the + * Channel List attribute of a GO Negotiation Response (status 1), + * so tolerate a length of 3. + */ + if (len < 3) return false; out->country[0] = *attr++;