diff options
| author | Max Krasnyansky <maxk@qualcomm.com> | 2002-03-08 21:12:35 +0000 | 
|---|---|---|
| committer | Max Krasnyansky <maxk@qualcomm.com> | 2002-03-08 21:12:35 +0000 | 
| commit | c98b2f82a4e532ca61592b08e3ad60749eb9f8d7 (patch) | |
| tree | 19a3df72d2cd6a8d64b7d98473261c7e07e306a0 /tools/hcisecfilter.c | |
Initial revision
Diffstat (limited to 'tools/hcisecfilter.c')
| -rw-r--r-- | tools/hcisecfilter.c | 79 | 
1 files changed, 79 insertions, 0 deletions
| diff --git a/tools/hcisecfilter.c b/tools/hcisecfilter.c new file mode 100644 index 00000000..bee16df1 --- /dev/null +++ b/tools/hcisecfilter.c @@ -0,0 +1,79 @@ +#include <stdio.h> +#include <sys/socket.h> + +#include <bluetooth/bluetooth.h> +#include <bluetooth/hci.h> +#include <bluetooth/hci_lib.h> + +int main(void) +{ +	uint32_t type_mask; +	uint32_t event_mask[2]; +	uint32_t ocf_mask[4]; + +	// Packet types +	memset((void *)&type_mask, 0, sizeof(type_mask)); +	hci_set_bit(HCI_EVENT_PKT, &type_mask); +	 +	printf("Type mask: { 0x%lx }\n", type_mask);  + +	// Events +	memset((void *)event_mask, 0, sizeof(event_mask)); +	hci_set_bit(EVT_INQUIRY_COMPLETE, event_mask);	 +	hci_set_bit(EVT_INQUIRY_RESULT,   event_mask);	 + +	hci_set_bit(EVT_CONN_COMPLETE, event_mask);	 +	hci_set_bit(EVT_CONN_REQUEST,  event_mask);	 +	hci_set_bit(EVT_DISCONN_COMPLETE, event_mask);	 + +	hci_set_bit(EVT_AUTH_COMPLETE,  event_mask);	 +	hci_set_bit(EVT_ENCRYPT_CHANGE, event_mask);	 + +	hci_set_bit(EVT_CMD_COMPLETE, event_mask); +	hci_set_bit(EVT_CMD_STATUS,   event_mask); + +	hci_set_bit(EVT_READ_REMOTE_FEATURES_COMPLETE, event_mask); +	hci_set_bit(EVT_READ_REMOTE_VERSION_COMPLETE,  event_mask); +	hci_set_bit(EVT_REMOTE_NAME_REQ_COMPLETE,      event_mask); + +	printf("Event mask: { 0x%lx, 0x%lx }\n", event_mask[0], event_mask[1]);  + +	// OGF_LINK_CTL +	memset((void *) ocf_mask, 0, sizeof(ocf_mask)); +	hci_set_bit(OCF_INQUIRY, ocf_mask); +	hci_set_bit(OCF_REMOTE_NAME_REQ, ocf_mask); +	hci_set_bit(OCF_READ_REMOTE_FEATURES, ocf_mask); +	hci_set_bit(OCF_READ_REMOTE_VERSION,  ocf_mask); + +	printf("OGF_LINK_CTL: { 0x%lx, 0x%lx, 0x%lx, 0x%lx }\n", +			ocf_mask[0], ocf_mask[1], ocf_mask[2], ocf_mask[3]);  + +	// OGF_LINK_POLICY +	memset((void *) ocf_mask, 0, sizeof(ocf_mask)); +	hci_set_bit(OCF_ROLE_DISCOVERY,   ocf_mask); +	hci_set_bit(OCF_READ_LINK_POLICY, ocf_mask); + +	printf("OGF_LINK_POLICY: { 0x%lx, 0x%lx, 0x%lx, 0x%lx }\n", +			ocf_mask[0], ocf_mask[1], ocf_mask[2], ocf_mask[3]); + +	// OGF_HOST_CTL +	memset((void *) ocf_mask, 0, sizeof(ocf_mask)); +	hci_set_bit(OCF_READ_AUTH_ENABLE, ocf_mask); +	hci_set_bit(OCF_READ_ENCRYPT_MODE, ocf_mask); +	hci_set_bit(OCF_READ_LOCAL_NAME, ocf_mask); +	hci_set_bit(OCF_READ_CLASS_OF_DEV, ocf_mask); + +	printf("OGF_HOST_CTL: { 0x%lx, 0x%lx, 0x%lx, 0x%lx }\n", +			ocf_mask[0], ocf_mask[1], ocf_mask[2], ocf_mask[3]);  + +	// OGF_INFO_PARAM +	memset((void *) ocf_mask, 0, sizeof(ocf_mask)); +	hci_set_bit(OCF_READ_LOCAL_VERSION, ocf_mask); +	hci_set_bit(OCF_READ_LOCAL_FEATURES, ocf_mask); +	hci_set_bit(OCF_READ_BUFFER_SIZE, ocf_mask); +	hci_set_bit(OCF_READ_BD_ADDR, ocf_mask); +	hci_set_bit(OCF_READ_BD_ADDR, ocf_mask); + +	printf("OGF_INFO_PARAM: { 0x%lx, 0x%lx, 0x%lx, 0x%lx}\n",  +			ocf_mask[0], ocf_mask[1], ocf_mask[2], ocf_mask[3]);  +} | 
