This patch adds support for max_tx_power in Get Connection Information request. Value is read only once for given connection and then always returned in response as parameter. Signed-off-by: Andrzej Kaczmarek <andrzej.kaczmarek@xxxxxxxxx> --- include/net/bluetooth/hci_core.h | 1 + include/net/bluetooth/mgmt.h | 1 + net/bluetooth/hci_conn.c | 1 + net/bluetooth/hci_event.c | 18 +++++++++++++++++- net/bluetooth/mgmt.c | 8 ++++++++ 5 files changed, 28 insertions(+), 1 deletion(-) diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h index a1eb022..b0f958a 100644 --- a/include/net/bluetooth/hci_core.h +++ b/include/net/bluetooth/hci_core.h @@ -379,6 +379,7 @@ struct hci_conn { __u16 le_conn_max_interval; __s8 rssi; __s8 tx_power; + __s8 max_tx_power; unsigned long flags; unsigned long last_info_read; diff --git a/include/net/bluetooth/mgmt.h b/include/net/bluetooth/mgmt.h index c26b7e2..ce7315d 100644 --- a/include/net/bluetooth/mgmt.h +++ b/include/net/bluetooth/mgmt.h @@ -420,6 +420,7 @@ struct mgmt_cp_get_conn_information { struct mgmt_rp_get_conn_information { struct mgmt_addr_info addr; __s8 rssi; + __s8 max_tx_power; __u32 flags; __le16 eir_len; __u8 eir[0]; diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c index 78cfe3b..05125b9 100644 --- a/net/bluetooth/hci_conn.c +++ b/net/bluetooth/hci_conn.c @@ -408,6 +408,7 @@ struct hci_conn *hci_conn_add(struct hci_dev *hdev, int type, bdaddr_t *dst) conn->remote_auth = 0xff; conn->key_type = 0xff; conn->tx_power = HCI_TX_POWER_INVALID; + conn->max_tx_power = HCI_TX_POWER_INVALID; set_bit(HCI_CONN_POWER_SAVE, &conn->flags); conn->disc_timeout = HCI_DISCONN_TIMEOUT; diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c index 0e67c8e..a80b51b 100644 --- a/net/bluetooth/hci_event.c +++ b/net/bluetooth/hci_event.c @@ -1283,9 +1283,25 @@ static void hci_cc_read_tx_power_level(struct hci_dev *hdev, hci_dev_lock(hdev); conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(rp->handle)); - if (conn && sent->type == TX_POWER_TYPE_CURRENT) + if (!conn) + goto unlock; + + switch (sent->type) { + case TX_POWER_TYPE_CURRENT: conn->tx_power = rp->tx_power_level; + break; + + case TX_POWER_TYPE_MAXIMUM: + conn->max_tx_power = rp->tx_power_level; + break; + default: + BT_ERR("Used reserved Read_Transmit_Power_Level param %d", + sent->type); + break; + } + +unlock: hci_dev_unlock(hdev); } diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c index 3f6c81a..81e412f 100644 --- a/net/bluetooth/mgmt.c +++ b/net/bluetooth/mgmt.c @@ -4605,6 +4605,7 @@ static void conn_info_complete(struct pending_cmd *cmd, void *data) } rp->rssi = conn->rssi; + rp->max_tx_power = conn->max_tx_power; if (cp->data_type & MGMT_CONN_INFO_DATA_TX_POWER) { eir_len = eir_append_data(rp->eir, 0, EIR_TX_POWER, @@ -4737,6 +4738,13 @@ static int get_conn_info(struct sock *sk, struct hci_dev *hdev, void *data, sizeof(req_txp_cp), &req_txp_cp); } + if (conn->max_tx_power == HCI_TX_POWER_INVALID) { + req_txp_cp.handle = cpu_to_le16(conn->handle); + req_txp_cp.type = TX_POWER_TYPE_MAXIMUM; + hci_req_add(&req, HCI_OP_READ_TX_POWER_LEVEL, + sizeof(req_txp_cp), &req_txp_cp); + } + err = hci_req_run(&req, conn_info_query_complete); if (err < 0) { hci_conn_drop(conn); -- 1.9.2 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html