194a5538cSMatthias Ringwald /* 294a5538cSMatthias Ringwald * Copyright (C) 2014 BlueKitchen GmbH 394a5538cSMatthias Ringwald * 494a5538cSMatthias Ringwald * Redistribution and use in source and binary forms, with or without 594a5538cSMatthias Ringwald * modification, are permitted provided that the following conditions 694a5538cSMatthias Ringwald * are met: 794a5538cSMatthias Ringwald * 894a5538cSMatthias Ringwald * 1. Redistributions of source code must retain the above copyright 994a5538cSMatthias Ringwald * notice, this list of conditions and the following disclaimer. 1094a5538cSMatthias Ringwald * 2. Redistributions in binary form must reproduce the above copyright 1194a5538cSMatthias Ringwald * notice, this list of conditions and the following disclaimer in the 1294a5538cSMatthias Ringwald * documentation and/or other materials provided with the distribution. 1394a5538cSMatthias Ringwald * 3. Neither the name of the copyright holders nor the names of 1494a5538cSMatthias Ringwald * contributors may be used to endorse or promote products derived 1594a5538cSMatthias Ringwald * from this software without specific prior written permission. 1694a5538cSMatthias Ringwald * 4. Any redistribution, use, or modification is done solely for 1794a5538cSMatthias Ringwald * personal benefit and not for any commercial purpose or for 1894a5538cSMatthias Ringwald * monetary gain. 1994a5538cSMatthias Ringwald * 2094a5538cSMatthias Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 2194a5538cSMatthias Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 2294a5538cSMatthias Ringwald * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 2394a5538cSMatthias Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS 2494a5538cSMatthias Ringwald * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 2594a5538cSMatthias Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 2694a5538cSMatthias Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 2794a5538cSMatthias Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 2894a5538cSMatthias Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 2994a5538cSMatthias Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 3094a5538cSMatthias Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 3194a5538cSMatthias Ringwald * SUCH DAMAGE. 3294a5538cSMatthias Ringwald * 3394a5538cSMatthias Ringwald * Please inquire about commercial licensing options at 3494a5538cSMatthias Ringwald * [email protected] 3594a5538cSMatthias Ringwald * 3694a5538cSMatthias Ringwald */ 3794a5538cSMatthias Ringwald 3894a5538cSMatthias Ringwald // ***************************************************************************** 3994a5538cSMatthias Ringwald // 4094a5538cSMatthias Ringwald // minimal setup for HCI code 4194a5538cSMatthias Ringwald // 4294a5538cSMatthias Ringwald // ***************************************************************************** 4394a5538cSMatthias Ringwald 4494a5538cSMatthias Ringwald #include <stdint.h> 4594a5538cSMatthias Ringwald #include <stdio.h> 4694a5538cSMatthias Ringwald #include <stdlib.h> 4794a5538cSMatthias Ringwald #include <string.h> 4894a5538cSMatthias Ringwald #include <signal.h> 4994a5538cSMatthias Ringwald 5094a5538cSMatthias Ringwald #include "btstack_config.h" 5194a5538cSMatthias Ringwald 5294a5538cSMatthias Ringwald #include "btstack_debug.h" 5394a5538cSMatthias Ringwald #include "btstack_event.h" 5494a5538cSMatthias Ringwald #include "btstack_link_key_db_fs.h" 5594a5538cSMatthias Ringwald #include "btstack_memory.h" 5694a5538cSMatthias Ringwald #include "btstack_run_loop.h" 5794a5538cSMatthias Ringwald #include "btstack_run_loop_posix.h" 5894a5538cSMatthias Ringwald #include "hci.h" 5994a5538cSMatthias Ringwald #include "hci_dump.h" 6094a5538cSMatthias Ringwald #include "stdin_support.h" 6194a5538cSMatthias Ringwald 6294a5538cSMatthias Ringwald #include "btstack_chipset_bcm.h" 6394a5538cSMatthias Ringwald #include "btstack_chipset_csr.h" 6494a5538cSMatthias Ringwald #include "btstack_chipset_cc256x.h" 6594a5538cSMatthias Ringwald #include "btstack_chipset_em9301.h" 6694a5538cSMatthias Ringwald #include "btstack_chipset_stlc2500d.h" 6794a5538cSMatthias Ringwald #include "btstack_chipset_tc3566x.h" 6894a5538cSMatthias Ringwald 6994a5538cSMatthias Ringwald int btstack_main(int argc, const char * argv[]); 7094a5538cSMatthias Ringwald 7194a5538cSMatthias Ringwald static hci_transport_config_uart_t config = { 7294a5538cSMatthias Ringwald HCI_TRANSPORT_CONFIG_UART, 7394a5538cSMatthias Ringwald 115200, 7494a5538cSMatthias Ringwald 0, // main baudrate 7594a5538cSMatthias Ringwald 1, // flow control 7694a5538cSMatthias Ringwald NULL, 7794a5538cSMatthias Ringwald }; 7894a5538cSMatthias Ringwald 7994a5538cSMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration; 8094a5538cSMatthias Ringwald 8194a5538cSMatthias Ringwald static void sigint_handler(int param){ 8294a5538cSMatthias Ringwald 8394a5538cSMatthias Ringwald #ifndef _WIN32 8494a5538cSMatthias Ringwald // reset anyway 8594a5538cSMatthias Ringwald btstack_stdin_reset(); 8694a5538cSMatthias Ringwald #endif 8794a5538cSMatthias Ringwald 8894a5538cSMatthias Ringwald log_info(" <= SIGINT received, shutting down..\n"); 8994a5538cSMatthias Ringwald hci_power_control(HCI_POWER_OFF); 9094a5538cSMatthias Ringwald hci_close(); 9194a5538cSMatthias Ringwald log_info("Good bye, see you.\n"); 9294a5538cSMatthias Ringwald exit(0); 9394a5538cSMatthias Ringwald } 9494a5538cSMatthias Ringwald 9594a5538cSMatthias Ringwald static int led_state = 0; 9694a5538cSMatthias Ringwald void hal_led_toggle(void){ 9794a5538cSMatthias Ringwald led_state = 1 - led_state; 9894a5538cSMatthias Ringwald printf("LED State %u\n", led_state); 9994a5538cSMatthias Ringwald } 10094a5538cSMatthias Ringwald static void use_fast_uart(void){ 10194a5538cSMatthias Ringwald // printf("Using 921600 baud.\n"); 10294a5538cSMatthias Ringwald // config.baudrate_main = 921600; 10394a5538cSMatthias Ringwald } 10494a5538cSMatthias Ringwald 10594a5538cSMatthias Ringwald static void local_version_information_callback(uint8_t * packet){ 10694a5538cSMatthias Ringwald printf("Local version information:\n"); 10794a5538cSMatthias Ringwald uint16_t hci_version = little_endian_read_16(packet, 4); 10894a5538cSMatthias Ringwald uint16_t hci_revision = little_endian_read_16(packet, 6); 10994a5538cSMatthias Ringwald uint16_t lmp_version = little_endian_read_16(packet, 8); 11094a5538cSMatthias Ringwald uint16_t manufacturer = little_endian_read_16(packet, 10); 11194a5538cSMatthias Ringwald uint16_t lmp_subversion = little_endian_read_16(packet, 12); 11294a5538cSMatthias Ringwald printf("- HCI Version 0x%04x\n", hci_version); 11394a5538cSMatthias Ringwald printf("- HCI Revision 0x%04x\n", hci_revision); 11494a5538cSMatthias Ringwald printf("- LMP Version 0x%04x\n", lmp_version); 11594a5538cSMatthias Ringwald printf("- LMP Revision 0x%04x\n", lmp_subversion); 11694a5538cSMatthias Ringwald printf("- Manufacturer 0x%04x\n", manufacturer); 11794a5538cSMatthias Ringwald switch (manufacturer){ 11894a5538cSMatthias Ringwald case COMPANY_ID_CAMBRIDGE_SILICON_RADIO: 11994a5538cSMatthias Ringwald printf("Cambridge Silicon Radio CSR chipset.\n"); 12094a5538cSMatthias Ringwald use_fast_uart(); 12194a5538cSMatthias Ringwald hci_set_chipset(btstack_chipset_csr_instance()); 12294a5538cSMatthias Ringwald break; 12394a5538cSMatthias Ringwald case COMPANY_ID_TEXAS_INSTRUMENTS_INC: 12494a5538cSMatthias Ringwald printf("Texas Instruments - CC256x compatible chipset.\n"); 12594a5538cSMatthias Ringwald use_fast_uart(); 12694a5538cSMatthias Ringwald hci_set_chipset(btstack_chipset_cc256x_instance()); 12794a5538cSMatthias Ringwald break; 12894a5538cSMatthias Ringwald case COMPANY_ID_BROADCOM_CORPORATION: 12994a5538cSMatthias Ringwald printf("Broadcom chipset. Not supported yet\n"); 13094a5538cSMatthias Ringwald // hci_set_chipset(btstack_chipset_bcm_instance()); 13194a5538cSMatthias Ringwald break; 13294a5538cSMatthias Ringwald case COMPANY_ID_ST_MICROELECTRONICS: 13394a5538cSMatthias Ringwald printf("ST Microelectronics - using STLC2500d driver.\n"); 13494a5538cSMatthias Ringwald use_fast_uart(); 13594a5538cSMatthias Ringwald hci_set_chipset(btstack_chipset_stlc2500d_instance()); 13694a5538cSMatthias Ringwald break; 13794a5538cSMatthias Ringwald case COMPANY_ID_EM_MICROELECTRONICS_MARIN: 13894a5538cSMatthias Ringwald printf("EM Microelectronics - using EM9301 driver.\n"); 13994a5538cSMatthias Ringwald hci_set_chipset(btstack_chipset_em9301_instance()); 14094a5538cSMatthias Ringwald break; 14194a5538cSMatthias Ringwald default: 14294a5538cSMatthias Ringwald printf("Unknown manufacturer / manufacturer not supported yet.\n"); 14394a5538cSMatthias Ringwald break; 14494a5538cSMatthias Ringwald } 14594a5538cSMatthias Ringwald } 14694a5538cSMatthias Ringwald 14794a5538cSMatthias Ringwald static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){ 14894a5538cSMatthias Ringwald if (packet_type != HCI_EVENT_PACKET) return; 14994a5538cSMatthias Ringwald if (hci_event_packet_get_type(packet) != BTSTACK_EVENT_STATE) return; 15094a5538cSMatthias Ringwald if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return; 15194a5538cSMatthias Ringwald printf("BTstack up and running.\n"); 15294a5538cSMatthias Ringwald } 15394a5538cSMatthias Ringwald 15494a5538cSMatthias Ringwald 15594a5538cSMatthias Ringwald int main(int argc, const char * argv[]){ 15694a5538cSMatthias Ringwald 15794a5538cSMatthias Ringwald /// GET STARTED with BTstack /// 15894a5538cSMatthias Ringwald btstack_memory_init(); 15994a5538cSMatthias Ringwald btstack_run_loop_init(btstack_run_loop_posix_get_instance()); 16094a5538cSMatthias Ringwald 16194a5538cSMatthias Ringwald // use logger: format HCI_DUMP_PACKETLOGGER, HCI_DUMP_BLUEZ or HCI_DUMP_STDOUT 16294a5538cSMatthias Ringwald hci_dump_open("/tmp/hci_dump.pklg", HCI_DUMP_PACKETLOGGER); 16394a5538cSMatthias Ringwald 16494a5538cSMatthias Ringwald // pick serial port 16594a5538cSMatthias Ringwald config.device_name = "/dev/tty.usbserial-A900K0VK"; 16694a5538cSMatthias Ringwald 16794a5538cSMatthias Ringwald // init HCI 16894a5538cSMatthias Ringwald const btstack_uart_block_t * uart_driver = btstack_uart_block_posix_instance(); 16994a5538cSMatthias Ringwald const hci_transport_t * transport = hci_transport_h5_instance(uart_driver); 17094a5538cSMatthias Ringwald const btstack_link_key_db_t * link_key_db = btstack_link_key_db_fs_instance(); 17194a5538cSMatthias Ringwald hci_init(transport, (void*) &config); 17294a5538cSMatthias Ringwald hci_set_link_key_db(link_key_db); 17394a5538cSMatthias Ringwald 174*4b871b9eSMatthias Ringwald // enable auto-sleep mode 175*4b871b9eSMatthias Ringwald // hci_transport_h5_set_auto_sleep(300); 176*4b871b9eSMatthias Ringwald 17794a5538cSMatthias Ringwald // setup dynamic chipset driver setup 17894a5538cSMatthias Ringwald hci_set_local_version_information_callback(&local_version_information_callback); 17994a5538cSMatthias Ringwald 18094a5538cSMatthias Ringwald // register for HCI events 18194a5538cSMatthias Ringwald hci_event_callback_registration.callback = &packet_handler; 18294a5538cSMatthias Ringwald hci_add_event_handler(&hci_event_callback_registration); 18394a5538cSMatthias Ringwald 18494a5538cSMatthias Ringwald // handle CTRL-c 18594a5538cSMatthias Ringwald signal(SIGINT, sigint_handler); 18694a5538cSMatthias Ringwald 18794a5538cSMatthias Ringwald // setup app 18894a5538cSMatthias Ringwald btstack_main(argc, argv); 18994a5538cSMatthias Ringwald 19094a5538cSMatthias Ringwald // go 19194a5538cSMatthias Ringwald btstack_run_loop_execute(); 19294a5538cSMatthias Ringwald 19394a5538cSMatthias Ringwald return 0; 19494a5538cSMatthias Ringwald } 195