diff options
author | Andre Guedes <andre.guedes@openbossa.org> | 2013-03-08 09:20:16 -0500 |
---|---|---|
committer | Gustavo Padovan <gustavo.padovan@collabora.co.uk> | 2013-03-09 15:10:47 -0500 |
commit | 5d73e0342fd9bf500583868906325d42c4d2bf6f (patch) | |
tree | bc438120341f687ff2cd9d6337f59459b1afd6a8 /include/net/bluetooth | |
parent | 920c8300c66566afbf92311152c6e462a310203e (diff) |
Bluetooth: HCI request error handling
When we are building a HCI request with more than one HCI command
and one of the hci_req_add calls fail, we should have some cleanup
routine so the HCI commands already queued on HCI request can be
deleted. Otherwise, we will face some memory leaks issues.
This patch implements the HCI request error handling which is the
following: If a hci_req_add fails, we save the error code in hci_
request. Once hci_req_run is called, we verify the error field. If
it is different from zero, we delete all HCI commands already queued
and return the error code.
Signed-off-by: Andre Guedes <andre.guedes@openbossa.org>
Acked-by: Johan Hedberg <johan.hedberg@intel.com>
Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
Diffstat (limited to 'include/net/bluetooth')
-rw-r--r-- | include/net/bluetooth/hci_core.h | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h index 3a9cbf2b55c0..332ee5099a52 100644 --- a/include/net/bluetooth/hci_core.h +++ b/include/net/bluetooth/hci_core.h | |||
@@ -1042,6 +1042,11 @@ int hci_unregister_cb(struct hci_cb *hcb); | |||
1042 | struct hci_request { | 1042 | struct hci_request { |
1043 | struct hci_dev *hdev; | 1043 | struct hci_dev *hdev; |
1044 | struct sk_buff_head cmd_q; | 1044 | struct sk_buff_head cmd_q; |
1045 | |||
1046 | /* If something goes wrong when building the HCI request, the error | ||
1047 | * value is stored in this field. | ||
1048 | */ | ||
1049 | int err; | ||
1045 | }; | 1050 | }; |
1046 | 1051 | ||
1047 | void hci_req_init(struct hci_request *req, struct hci_dev *hdev); | 1052 | void hci_req_init(struct hci_request *req, struct hci_dev *hdev); |