14e630824SMatthias Ringwald #include <stdint.h> 24e630824SMatthias Ringwald #include <stdio.h> 34e630824SMatthias Ringwald #include <stdlib.h> 44e630824SMatthias Ringwald #include <string.h> 54e630824SMatthias Ringwald #include <signal.h> 64e630824SMatthias Ringwald 74e630824SMatthias Ringwald #include "btstack_config.h" 84e630824SMatthias Ringwald 94e630824SMatthias Ringwald #include "btstack_debug.h" 104e630824SMatthias Ringwald #include "btstack_event.h" 114e630824SMatthias Ringwald #include "btstack_memory.h" 124e630824SMatthias Ringwald #include "btstack_run_loop.h" 134e630824SMatthias Ringwald #include "btstack_run_loop_windows.h" 144e630824SMatthias Ringwald #include "hci.h" 154e630824SMatthias Ringwald #include "hci_dump.h" 164e630824SMatthias Ringwald #include "hal_led.h" 17422979b1SMatthias Ringwald #include "btstack_link_key_db_fs.h" 18422979b1SMatthias Ringwald 19341c09eeSMatthias Ringwald #include "stdin_support.h" 204e630824SMatthias Ringwald 21422979b1SMatthias Ringwald #include "btstack_chipset_bcm.h" 22422979b1SMatthias Ringwald #include "btstack_chipset_csr.h" 23422979b1SMatthias Ringwald #include "btstack_chipset_cc256x.h" 24422979b1SMatthias Ringwald #include "btstack_chipset_em9301.h" 25422979b1SMatthias Ringwald #include "btstack_chipset_stlc2500d.h" 26422979b1SMatthias Ringwald #include "btstack_chipset_tc3566x.h" 27422979b1SMatthias Ringwald 2827ff675bSMatthias Ringwald int btstack_main(int argc, const char * argv[]); 2927ff675bSMatthias Ringwald 30422979b1SMatthias Ringwald static hci_transport_config_uart_t config = { 31422979b1SMatthias Ringwald HCI_TRANSPORT_CONFIG_UART, 32422979b1SMatthias Ringwald 115200, 33422979b1SMatthias Ringwald 0, // main baudrate 34422979b1SMatthias Ringwald 1, // flow control 35422979b1SMatthias Ringwald NULL, 36422979b1SMatthias Ringwald }; 37422979b1SMatthias Ringwald 38422979b1SMatthias Ringwald int is_bcm; 39422979b1SMatthias Ringwald 404e630824SMatthias Ringwald static int led_state = 0; 41422979b1SMatthias Ringwald 424e630824SMatthias Ringwald void hal_led_toggle(void){ 434e630824SMatthias Ringwald led_state = 1 - led_state; 444e630824SMatthias Ringwald printf("LED State %u\n", led_state); 454e630824SMatthias Ringwald } 464e630824SMatthias Ringwald 4727ff675bSMatthias Ringwald static void sigint_handler(int param){ 4827ff675bSMatthias Ringwald 49341c09eeSMatthias Ringwald // reset even if not setup before 5027ff675bSMatthias Ringwald btstack_stdin_reset(); 51341c09eeSMatthias Ringwald 5227ff675bSMatthias Ringwald log_info(" <= SIGINT received, shutting down..\n"); 5327ff675bSMatthias Ringwald // hci_power_control(HCI_POWER_OFF); 5427ff675bSMatthias Ringwald // hci_close(); 5527ff675bSMatthias Ringwald log_info("Good bye, see you.\n"); 5627ff675bSMatthias Ringwald exit(0); 5727ff675bSMatthias Ringwald } 5827ff675bSMatthias Ringwald 59422979b1SMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration; 60422979b1SMatthias Ringwald 61422979b1SMatthias Ringwald static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){ 62422979b1SMatthias Ringwald if (packet_type != HCI_EVENT_PACKET) return; 63422979b1SMatthias Ringwald switch (hci_event_packet_get_type(packet)){ 64422979b1SMatthias Ringwald case BTSTACK_EVENT_STATE: 65422979b1SMatthias Ringwald if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) break; 66422979b1SMatthias Ringwald printf("BTstack up and running.\n"); 67422979b1SMatthias Ringwald break; 68422979b1SMatthias Ringwald case HCI_EVENT_COMMAND_COMPLETE: 69422979b1SMatthias Ringwald if (HCI_EVENT_IS_COMMAND_COMPLETE(packet, hci_read_local_name)){ 70422979b1SMatthias Ringwald // terminate, name 248 chars 71422979b1SMatthias Ringwald packet[6+248] = 0; 72422979b1SMatthias Ringwald printf("Local name: %s\n", &packet[6]); 73422979b1SMatthias Ringwald if (is_bcm){ 74422979b1SMatthias Ringwald btstack_chipset_bcm_set_device_name((const char *)&packet[6]); 75422979b1SMatthias Ringwald } 76422979b1SMatthias Ringwald } 77422979b1SMatthias Ringwald break; 78422979b1SMatthias Ringwald default: 79422979b1SMatthias Ringwald break; 80422979b1SMatthias Ringwald } 81422979b1SMatthias Ringwald } 82422979b1SMatthias Ringwald 83422979b1SMatthias Ringwald static void use_fast_uart(void){ 84422979b1SMatthias Ringwald printf("Using 921600 baud.\n"); 85422979b1SMatthias Ringwald config.baudrate_main = 921600; 86422979b1SMatthias Ringwald } 87422979b1SMatthias Ringwald 88422979b1SMatthias Ringwald static void local_version_information_callback(uint8_t * packet){ 89422979b1SMatthias Ringwald printf("Local version information:\n"); 90422979b1SMatthias Ringwald uint16_t hci_version = little_endian_read_16(packet, 4); 91422979b1SMatthias Ringwald uint16_t hci_revision = little_endian_read_16(packet, 6); 92422979b1SMatthias Ringwald uint16_t lmp_version = little_endian_read_16(packet, 8); 93422979b1SMatthias Ringwald uint16_t manufacturer = little_endian_read_16(packet, 10); 94422979b1SMatthias Ringwald uint16_t lmp_subversion = little_endian_read_16(packet, 12); 95422979b1SMatthias Ringwald printf("- HCI Version 0x%04x\n", hci_version); 96422979b1SMatthias Ringwald printf("- HCI Revision 0x%04x\n", hci_revision); 97422979b1SMatthias Ringwald printf("- LMP Version 0x%04x\n", lmp_version); 98422979b1SMatthias Ringwald printf("- LMP Revision 0x%04x\n", lmp_subversion); 99422979b1SMatthias Ringwald printf("- Manufacturer 0x%04x\n", manufacturer); 100422979b1SMatthias Ringwald switch (manufacturer){ 101422979b1SMatthias Ringwald case COMPANY_ID_CAMBRIDGE_SILICON_RADIO: 102422979b1SMatthias Ringwald printf("Cambridge Silicon Radio - CSR chipset.\n"); 103422979b1SMatthias Ringwald use_fast_uart(); 104422979b1SMatthias Ringwald hci_set_chipset(btstack_chipset_csr_instance()); 105422979b1SMatthias Ringwald break; 106422979b1SMatthias Ringwald case COMPANY_ID_TEXAS_INSTRUMENTS_INC: 107422979b1SMatthias Ringwald printf("Texas Instruments - CC256x compatible chipset.\n"); 108422979b1SMatthias Ringwald use_fast_uart(); 109422979b1SMatthias Ringwald hci_set_chipset(btstack_chipset_cc256x_instance()); 110422979b1SMatthias Ringwald #ifdef ENABLE_EHCILL 111422979b1SMatthias Ringwald printf("eHCILL enabled.\n"); 112422979b1SMatthias Ringwald #else 113422979b1SMatthias Ringwald printf("eHCILL disable.\n"); 114422979b1SMatthias Ringwald #endif 115422979b1SMatthias Ringwald break; 116422979b1SMatthias Ringwald case COMPANY_ID_BROADCOM_CORPORATION: 117422979b1SMatthias Ringwald printf("Broadcom - using BCM driver.\n"); 118422979b1SMatthias Ringwald hci_set_chipset(btstack_chipset_bcm_instance()); 119422979b1SMatthias Ringwald use_fast_uart(); 120422979b1SMatthias Ringwald is_bcm = 1; 121422979b1SMatthias Ringwald break; 122422979b1SMatthias Ringwald case COMPANY_ID_ST_MICROELECTRONICS: 123422979b1SMatthias Ringwald printf("ST Microelectronics - using STLC2500d driver.\n"); 124422979b1SMatthias Ringwald use_fast_uart(); 125422979b1SMatthias Ringwald hci_set_chipset(btstack_chipset_stlc2500d_instance()); 126422979b1SMatthias Ringwald break; 127422979b1SMatthias Ringwald case COMPANY_ID_EM_MICROELECTRONICS_MARIN: 128422979b1SMatthias Ringwald printf("EM Microelectronics - using EM9301 driver.\n"); 129422979b1SMatthias Ringwald hci_set_chipset(btstack_chipset_em9301_instance()); 130422979b1SMatthias Ringwald break; 131422979b1SMatthias Ringwald case COMPANY_ID_NORDIC_SEMICONDUCTOR_ASA: 132422979b1SMatthias Ringwald printf("Nordic Semiconductor nRF5 chipset.\n"); 133422979b1SMatthias Ringwald break; 134422979b1SMatthias Ringwald default: 135422979b1SMatthias Ringwald printf("Unknown manufacturer / manufacturer not supported yet.\n"); 136422979b1SMatthias Ringwald break; 137422979b1SMatthias Ringwald } 138422979b1SMatthias Ringwald } 139422979b1SMatthias Ringwald 14027ff675bSMatthias Ringwald int main(int argc, const char * argv[]){ 1414e630824SMatthias Ringwald printf("BTstack on windows booting up\n"); 1424e630824SMatthias Ringwald 1434e630824SMatthias Ringwald /// GET STARTED with BTstack /// 1444e630824SMatthias Ringwald btstack_memory_init(); 1454e630824SMatthias Ringwald btstack_run_loop_init(btstack_run_loop_windows_get_instance()); 1464e630824SMatthias Ringwald 147*5096a6aeSMatthias Ringwald hci_dump_open("hci_dump.pklg", HCI_DUMP_PACKETLOGGER); 148422979b1SMatthias Ringwald 149422979b1SMatthias Ringwald // pick serial port 150422979b1SMatthias Ringwald config.device_name = "\\\\.\\COM7"; 151422979b1SMatthias Ringwald 152422979b1SMatthias Ringwald // init HCI 153422979b1SMatthias Ringwald const btstack_uart_block_t * uart_driver = btstack_uart_block_windows_instance(); 154422979b1SMatthias Ringwald const hci_transport_t * transport = hci_transport_h4_instance(uart_driver); 155422979b1SMatthias Ringwald const btstack_link_key_db_t * link_key_db = btstack_link_key_db_fs_instance(); 156422979b1SMatthias Ringwald hci_init(transport, (void*) &config); 157422979b1SMatthias Ringwald hci_set_link_key_db(link_key_db); 158422979b1SMatthias Ringwald 159422979b1SMatthias Ringwald // inform about BTstack state 160422979b1SMatthias Ringwald hci_event_callback_registration.callback = &packet_handler; 161422979b1SMatthias Ringwald hci_add_event_handler(&hci_event_callback_registration); 162422979b1SMatthias Ringwald 163422979b1SMatthias Ringwald // setup dynamic chipset driver setup 164422979b1SMatthias Ringwald hci_set_local_version_information_callback(&local_version_information_callback); 165422979b1SMatthias Ringwald 16627ff675bSMatthias Ringwald // handle CTRL-c 16727ff675bSMatthias Ringwald signal(SIGINT, sigint_handler); 16827ff675bSMatthias Ringwald 16927ff675bSMatthias Ringwald // setup app 17027ff675bSMatthias Ringwald btstack_main(argc, argv); 17127ff675bSMatthias Ringwald 17227ff675bSMatthias Ringwald // go 17327ff675bSMatthias Ringwald btstack_run_loop_execute(); 17427ff675bSMatthias Ringwald 1754e630824SMatthias Ringwald return 0; 1764e630824SMatthias Ringwald } 177