//***************************************************************************** // // minimal setup for SDP client over USB or UART // //***************************************************************************** #include "config.h" #include #include #include #include #include "sdp_parser.h" #include "sdp_client.h" #include "sdp_query_util.h" #include #include #include "hci.h" #include "btstack_memory.h" #include "hci_dump.h" #include "l2cap.h" #include "sdp_query_util.h" int record_id = -1; int attribute_id = -1; static uint8_t attribute_value[1000]; static const int attribute_value_buffer_size = sizeof(attribute_value); static bd_addr_t remote = {0x04,0x0C,0xCE,0xE4,0x85,0xD3}; static void handle_sdp_client_query_result(sdp_parser_event_t * event); static void packet_handler (void * connection, uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){ printf("packet_handler type %u, packet[0] %x\n", packet_type, packet[0]); if (packet_type != HCI_EVENT_PACKET) return; uint8_t event = packet[0]; switch (event) { case BTSTACK_EVENT_STATE: // bt stack activated, get started if (packet[2] == HCI_STATE_WORKING){ sdp_general_query_for_uuid(remote, 0x1002); } break; default: break; } } static void btstack_setup(){ /// GET STARTED /// btstack_memory_init(); run_loop_init(RUN_LOOP_POSIX); // hci_dump_open("/tmp/hci_dump_sdp_client.pklg", HCI_DUMP_PACKETLOGGER); hci_transport_t * transport = hci_transport_usb_instance(); hci_uart_config_t * config = NULL; bt_control_t * control = NULL; remote_device_db_t * remote_db = (remote_device_db_t *) &remote_device_db_memory; hci_init(transport, config, control, remote_db); printf("Client HCI init done\r\n"); // init L2CAP l2cap_init(); l2cap_register_packet_handler(packet_handler); // turn on! hci_power_control(HCI_POWER_ON); } static void assertBuffer(int size){ if (size > attribute_value_buffer_size){ printf("SDP attribute value buffer size exceeded: available %d, required %d", attribute_value_buffer_size, size); } } static void handle_sdp_client_query_result(sdp_parser_event_t * event){ sdp_parser_attribute_value_event_t * ve; sdp_query_complete_event_t * ce; switch (event->type){ case SDP_QUERY_ATTRIBUTE_VALUE: ve = (sdp_parser_attribute_value_event_t*) event; // handle new record if (ve->record_id != record_id){ record_id = ve->record_id; printf("\n---\nRecord nr. %u\n", record_id); } assertBuffer(ve->attribute_length); attribute_value[ve->data_offset] = ve->data; if ((uint16_t)(ve->data_offset+1) == ve->attribute_length){ printf("Attribute 0x%04x: ", ve->attribute_id); de_dump_data_element(attribute_value); } break; case SDP_QUERY_COMPLETE: ce = (sdp_query_complete_event_t*) event; printf("General query done with status %d.\n\n", ce->status); break; } } int main(void){ sdp_parser_init(); sdp_parser_register_callback(handle_sdp_client_query_result); btstack_setup(); // go! run_loop_execute(); return 0; }