/* * Copyright (C) 2014 BlueKitchen GmbH * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of the copyright holders nor the names of * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * 4. Any redistribution, use, or modification is done solely for * personal benefit and not for any commercial purpose or for * monetary gain. * * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * Please inquire about commercial licensing options at * contact@bluekitchen-gmbh.com * */ #define BTSTACK_FILE__ "gatt_device_information_query.c" // ***************************************************************************** /* EXAMPLE_START(gatt_device_information_query): GATT Device Information Service Client * * @text This example demonstrates how to use the GATT Device Information Service client to * receive device information such as various IDs and revisions. The example scans * for remote devices and connects to the first found device. If the remote device provides a Device * Information Service, the information is collected and printed in console output, otherwise, * the device will be blacklisted and the scan restarted. */ // ***************************************************************************** #include #include #include #include #include "btstack.h" // gatt_device_information_query.gatt contains the declaration of the provided GATT Services + Characteristics // gatt_device_information_query.h contains the binary representation of gatt_device_information_query.gatt // it is generated by the build system by calling: $BTSTACK_ROOT/tool/compile_gatt.py gatt_device_information_query.gatt gatt_device_information_query.h // it needs to be regenerated when the GATT Database declared in gatt_device_information_query.gatt file is modified #include "gatt_device_information_query.h" typedef struct advertising_report { uint8_t type; uint8_t event_type; uint8_t address_type; bd_addr_t address; uint8_t rssi; uint8_t length; const uint8_t * data; } advertising_report_t; static enum { APP_STATE_IDLE, APP_STATE_W4_SCAN_RESULT, APP_STATE_W4_CONNECT, APP_STATE_CONNECTED } app_state; static int blacklist_index = 0; static bd_addr_t blacklist[20]; static advertising_report_t report; static hci_con_handle_t connection_handle; static bd_addr_t cmdline_addr; static int cmdline_addr_found = 0; static btstack_packet_callback_registration_t hci_event_callback_registration; /* @section Main Application Setup * * @text The Listing MainConfiguration shows how to setup Device Information Service client. * Besides calling init() method for each service, you'll also need to register HCI packet handler * to handle advertisements, as well as connect and disconect events. * * @text Handling of GATT Device Information Service events will be later delegated to a sepparate packet * handler, i.e. gatt_client_event_handler. * * @note There are two additional files associated with this client to allow a remote device to query out GATT database: * - gatt_device_information_query.gatt - contains the declaration of the provided GATT Services and Characteristics. * - gatt_device_information_query.h - contains the binary representation of gatt_device_information_query.gatt. * * gatt_device_information_query.h is generated by the build system by calling: * $BTSTACK_ROOT/tool/compile_gatt.py gatt_device_information_query.gatt gatt_device_information_query.h * This file needs to be regenerated when the GATT Database declared in gatt_device_information_query.gatt file is modified. */ /* LISTING_START(MainConfiguration): Setup Device Information Service Client service */ static void hci_packet_handler(uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size); static void gatt_client_event_handler(uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size); static void device_information_service_client_setup(void){ // Init L2CAP l2cap_init(); // Setup ATT server - only needed if LE Peripheral does ATT queries on its own, e.g. Android phones att_server_init(profile_data, NULL, NULL); // GATT Client setup gatt_client_init(); // Device Information Service Client setup device_information_service_client_init(); sm_init(); sm_set_io_capabilities(IO_CAPABILITY_NO_INPUT_NO_OUTPUT); hci_event_callback_registration.callback = &hci_packet_handler; hci_add_event_handler(&hci_event_callback_registration); } /* LISTING_END */ static int blacklist_size(void){ return sizeof(blacklist) / sizeof(bd_addr_t); } static int blacklist_contains(bd_addr_t addr){ int i; for (i=0; i