diff options
author | Insun Song <insun.song@broadcom.com> | 2017-05-12 21:39:45 +0000 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2017-05-12 21:39:45 +0000 |
commit | 1eb75189ad0adee020c534f95483d020b2c8e43e (patch) | |
tree | 1df933f69dacda9fa289b68d39f3908c46fe13e5 | |
parent | dddf8f55fc5d965f153550d67cd5bf4e377fdd39 (diff) | |
parent | c9b7625dc090a027ccec387dad4ea7b82ee0d747 (diff) | |
download | wlan-1eb75189ad0adee020c534f95483d020b2c8e43e.tar.gz |
net: wireless: bcmdhd: adding bssid count NL attribute in SWC config am: f57fbe1611 am: 79f1dd5850 am: 2498b6a272 am: 96e0be9043
am: c9b7625dc0
Change-Id: Ib0005b4a0fefb1edf0563eb74aa4053a07425988
-rw-r--r-- | bcmdhd/wifi_hal/gscan.cpp | 48 |
1 files changed, 28 insertions, 20 deletions
diff --git a/bcmdhd/wifi_hal/gscan.cpp b/bcmdhd/wifi_hal/gscan.cpp index 47eea15..d3dc0e7 100644 --- a/bcmdhd/wifi_hal/gscan.cpp +++ b/bcmdhd/wifi_hal/gscan.cpp @@ -1436,30 +1436,38 @@ public: if (result < 0) { return result; } - - struct nlattr * attr = request.attr_start(GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS); - - for (int i = 0; i < mParams.num_bssid; i++) { - nlattr *attr2 = request.attr_start(i); - if (attr2 == NULL) { + result = request.put_u16(GSCAN_ATTRIBUTE_NUM_BSSID, mParams.num_bssid); + if (result < 0) { + return result; + } + if (mParams.num_bssid != 0) { + nlattr* attr = request.attr_start(GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS); + if (attr == NULL) { return WIFI_ERROR_OUT_OF_MEMORY; } - result = request.put_addr(GSCAN_ATTRIBUTE_BSSID, mParams.ap[i].bssid); - if (result < 0) { - return result; - } - result = request.put_u8(GSCAN_ATTRIBUTE_RSSI_HIGH, mParams.ap[i].high); - if (result < 0) { - return result; - } - result = request.put_u8(GSCAN_ATTRIBUTE_RSSI_LOW, mParams.ap[i].low); - if (result < 0) { - return result; + + for (int i = 0; i < mParams.num_bssid; i++) { + nlattr* attr2 = request.attr_start(i); + if (attr2 == NULL) { + return WIFI_ERROR_OUT_OF_MEMORY; + } + result = request.put_addr(GSCAN_ATTRIBUTE_BSSID, mParams.ap[i].bssid); + if (result < 0) { + return result; + } + result = request.put_u8(GSCAN_ATTRIBUTE_RSSI_HIGH, mParams.ap[i].high); + if (result < 0) { + return result; + } + result = request.put_u8(GSCAN_ATTRIBUTE_RSSI_LOW, mParams.ap[i].low); + if (result < 0) { + return result; + } + request.attr_end(attr2); } - request.attr_end(attr2); - } - request.attr_end(attr); + request.attr_end(attr); + } request.attr_end(data); return result; |