18caefee3SMatthias Ringwald /* 28caefee3SMatthias Ringwald * Copyright (C) 2014 BlueKitchen GmbH 38caefee3SMatthias Ringwald * 48caefee3SMatthias Ringwald * Redistribution and use in source and binary forms, with or without 58caefee3SMatthias Ringwald * modification, are permitted provided that the following conditions 68caefee3SMatthias Ringwald * are met: 78caefee3SMatthias Ringwald * 88caefee3SMatthias Ringwald * 1. Redistributions of source code must retain the above copyright 98caefee3SMatthias Ringwald * notice, this list of conditions and the following disclaimer. 108caefee3SMatthias Ringwald * 2. Redistributions in binary form must reproduce the above copyright 118caefee3SMatthias Ringwald * notice, this list of conditions and the following disclaimer in the 128caefee3SMatthias Ringwald * documentation and/or other materials provided with the distribution. 138caefee3SMatthias Ringwald * 3. Neither the name of the copyright holders nor the names of 148caefee3SMatthias Ringwald * contributors may be used to endorse or promote products derived 158caefee3SMatthias Ringwald * from this software without specific prior written permission. 168caefee3SMatthias Ringwald * 4. Any redistribution, use, or modification is done solely for 178caefee3SMatthias Ringwald * personal benefit and not for any commercial purpose or for 188caefee3SMatthias Ringwald * monetary gain. 198caefee3SMatthias Ringwald * 208caefee3SMatthias Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 218caefee3SMatthias Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 228caefee3SMatthias Ringwald * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 238caefee3SMatthias Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS 248caefee3SMatthias Ringwald * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 258caefee3SMatthias Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 268caefee3SMatthias Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 278caefee3SMatthias Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 288caefee3SMatthias Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 298caefee3SMatthias Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 308caefee3SMatthias Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 318caefee3SMatthias Ringwald * SUCH DAMAGE. 328caefee3SMatthias Ringwald * 338caefee3SMatthias Ringwald * Please inquire about commercial licensing options at 348caefee3SMatthias Ringwald * [email protected] 358caefee3SMatthias Ringwald * 368caefee3SMatthias Ringwald */ 378caefee3SMatthias Ringwald 388caefee3SMatthias Ringwald // ***************************************************************************** 398caefee3SMatthias Ringwald // 408caefee3SMatthias Ringwald // minimal setup for HCI code 418caefee3SMatthias Ringwald // 428caefee3SMatthias Ringwald // ***************************************************************************** 438caefee3SMatthias Ringwald 448caefee3SMatthias Ringwald #include <stdint.h> 458caefee3SMatthias Ringwald #include <stdio.h> 468caefee3SMatthias Ringwald #include <stdlib.h> 478caefee3SMatthias Ringwald #include <string.h> 488caefee3SMatthias Ringwald #include <signal.h> 498caefee3SMatthias Ringwald 507907f069SMatthias Ringwald #include "btstack_config.h" 518caefee3SMatthias Ringwald 5216ece135SMatthias Ringwald #include "btstack_debug.h" 53e392c21bSMatthias Ringwald #include "btstack_event.h" 5454b584ffSMatthias Ringwald #include "btstack_link_key_db_fs.h" 5554b584ffSMatthias Ringwald #include "btstack_memory.h" 5682636622SMatthias Ringwald #include "btstack_run_loop.h" 578f2a52f4SMatthias Ringwald #include "btstack_run_loop_posix.h" 5854b584ffSMatthias Ringwald #include "hci.h" 5954b584ffSMatthias Ringwald #include "hci_dump.h" 608caefee3SMatthias Ringwald #include "stdin_support.h" 618caefee3SMatthias Ringwald 62c0cdcfe7SMatthias Ringwald #include "btstack_chipset_bcm.h" 63c0cdcfe7SMatthias Ringwald #include "btstack_chipset_csr.h" 64c0cdcfe7SMatthias Ringwald #include "btstack_chipset_cc256x.h" 65c0cdcfe7SMatthias Ringwald #include "btstack_chipset_em9301.h" 66c0cdcfe7SMatthias Ringwald #include "btstack_chipset_stlc2500d.h" 67c0cdcfe7SMatthias Ringwald #include "btstack_chipset_tc3566x.h" 68c0cdcfe7SMatthias Ringwald 698caefee3SMatthias Ringwald int btstack_main(int argc, const char * argv[]); 708caefee3SMatthias Ringwald 719796ebeaSMatthias Ringwald static hci_transport_config_uart_t config = { 729796ebeaSMatthias Ringwald HCI_TRANSPORT_CONFIG_UART, 738caefee3SMatthias Ringwald 115200, 749796ebeaSMatthias Ringwald 0, // main baudrate 759796ebeaSMatthias Ringwald 1, // flow control 769796ebeaSMatthias Ringwald NULL, 778caefee3SMatthias Ringwald }; 788caefee3SMatthias Ringwald 79d356a6daSMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration; 80d356a6daSMatthias Ringwald 81d356a6daSMatthias Ringwald static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){ 82d356a6daSMatthias Ringwald if (packet_type != HCI_EVENT_PACKET) return; 83d356a6daSMatthias Ringwald if (hci_event_packet_get_type(packet) != BTSTACK_EVENT_STATE) return; 84d356a6daSMatthias Ringwald if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return; 85d356a6daSMatthias Ringwald printf("BTstack up and running.\n"); 86d356a6daSMatthias Ringwald } 87d356a6daSMatthias Ringwald 888caefee3SMatthias Ringwald static void sigint_handler(int param){ 898caefee3SMatthias Ringwald 908caefee3SMatthias Ringwald #ifndef _WIN32 918caefee3SMatthias Ringwald // reset anyway 928caefee3SMatthias Ringwald btstack_stdin_reset(); 938caefee3SMatthias Ringwald #endif 948caefee3SMatthias Ringwald 958caefee3SMatthias Ringwald log_info(" <= SIGINT received, shutting down..\n"); 968caefee3SMatthias Ringwald hci_power_control(HCI_POWER_OFF); 978caefee3SMatthias Ringwald hci_close(); 988caefee3SMatthias Ringwald log_info("Good bye, see you.\n"); 998caefee3SMatthias Ringwald exit(0); 1008caefee3SMatthias Ringwald } 1018caefee3SMatthias Ringwald 1028caefee3SMatthias Ringwald static int led_state = 0; 1038caefee3SMatthias Ringwald void hal_led_toggle(void){ 1048caefee3SMatthias Ringwald led_state = 1 - led_state; 1058caefee3SMatthias Ringwald printf("LED State %u\n", led_state); 1068caefee3SMatthias Ringwald } 1073250103aSMatthias Ringwald static void use_fast_uart(void){ 108615ae444SMatthias Ringwald #if defined(HAVE_POSIX_B240000_MAPPED_TO_3000000) || defined(HAVE_POSIX_B600_MAPPED_TO_3000000) 1093250103aSMatthias Ringwald printf("Using 3000000 baud.\n"); 1103250103aSMatthias Ringwald config.baudrate_main = 3000000; 111615ae444SMatthias Ringwald #elif defined(HAVE_POSIX_B1200_MAPPED_TO_2000000) || defined(HAVE_POSIX_B300_MAPPED_TO_2000000) 1123250103aSMatthias Ringwald printf("Using 2000000 baud.\n"); 1133250103aSMatthias Ringwald config.baudrate_main = 2000000; 1143250103aSMatthias Ringwald #else 1152c2bf480SMatthias Ringwald printf("Using 921600 baud.\n"); 1162c2bf480SMatthias Ringwald config.baudrate_main = 921600; 1173250103aSMatthias Ringwald #endif 1182c2bf480SMatthias Ringwald } 1198caefee3SMatthias Ringwald 120a6ddbcb9SMatthias Ringwald static void local_version_information_callback(uint8_t * packet){ 121c0cdcfe7SMatthias Ringwald printf("Local version information:\n"); 122f8fbdce0SMatthias Ringwald uint16_t hci_version = little_endian_read_16(packet, 4); 123f8fbdce0SMatthias Ringwald uint16_t hci_revision = little_endian_read_16(packet, 6); 124f8fbdce0SMatthias Ringwald uint16_t lmp_version = little_endian_read_16(packet, 8); 125f8fbdce0SMatthias Ringwald uint16_t manufacturer = little_endian_read_16(packet, 10); 126f8fbdce0SMatthias Ringwald uint16_t lmp_subversion = little_endian_read_16(packet, 12); 127c0cdcfe7SMatthias Ringwald printf("- HCI Version 0x%04x\n", hci_version); 128c0cdcfe7SMatthias Ringwald printf("- HCI Revision 0x%04x\n", hci_revision); 129c0cdcfe7SMatthias Ringwald printf("- LMP Version 0x%04x\n", lmp_version); 130c0cdcfe7SMatthias Ringwald printf("- LMP Revision 0x%04x\n", lmp_subversion); 131c0cdcfe7SMatthias Ringwald printf("- Manufacturer 0x%04x\n", manufacturer); 132c0cdcfe7SMatthias Ringwald switch (manufacturer){ 133c0cdcfe7SMatthias Ringwald case COMPANY_ID_CAMBRIDGE_SILICON_RADIO: 134c0cdcfe7SMatthias Ringwald printf("Cambridge Silicon Radio CSR chipset.\n"); 1353250103aSMatthias Ringwald use_fast_uart(); 136c0cdcfe7SMatthias Ringwald hci_set_chipset(btstack_chipset_csr_instance()); 137c0cdcfe7SMatthias Ringwald break; 138c0cdcfe7SMatthias Ringwald case COMPANY_ID_TEXAS_INSTRUMENTS_INC: 139c0cdcfe7SMatthias Ringwald printf("Texas Instruments - CC256x compatible chipset.\n"); 1403250103aSMatthias Ringwald use_fast_uart(); 141c0cdcfe7SMatthias Ringwald hci_set_chipset(btstack_chipset_cc256x_instance()); 142f6a20ec9SMatthias Ringwald #ifdef ENABLE_EHCILL 143f6a20ec9SMatthias Ringwald printf("eHCILL enabled.\n"); 144*8c768b83SMatthias Ringwald #else 145*8c768b83SMatthias Ringwald printf("eHCILL disable.\n"); 1468a23fc53SMatthias Ringwald #endif 147c0cdcfe7SMatthias Ringwald break; 148c0cdcfe7SMatthias Ringwald case COMPANY_ID_BROADCOM_CORPORATION: 149c0cdcfe7SMatthias Ringwald printf("Broadcom chipset. Not supported yet\n"); 150c0cdcfe7SMatthias Ringwald // hci_set_chipset(btstack_chipset_bcm_instance()); 151c0cdcfe7SMatthias Ringwald break; 152c0cdcfe7SMatthias Ringwald case COMPANY_ID_ST_MICROELECTRONICS: 153c0cdcfe7SMatthias Ringwald printf("ST Microelectronics - using STLC2500d driver.\n"); 1543250103aSMatthias Ringwald use_fast_uart(); 155c0cdcfe7SMatthias Ringwald hci_set_chipset(btstack_chipset_stlc2500d_instance()); 156c0cdcfe7SMatthias Ringwald break; 157c0cdcfe7SMatthias Ringwald case COMPANY_ID_EM_MICROELECTRONICS_MARIN: 158c0cdcfe7SMatthias Ringwald printf("EM Microelectronics - using EM9301 driver.\n"); 159c0cdcfe7SMatthias Ringwald hci_set_chipset(btstack_chipset_em9301_instance()); 160c0cdcfe7SMatthias Ringwald break; 161c0cdcfe7SMatthias Ringwald default: 162c0cdcfe7SMatthias Ringwald printf("Unknown manufacturer / manufacturer not supported yet.\n"); 163c0cdcfe7SMatthias Ringwald break; 164c0cdcfe7SMatthias Ringwald } 165c0cdcfe7SMatthias Ringwald } 166c0cdcfe7SMatthias Ringwald 1678caefee3SMatthias Ringwald int main(int argc, const char * argv[]){ 1688caefee3SMatthias Ringwald 1698caefee3SMatthias Ringwald /// GET STARTED with BTstack /// 1708caefee3SMatthias Ringwald btstack_memory_init(); 171528a4a3bSMatthias Ringwald btstack_run_loop_init(btstack_run_loop_posix_get_instance()); 1728caefee3SMatthias Ringwald 1738caefee3SMatthias Ringwald // use logger: format HCI_DUMP_PACKETLOGGER, HCI_DUMP_BLUEZ or HCI_DUMP_STDOUT 1748caefee3SMatthias Ringwald hci_dump_open("/tmp/hci_dump.pklg", HCI_DUMP_PACKETLOGGER); 1758caefee3SMatthias Ringwald 1768caefee3SMatthias Ringwald // pick serial port 177c0cdcfe7SMatthias Ringwald config.device_name = "/dev/tty.usbserial-A900K0VK"; 1788caefee3SMatthias Ringwald 1798caefee3SMatthias Ringwald // init HCI 180084ad01cSMatthias Ringwald const btstack_uart_block_t * uart_driver = btstack_uart_block_posix_instance(); 181084ad01cSMatthias Ringwald const hci_transport_t * transport = hci_transport_h4_instance(uart_driver); 18254b584ffSMatthias Ringwald const btstack_link_key_db_t * link_key_db = btstack_link_key_db_fs_instance(); 1832d5e09d6SMatthias Ringwald hci_init(transport, (void*) &config); 1842d5e09d6SMatthias Ringwald hci_set_link_key_db(link_key_db); 1858caefee3SMatthias Ringwald 186d356a6daSMatthias Ringwald // inform about BTstack state 187d356a6daSMatthias Ringwald hci_event_callback_registration.callback = &packet_handler; 188d356a6daSMatthias Ringwald hci_add_event_handler(&hci_event_callback_registration); 189d356a6daSMatthias Ringwald 190a6ddbcb9SMatthias Ringwald // setup dynamic chipset driver setup 191a6ddbcb9SMatthias Ringwald hci_set_local_version_information_callback(&local_version_information_callback); 192c0cdcfe7SMatthias Ringwald 1938caefee3SMatthias Ringwald // handle CTRL-c 1948caefee3SMatthias Ringwald signal(SIGINT, sigint_handler); 1958caefee3SMatthias Ringwald 1968caefee3SMatthias Ringwald // setup app 1978caefee3SMatthias Ringwald btstack_main(argc, argv); 1988caefee3SMatthias Ringwald 1998caefee3SMatthias Ringwald // go 200528a4a3bSMatthias Ringwald btstack_run_loop_execute(); 2018caefee3SMatthias Ringwald 2028caefee3SMatthias Ringwald return 0; 2038caefee3SMatthias Ringwald } 204