From 6f2c0607112354744cec693968f1bb689ffb070f Mon Sep 17 00:00:00 2001 From: Jean-Michel Bachot Date: Sat, 19 Mar 2011 12:16:20 +0200 Subject: P2P: Keep track of peer WPS vendor extensions Make the P2P code keep track of WPS vendor extensions received from peers so they can be exposed via DBus later. Signed-off-by: Jean-Michel Bachot Signed-off-by: Johannes Berg --- src/wps/wps.h | 4 ++++ src/wps/wps_attr_parse.c | 25 +++++++++++++++++++++---- src/wps/wps_i.h | 4 ++++ 3 files changed, 29 insertions(+), 4 deletions(-) (limited to 'src/wps') diff --git a/src/wps/wps.h b/src/wps/wps.h index 8b29982..fc706d9 100644 --- a/src/wps/wps.h +++ b/src/wps/wps.h @@ -66,6 +66,10 @@ struct wps_credential { #define WPS_SEC_DEV_TYPE_MAX_LEN 128 /* maximum number of advertised WPS vendor extension attributes */ #define MAX_WPS_VENDOR_EXTENSIONS 10 +/* maximum size of WPS Vendor extension attribute */ +#define WPS_MAX_VENDOR_EXT_LEN 1024 +/* maximum number of parsed WPS vendor extension attributes */ +#define MAX_WPS_PARSE_VENDOR_EXT 10 /** * struct wps_device_data - WPS Device Data diff --git a/src/wps/wps_attr_parse.c b/src/wps/wps_attr_parse.c index 0c4a4b4..bc3766c 100644 --- a/src/wps/wps_attr_parse.c +++ b/src/wps/wps_attr_parse.c @@ -108,12 +108,29 @@ static int wps_parse_vendor_ext(struct wps_parse_attr *attr, const u8 *pos, switch (vendor_id) { case WPS_VENDOR_ID_WFA: return wps_parse_vendor_ext_wfa(attr, pos + 3, len - 3); - default: - wpa_printf(MSG_MSGDUMP, "WPS: Skip unknown Vendor Extension " - "(Vendor ID %u)", vendor_id); - break; } + /* Handle unknown vendor extensions */ + + wpa_printf(MSG_MSGDUMP, "WPS: Unknown Vendor Extension (Vendor ID %u)", + vendor_id); + + if (len > WPS_MAX_VENDOR_EXT_LEN) { + wpa_printf(MSG_DEBUG, "WPS: Too long Vendor Extension (%u)", + len); + return -1; + } + + if (attr->num_vendor_ext > MAX_WPS_PARSE_VENDOR_EXT) { + wpa_printf(MSG_DEBUG, "WPS: Skipped Vendor Extension " + "attribute (max %d vendor extensions)", + MAX_WPS_PARSE_VENDOR_EXT); + return -1; + } + attr->vendor_ext[attr->num_vendor_ext] = pos; + attr->vendor_ext_len[attr->num_vendor_ext] = len; + attr->num_vendor_ext++; + return 0; } diff --git a/src/wps/wps_i.h b/src/wps/wps_i.h index 827a82a..437999b 100644 --- a/src/wps/wps_i.h +++ b/src/wps/wps_i.h @@ -207,6 +207,10 @@ struct wps_parse_attr { #define MAX_REQ_DEV_TYPE_COUNT 10 const u8 *req_dev_type[MAX_REQ_DEV_TYPE_COUNT]; size_t num_req_dev_type; + + const u8 *vendor_ext[MAX_WPS_PARSE_VENDOR_EXT]; + size_t vendor_ext_len[MAX_WPS_PARSE_VENDOR_EXT]; + size_t num_vendor_ext; }; /* wps_common.c */ -- cgit v1.1