aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSuraj Sumangala <suraj@atheros.com>2010-07-14 03:32:16 -0400
committerMarcel Holtmann <marcel@holtmann.org>2010-07-21 13:39:12 -0400
commitcd4c53919ed50b0d532f106aeb76e79077bece98 (patch)
treedb669259c941d543a12014fc0d69103a4e368cea
parent0a79f67445de50ca0a8dc1d34f3cc406d89c28b2 (diff)
Bluetooth: Add one more buffer for HCI stream reassembly
Additional reassembly buffer to keep track of stream reasembly Signed-off-by: Suraj Sumangala <suraj@atheros.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
-rw-r--r--include/net/bluetooth/hci_core.h4
-rw-r--r--net/bluetooth/hci_core.c6
2 files changed, 5 insertions, 5 deletions
diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h
index 600372d44578..28e5eeefdec8 100644
--- a/include/net/bluetooth/hci_core.h
+++ b/include/net/bluetooth/hci_core.h
@@ -66,7 +66,7 @@ struct bdaddr_list {
66 struct list_head list; 66 struct list_head list;
67 bdaddr_t bdaddr; 67 bdaddr_t bdaddr;
68}; 68};
69 69#define NUM_REASSEMBLY 4
70struct hci_dev { 70struct hci_dev {
71 struct list_head list; 71 struct list_head list;
72 spinlock_t lock; 72 spinlock_t lock;
@@ -123,7 +123,7 @@ struct hci_dev {
123 struct sk_buff_head cmd_q; 123 struct sk_buff_head cmd_q;
124 124
125 struct sk_buff *sent_cmd; 125 struct sk_buff *sent_cmd;
126 struct sk_buff *reassembly[3]; 126 struct sk_buff *reassembly[NUM_REASSEMBLY];
127 127
128 struct mutex req_lock; 128 struct mutex req_lock;
129 wait_queue_head_t req_wait_q; 129 wait_queue_head_t req_wait_q;
diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c
index aeb2982310a0..0ded790bfb67 100644
--- a/net/bluetooth/hci_core.c
+++ b/net/bluetooth/hci_core.c
@@ -914,7 +914,7 @@ int hci_register_dev(struct hci_dev *hdev)
914 skb_queue_head_init(&hdev->cmd_q); 914 skb_queue_head_init(&hdev->cmd_q);
915 skb_queue_head_init(&hdev->raw_q); 915 skb_queue_head_init(&hdev->raw_q);
916 916
917 for (i = 0; i < 3; i++) 917 for (i = 0; i < NUM_REASSEMBLY; i++)
918 hdev->reassembly[i] = NULL; 918 hdev->reassembly[i] = NULL;
919 919
920 init_waitqueue_head(&hdev->req_wait_q); 920 init_waitqueue_head(&hdev->req_wait_q);
@@ -973,7 +973,7 @@ int hci_unregister_dev(struct hci_dev *hdev)
973 973
974 hci_dev_do_close(hdev); 974 hci_dev_do_close(hdev);
975 975
976 for (i = 0; i < 3; i++) 976 for (i = 0; i < NUM_REASSEMBLY; i++)
977 kfree_skb(hdev->reassembly[i]); 977 kfree_skb(hdev->reassembly[i]);
978 978
979 hci_notify(hdev, HCI_DEV_UNREG); 979 hci_notify(hdev, HCI_DEV_UNREG);
@@ -1034,7 +1034,7 @@ int hci_recv_frame(struct sk_buff *skb)
1034EXPORT_SYMBOL(hci_recv_frame); 1034EXPORT_SYMBOL(hci_recv_frame);
1035 1035
1036/* Receive packet type fragment */ 1036/* Receive packet type fragment */
1037#define __reassembly(hdev, type) ((hdev)->reassembly[(type) - 2]) 1037#define __reassembly(hdev, type) ((hdev)->reassembly[(type) - 1])
1038 1038
1039int hci_recv_fragment(struct hci_dev *hdev, int type, void *data, int count) 1039int hci_recv_fragment(struct hci_dev *hdev, int type, void *data, int count)
1040{ 1040{