aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2014-12-17 12:18:08 -0500
committerJohan Hedberg <johan.hedberg@intel.com>2014-12-17 15:03:49 -0500
commitea8ae2516ac43028a01c40b58ffa80d3b0afb802 (patch)
tree1bf4498f94dcc0e7f0cd2be486da53015c138872
parent65891feac27e26115dc4cce881743a1ac33372df (diff)
Bluetooth: Fix bug with filter in service discovery optimization
The optimization for filtering out extended inquiry results, advertising reports or scan response data based on provided UUID list has a logic bug. In case no match is found in the advertising data, the scan response is ignored and not checked against the filter. This will lead to events being filtered wrongly. Change the code to actually only drop the events when the scan response data is not present. If it is present, it needs to be checked against the provided filter. The patch is a bit more complex than it needs to be. That is because it also fixes this compiler warning that some gcc versions produce. CC net/bluetooth/mgmt.o net/bluetooth/mgmt.c: In function ‘mgmt_device_found’: net/bluetooth/mgmt.c:7028:7: warning: ‘match’ may be used uninitialized in this function [-Wmaybe-uninitialized] bool match; ^ It seems that gcc can not clearly figure out the context of the match variable. So just change the branches for the extended inquiry response and advertising data around so that it is clear. Reported-by: Geert Uytterhoeven <geert@linux-m68k.org> Signed-off-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
-rw-r--r--net/bluetooth/mgmt.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c
index 06c2e652e4b6..693ce8bcd06e 100644
--- a/net/bluetooth/mgmt.c
+++ b/net/bluetooth/mgmt.c
@@ -7081,13 +7081,15 @@ void mgmt_device_found(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 link_type,
7081 * kept and checking possible scan response data 7081 * kept and checking possible scan response data
7082 * will be skipped. 7082 * will be skipped.
7083 */ 7083 */
7084 if (hdev->discovery.uuid_count > 0) { 7084 if (hdev->discovery.uuid_count > 0)
7085 match = eir_has_uuids(eir, eir_len, 7085 match = eir_has_uuids(eir, eir_len,
7086 hdev->discovery.uuid_count, 7086 hdev->discovery.uuid_count,
7087 hdev->discovery.uuids); 7087 hdev->discovery.uuids);
7088 if (!match) 7088 else
7089 return; 7089 match = true;
7090 } 7090
7091 if (!match && !scan_rsp_len)
7092 return;
7091 7093
7092 /* Copy EIR or advertising data into event */ 7094 /* Copy EIR or advertising data into event */
7093 memcpy(ev->eir, eir, eir_len); 7095 memcpy(ev->eir, eir, eir_len);
@@ -7096,8 +7098,10 @@ void mgmt_device_found(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 link_type,
7096 * provided, results with empty EIR or advertising data 7098 * provided, results with empty EIR or advertising data
7097 * should be dropped since they do not match any UUID. 7099 * should be dropped since they do not match any UUID.
7098 */ 7100 */
7099 if (hdev->discovery.uuid_count > 0) 7101 if (hdev->discovery.uuid_count > 0 && !scan_rsp_len)
7100 return; 7102 return;
7103
7104 match = false;
7101 } 7105 }
7102 7106
7103 if (dev_class && !eir_has_data_type(ev->eir, eir_len, EIR_CLASS_OF_DEV)) 7107 if (dev_class && !eir_has_data_type(ev->eir, eir_len, EIR_CLASS_OF_DEV))