summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/bluetooth/mgmt.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c
index 797cf6cf958f..cc4e76f8be0e 100644
--- a/net/bluetooth/mgmt.c
+++ b/net/bluetooth/mgmt.c
@@ -986,7 +986,13 @@ static u8 create_instance_adv_data(struct hci_dev *hdev, u8 *ptr)
986 if (hdev->adv_instance.flags & MGMT_ADV_FLAG_LIMITED_DISCOV) 986 if (hdev->adv_instance.flags & MGMT_ADV_FLAG_LIMITED_DISCOV)
987 flags |= LE_AD_LIMITED; 987 flags |= LE_AD_LIMITED;
988 988
989 if (flags) { 989 if (flags || (hdev->adv_instance.flags & MGMT_ADV_FLAG_MANAGED_FLAGS)) {
990 /* If a discovery flag wasn't provided, simply use the global
991 * settings.
992 */
993 if (!flags)
994 flags |= get_adv_discov_flags(hdev);
995
990 if (!hci_dev_test_flag(hdev, HCI_BREDR_ENABLED)) 996 if (!hci_dev_test_flag(hdev, HCI_BREDR_ENABLED))
991 flags |= LE_AD_NO_BREDR; 997 flags |= LE_AD_NO_BREDR;
992 998
@@ -6582,7 +6588,8 @@ static bool tlv_data_is_valid(struct hci_dev *hdev, u32 adv_flags, u8 *data,
6582 u8 max_len = HCI_MAX_AD_LENGTH; 6588 u8 max_len = HCI_MAX_AD_LENGTH;
6583 int i, cur_len; 6589 int i, cur_len;
6584 bool flags_managed = false; 6590 bool flags_managed = false;
6585 u32 flags_params = MGMT_ADV_FLAG_DISCOV | MGMT_ADV_FLAG_LIMITED_DISCOV; 6591 u32 flags_params = MGMT_ADV_FLAG_DISCOV | MGMT_ADV_FLAG_LIMITED_DISCOV |
6592 MGMT_ADV_FLAG_MANAGED_FLAGS;
6586 6593
6587 if (is_adv_data && (adv_flags & flags_params)) { 6594 if (is_adv_data && (adv_flags & flags_params)) {
6588 flags_managed = true; 6595 flags_managed = true;