Commit b57c1a56 authored by Johan Hedberg's avatar Johan Hedberg

Bluetooth: Convert inquiry cache to use standard list types

This makes it possible to use the convenience functions provided for
standard kernel list types and it also makes it easier to extend the use
of the cache for the management interface where e.g. name resolving
control will be needed.
Signed-off-by: default avatarJohan Hedberg <johan.hedberg@intel.com>
Acked-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent 12325280
...@@ -44,14 +44,14 @@ struct inquiry_data { ...@@ -44,14 +44,14 @@ struct inquiry_data {
}; };
struct inquiry_entry { struct inquiry_entry {
struct inquiry_entry *next; struct list_head list;
__u32 timestamp; __u32 timestamp;
struct inquiry_data data; struct inquiry_data data;
}; };
struct inquiry_cache { struct inquiry_cache {
struct list_head list;
__u32 timestamp; __u32 timestamp;
struct inquiry_entry *list;
}; };
struct hci_conn_hash { struct hci_conn_hash {
...@@ -350,14 +350,12 @@ extern int sco_recv_scodata(struct hci_conn *hcon, struct sk_buff *skb); ...@@ -350,14 +350,12 @@ extern int sco_recv_scodata(struct hci_conn *hcon, struct sk_buff *skb);
static inline void inquiry_cache_init(struct hci_dev *hdev) static inline void inquiry_cache_init(struct hci_dev *hdev)
{ {
struct inquiry_cache *c = &hdev->inq_cache; INIT_LIST_HEAD(&hdev->inq_cache.list);
c->list = NULL;
} }
static inline int inquiry_cache_empty(struct hci_dev *hdev) static inline int inquiry_cache_empty(struct hci_dev *hdev)
{ {
struct inquiry_cache *c = &hdev->inq_cache; return list_empty(&hdev->inq_cache.list);
return c->list == NULL;
} }
static inline long inquiry_cache_age(struct hci_dev *hdev) static inline long inquiry_cache_age(struct hci_dev *hdev)
......
...@@ -357,15 +357,11 @@ struct hci_dev *hci_dev_get(int index) ...@@ -357,15 +357,11 @@ struct hci_dev *hci_dev_get(int index)
/* ---- Inquiry support ---- */ /* ---- Inquiry support ---- */
static void inquiry_cache_flush(struct hci_dev *hdev) static void inquiry_cache_flush(struct hci_dev *hdev)
{ {
struct inquiry_cache *cache = &hdev->inq_cache; struct inquiry_entry *p, *n;
struct inquiry_entry *next = cache->list, *e;
BT_DBG("cache %p", cache);
cache->list = NULL; list_for_each_entry_safe(p, n, &hdev->inq_cache.list, list) {
while ((e = next)) { list_del(&p->list);
next = e->next; kfree(p);
kfree(e);
} }
} }
...@@ -376,10 +372,12 @@ struct inquiry_entry *hci_inquiry_cache_lookup(struct hci_dev *hdev, bdaddr_t *b ...@@ -376,10 +372,12 @@ struct inquiry_entry *hci_inquiry_cache_lookup(struct hci_dev *hdev, bdaddr_t *b
BT_DBG("cache %p, %s", cache, batostr(bdaddr)); BT_DBG("cache %p, %s", cache, batostr(bdaddr));
for (e = cache->list; e; e = e->next) list_for_each_entry(e, &cache->list, list) {
if (!bacmp(&e->data.bdaddr, bdaddr)) if (!bacmp(&e->data.bdaddr, bdaddr))
break;
return e; return e;
}
return NULL;
} }
void hci_inquiry_cache_update(struct hci_dev *hdev, struct inquiry_data *data) void hci_inquiry_cache_update(struct hci_dev *hdev, struct inquiry_data *data)
...@@ -396,8 +394,7 @@ void hci_inquiry_cache_update(struct hci_dev *hdev, struct inquiry_data *data) ...@@ -396,8 +394,7 @@ void hci_inquiry_cache_update(struct hci_dev *hdev, struct inquiry_data *data)
if (!ie) if (!ie)
return; return;
ie->next = cache->list; list_add(&ie->list, &cache->list);
cache->list = ie;
} }
memcpy(&ie->data, data, sizeof(*data)); memcpy(&ie->data, data, sizeof(*data));
...@@ -412,15 +409,21 @@ static int inquiry_cache_dump(struct hci_dev *hdev, int num, __u8 *buf) ...@@ -412,15 +409,21 @@ static int inquiry_cache_dump(struct hci_dev *hdev, int num, __u8 *buf)
struct inquiry_entry *e; struct inquiry_entry *e;
int copied = 0; int copied = 0;
for (e = cache->list; e && copied < num; e = e->next, copied++) { list_for_each_entry(e, &cache->list, list) {
struct inquiry_data *data = &e->data; struct inquiry_data *data = &e->data;
if (copied >= num)
break;
bacpy(&info->bdaddr, &data->bdaddr); bacpy(&info->bdaddr, &data->bdaddr);
info->pscan_rep_mode = data->pscan_rep_mode; info->pscan_rep_mode = data->pscan_rep_mode;
info->pscan_period_mode = data->pscan_period_mode; info->pscan_period_mode = data->pscan_period_mode;
info->pscan_mode = data->pscan_mode; info->pscan_mode = data->pscan_mode;
memcpy(info->dev_class, data->dev_class, 3); memcpy(info->dev_class, data->dev_class, 3);
info->clock_offset = data->clock_offset; info->clock_offset = data->clock_offset;
info++; info++;
copied++;
} }
BT_DBG("cache %p, copied %d", cache, copied); BT_DBG("cache %p, copied %d", cache, copied);
......
...@@ -388,7 +388,7 @@ static int inquiry_cache_show(struct seq_file *f, void *p) ...@@ -388,7 +388,7 @@ static int inquiry_cache_show(struct seq_file *f, void *p)
hci_dev_lock(hdev); hci_dev_lock(hdev);
for (e = cache->list; e; e = e->next) { list_for_each_entry(e, &cache->list, list) {
struct inquiry_data *data = &e->data; struct inquiry_data *data = &e->data;
seq_printf(f, "%s %d %d %d 0x%.2x%.2x%.2x 0x%.4x %d %d %u\n", seq_printf(f, "%s %d %d %d 0x%.2x%.2x%.2x 0x%.4x %d %d %u\n",
batostr(&data->bdaddr), batostr(&data->bdaddr),
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment