aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/bluetooth/mgmt.c23
1 files changed, 17 insertions, 6 deletions
diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c
index 664dbc4eccbe..17ebaa3b01bb 100644
--- a/net/bluetooth/mgmt.c
+++ b/net/bluetooth/mgmt.c
@@ -4583,12 +4583,13 @@ static void get_conn_info_complete(struct pending_cmd *cmd, void *data)
4583 if (!match->mgmt_status) { 4583 if (!match->mgmt_status) {
4584 rp.rssi = conn->rssi; 4584 rp.rssi = conn->rssi;
4585 4585
4586 if (match->valid_tx_power) 4586 if (match->valid_tx_power) {
4587 rp.tx_power = conn->tx_power; 4587 rp.tx_power = conn->tx_power;
4588 else 4588 rp.max_tx_power = conn->max_tx_power;
4589 } else {
4589 rp.tx_power = HCI_TX_POWER_INVALID; 4590 rp.tx_power = HCI_TX_POWER_INVALID;
4590 4591 rp.max_tx_power = HCI_TX_POWER_INVALID;
4591 rp.max_tx_power = HCI_TX_POWER_INVALID; 4592 }
4592 } 4593 }
4593 4594
4594 cmd_complete(cmd->sk, cmd->index, MGMT_OP_GET_CONN_INFO, 4595 cmd_complete(cmd->sk, cmd->index, MGMT_OP_GET_CONN_INFO,
@@ -4611,7 +4612,9 @@ static void conn_info_refresh_complete(struct hci_dev *hdev, u8 status)
4611 hci_dev_lock(hdev); 4612 hci_dev_lock(hdev);
4612 4613
4613 /* TX power data is valid in case request completed successfully, 4614 /* TX power data is valid in case request completed successfully,
4614 * otherwise we assume it's not valid. 4615 * otherwise we assume it's not valid. At the moment we assume that
4616 * either both or none of current and max values are valid to keep code
4617 * simple.
4615 */ 4618 */
4616 match.valid_tx_power = !status; 4619 match.valid_tx_power = !status;
4617 4620
@@ -4728,6 +4731,14 @@ static int get_conn_info(struct sock *sk, struct hci_dev *hdev, void *data,
4728 sizeof(req_txp_cp), &req_txp_cp); 4731 sizeof(req_txp_cp), &req_txp_cp);
4729 } 4732 }
4730 4733
4734 /* Max TX power needs to be read only once per connection */
4735 if (conn->max_tx_power == HCI_TX_POWER_INVALID) {
4736 req_txp_cp.handle = cpu_to_le16(conn->handle);
4737 req_txp_cp.type = 0x01;
4738 hci_req_add(&req, HCI_OP_READ_TX_POWER,
4739 sizeof(req_txp_cp), &req_txp_cp);
4740 }
4741
4731 err = hci_req_run(&req, conn_info_refresh_complete); 4742 err = hci_req_run(&req, conn_info_refresh_complete);
4732 if (err < 0) 4743 if (err < 0)
4733 goto unlock; 4744 goto unlock;
@@ -4747,7 +4758,7 @@ static int get_conn_info(struct sock *sk, struct hci_dev *hdev, void *data,
4747 /* Cache is valid, just reply with values cached in hci_conn */ 4758 /* Cache is valid, just reply with values cached in hci_conn */
4748 rp.rssi = conn->rssi; 4759 rp.rssi = conn->rssi;
4749 rp.tx_power = conn->tx_power; 4760 rp.tx_power = conn->tx_power;
4750 rp.max_tx_power = HCI_TX_POWER_INVALID; 4761 rp.max_tx_power = conn->max_tx_power;
4751 4762
4752 err = cmd_complete(sk, hdev->id, MGMT_OP_GET_CONN_INFO, 4763 err = cmd_complete(sk, hdev->id, MGMT_OP_GET_CONN_INFO,
4753 MGMT_STATUS_SUCCESS, &rp, sizeof(rp)); 4764 MGMT_STATUS_SUCCESS, &rp, sizeof(rp));