aboutsummaryrefslogtreecommitdiffstats
path: root/net/bluetooth
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2012-03-11 22:27:21 -0400
committerGustavo Padovan <gustavo@padovan.org>2012-05-08 23:41:30 -0400
commit91c4e9b1ac595f83681c9a9de691e0f30eeafb44 (patch)
treea9917d121f19adafb81abf4b7f264f185f60b736 /net/bluetooth
parent6935e0f5181644201894f0b7fbe3d8910c18af05 (diff)
Bluetooth: Add TX power tag to EIR data
The Inquiry Response TX power tag should be added to the Extended Inquiry Data (EIR) as well. Signed-off-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Diffstat (limited to 'net/bluetooth')
-rw-r--r--net/bluetooth/hci_event.c9
-rw-r--r--net/bluetooth/mgmt.c9
2 files changed, 15 insertions, 3 deletions
diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c
index 50ff9a989531..75f01d1b126f 100644
--- a/net/bluetooth/hci_event.c
+++ b/net/bluetooth/hci_event.c
@@ -887,11 +887,14 @@ static void hci_cc_write_inquiry_mode(struct hci_dev *hdev,
887static void hci_cc_read_inq_rsp_tx_power(struct hci_dev *hdev, 887static void hci_cc_read_inq_rsp_tx_power(struct hci_dev *hdev,
888 struct sk_buff *skb) 888 struct sk_buff *skb)
889{ 889{
890 __u8 status = *((__u8 *) skb->data); 890 struct hci_rp_read_inq_rsp_tx_power *rp = (void *) skb->data;
891 891
892 BT_DBG("%s status 0x%x", hdev->name, status); 892 BT_DBG("%s status 0x%x", hdev->name, rp->status);
893
894 if (!rp->status)
895 hdev->inq_tx_power = rp->tx_power;
893 896
894 hci_req_complete(hdev, HCI_OP_READ_INQ_RSP_TX_POWER, status); 897 hci_req_complete(hdev, HCI_OP_READ_INQ_RSP_TX_POWER, rp->status);
895} 898}
896 899
897static void hci_cc_set_event_flt(struct hci_dev *hdev, struct sk_buff *skb) 900static void hci_cc_set_event_flt(struct hci_dev *hdev, struct sk_buff *skb)
diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c
index 4a2fb06226fc..02b89e299ff8 100644
--- a/net/bluetooth/mgmt.c
+++ b/net/bluetooth/mgmt.c
@@ -479,6 +479,15 @@ static void create_eir(struct hci_dev *hdev, u8 *data)
479 ptr += (name_len + 2); 479 ptr += (name_len + 2);
480 } 480 }
481 481
482 if (hdev->inq_tx_power) {
483 ptr[0] = 2;
484 ptr[1] = EIR_TX_POWER;
485 ptr[2] = (u8) hdev->inq_tx_power;
486
487 eir_len += 3;
488 ptr += 3;
489 }
490
482 memset(uuid16_list, 0, sizeof(uuid16_list)); 491 memset(uuid16_list, 0, sizeof(uuid16_list));
483 492
484 /* Group all UUID16 types */ 493 /* Group all UUID16 types */