Date: Thu, 16 Apr 2009 13:15:18 +0100 (BST) From: Iain Hibbert <plunky@rya-online.net> To: Maksim Yevmenkin <maksim.yevmenkin@gmail.com> Cc: "freebsd-bluetooth@freebsd.org" <freebsd-bluetooth@freebsd.org> Subject: Re: libhci update Message-ID: <1239884118.412855.3144.nullmailer@galant.ukfsn.org> In-Reply-To: <1239871569.560012.1086.nullmailer@galant.ukfsn.org> References: <49D92E26.2030508@incunabulum.net> <bb4a86c70904061358l3983ed51m11265859a833f202@mail.gmail.com> <49DD40E2.5030403@incunabulum.net> <1239264003.862926.638.nullmailer@galant.ukfsn.org> <bb4a86c70904091013l2d7c2b77ic7f6988e6e7709f2@mail.gmail.com> <49DE4E2F.2000805@incunabulum.net> <bb4a86c70904091337x7061ab5uf57bbaff1d5f3197@mail.gmail.com> <49DE6D42.6000004@incunabulum.net> <bb4a86c70904091537x1c6ec085r877d847268b38d3e@mail.gmail.com> <bb4a86c70904151359y3dcf9627u6f30528f07c7252c@mail.gmail.com> <1239871569.560012.1086.nullmailer@galant.ukfsn.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On Thu, 16 Apr 2009, Iain Hibbert wrote: > +int > +bt_devfilter(int s, struct bt_devfilter const *new, struct bt_devfilter *old) > > And finally, the HCI filter is slightly different in NetBSD (I provided > independent PKT and EVT filters each of 256 bits) and I'm going to think > about that.. Ok, I'm not objecting in priniciple to coupling the two filters together but I think that bt_devfilter should be opaque enough that the API does not depend about its internal structure. Ie, requiring the caller to subtract 1 and manage the bitwise manipulation + f.event_mask |= (1 << (NG_HCI_EVENT_INQUIRY_COMPL - 1)); + f.event_mask |= (1 << (NG_HCI_EVENT_INQUIRY_RESULT - 1)); is too specific and makes the callers somewhat messy. Can we provide some kind of accessor functions to do that? I include below what I used in NetBSD for an example.. Also, at least for events, the full 256 bits is required because there are events such as 0xfe (BT Logo) and 0xff (Vendor) that may currently be returned and the highest value (in 2.1 spec) is 0x3d, dangerously close to the 64 bit limit. Although its not likely that there will be many packet types added, it could be that some manufacturers would introduce custom packet types with similarly high end values.. (eg for private device configuration?) regards, iain /* * HCI socket filter and get/set routines * * for ease of use, we filter 256 possible events/packets */ struct hci_filter { uint32_t mask[8]; /* 256 bits */ }; static __inline void hci_filter_set(uint8_t bit, struct hci_filter *filter) { uint8_t off = bit - 1; off >>= 5; filter->mask[off] |= (1 << ((bit - 1) & 0x1f)); } static __inline void hci_filter_clr(uint8_t bit, struct hci_filter *filter) { uint8_t off = bit - 1; off >>= 5; filter->mask[off] &= ~(1 << ((bit - 1) & 0x1f)); } static __inline int hci_filter_test(uint8_t bit, struct hci_filter *filter) { uint8_t off = bit - 1; off >>= 5; return (filter->mask[off] & (1 << ((bit - 1) & 0x1f))); }
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?1239884118.412855.3144.nullmailer>