1*ecde56a6SMatthias Ringwald /* 2*ecde56a6SMatthias Ringwald * Copyright (C) 2014 BlueKitchen GmbH 3*ecde56a6SMatthias Ringwald * 4*ecde56a6SMatthias Ringwald * Redistribution and use in source and binary forms, with or without 5*ecde56a6SMatthias Ringwald * modification, are permitted provided that the following conditions 6*ecde56a6SMatthias Ringwald * are met: 7*ecde56a6SMatthias Ringwald * 8*ecde56a6SMatthias Ringwald * 1. Redistributions of source code must retain the above copyright 9*ecde56a6SMatthias Ringwald * notice, this list of conditions and the following disclaimer. 10*ecde56a6SMatthias Ringwald * 2. Redistributions in binary form must reproduce the above copyright 11*ecde56a6SMatthias Ringwald * notice, this list of conditions and the following disclaimer in the 12*ecde56a6SMatthias Ringwald * documentation and/or other materials provided with the distribution. 13*ecde56a6SMatthias Ringwald * 3. Neither the name of the copyright holders nor the names of 14*ecde56a6SMatthias Ringwald * contributors may be used to endorse or promote products derived 15*ecde56a6SMatthias Ringwald * from this software without specific prior written permission. 16*ecde56a6SMatthias Ringwald * 4. Any redistribution, use, or modification is done solely for 17*ecde56a6SMatthias Ringwald * personal benefit and not for any commercial purpose or for 18*ecde56a6SMatthias Ringwald * monetary gain. 19*ecde56a6SMatthias Ringwald * 20*ecde56a6SMatthias Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 21*ecde56a6SMatthias Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 22*ecde56a6SMatthias Ringwald * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 23*ecde56a6SMatthias Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS 24*ecde56a6SMatthias Ringwald * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 25*ecde56a6SMatthias Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 26*ecde56a6SMatthias Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 27*ecde56a6SMatthias Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 28*ecde56a6SMatthias Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 29*ecde56a6SMatthias Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 30*ecde56a6SMatthias Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31*ecde56a6SMatthias Ringwald * SUCH DAMAGE. 32*ecde56a6SMatthias Ringwald * 33*ecde56a6SMatthias Ringwald * Please inquire about commercial licensing options at 34*ecde56a6SMatthias Ringwald * [email protected] 35*ecde56a6SMatthias Ringwald * 36*ecde56a6SMatthias Ringwald */ 37*ecde56a6SMatthias Ringwald 38*ecde56a6SMatthias Ringwald #define __BTSTACK_FILE__ "main.c" 39*ecde56a6SMatthias Ringwald 40*ecde56a6SMatthias Ringwald // ***************************************************************************** 41*ecde56a6SMatthias Ringwald // 42*ecde56a6SMatthias Ringwald // minimal setup for HCI code 43*ecde56a6SMatthias Ringwald // 44*ecde56a6SMatthias Ringwald // ***************************************************************************** 45*ecde56a6SMatthias Ringwald 46*ecde56a6SMatthias Ringwald #include <stdint.h> 47*ecde56a6SMatthias Ringwald #include <stdio.h> 48*ecde56a6SMatthias Ringwald #include <stdlib.h> 49*ecde56a6SMatthias Ringwald #include <string.h> 50*ecde56a6SMatthias Ringwald #include <signal.h> 51*ecde56a6SMatthias Ringwald 52*ecde56a6SMatthias Ringwald #include "btstack_config.h" 53*ecde56a6SMatthias Ringwald 54*ecde56a6SMatthias Ringwald #include "btstack_debug.h" 55*ecde56a6SMatthias Ringwald #include "btstack_event.h" 56*ecde56a6SMatthias Ringwald #include "btstack_link_key_db_fs.h" 57*ecde56a6SMatthias Ringwald #include "btstack_memory.h" 58*ecde56a6SMatthias Ringwald #include "btstack_run_loop.h" 59*ecde56a6SMatthias Ringwald #include "btstack_run_loop_posix.h" 60*ecde56a6SMatthias Ringwald #include "hci.h" 61*ecde56a6SMatthias Ringwald #include "hci_dump.h" 62*ecde56a6SMatthias Ringwald #include "btstack_stdin.h" 63*ecde56a6SMatthias Ringwald 64*ecde56a6SMatthias Ringwald #include "btstack_chipset_da14581.h" 65*ecde56a6SMatthias Ringwald #include "hci_581_active_uart.h" 66*ecde56a6SMatthias Ringwald 67*ecde56a6SMatthias Ringwald static int main_argc; 68*ecde56a6SMatthias Ringwald static const char ** main_argv; 69*ecde56a6SMatthias Ringwald static const btstack_uart_block_t * uart_driver; 70*ecde56a6SMatthias Ringwald static btstack_uart_config_t uart_config; 71*ecde56a6SMatthias Ringwald 72*ecde56a6SMatthias Ringwald int btstack_main(int argc, const char * argv[]); 73*ecde56a6SMatthias Ringwald 74*ecde56a6SMatthias Ringwald static hci_transport_config_uart_t transport_config = { 75*ecde56a6SMatthias Ringwald HCI_TRANSPORT_CONFIG_UART, 76*ecde56a6SMatthias Ringwald 115200, 77*ecde56a6SMatthias Ringwald 0, // main baudrate 78*ecde56a6SMatthias Ringwald 1, // flow control 79*ecde56a6SMatthias Ringwald NULL, 80*ecde56a6SMatthias Ringwald }; 81*ecde56a6SMatthias Ringwald 82*ecde56a6SMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration; 83*ecde56a6SMatthias Ringwald 84*ecde56a6SMatthias Ringwald static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){ 85*ecde56a6SMatthias Ringwald if (packet_type != HCI_EVENT_PACKET) return; 86*ecde56a6SMatthias Ringwald switch (hci_event_packet_get_type(packet)){ 87*ecde56a6SMatthias Ringwald case BTSTACK_EVENT_STATE: 88*ecde56a6SMatthias Ringwald if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) break; 89*ecde56a6SMatthias Ringwald printf("BTstack up and running.\n"); 90*ecde56a6SMatthias Ringwald break; 91*ecde56a6SMatthias Ringwald default: 92*ecde56a6SMatthias Ringwald break; 93*ecde56a6SMatthias Ringwald } 94*ecde56a6SMatthias Ringwald } 95*ecde56a6SMatthias Ringwald 96*ecde56a6SMatthias Ringwald static void sigint_handler(int param){ 97*ecde56a6SMatthias Ringwald UNUSED(param); 98*ecde56a6SMatthias Ringwald 99*ecde56a6SMatthias Ringwald printf("CTRL-C - SIGINT received, shutting down..\n"); 100*ecde56a6SMatthias Ringwald log_info("sigint_handler: shutting down"); 101*ecde56a6SMatthias Ringwald 102*ecde56a6SMatthias Ringwald // reset anyway 103*ecde56a6SMatthias Ringwald btstack_stdin_reset(); 104*ecde56a6SMatthias Ringwald 105*ecde56a6SMatthias Ringwald // power down 106*ecde56a6SMatthias Ringwald hci_power_control(HCI_POWER_OFF); 107*ecde56a6SMatthias Ringwald hci_close(); 108*ecde56a6SMatthias Ringwald log_info("Good bye, see you.\n"); 109*ecde56a6SMatthias Ringwald exit(0); 110*ecde56a6SMatthias Ringwald } 111*ecde56a6SMatthias Ringwald 112*ecde56a6SMatthias Ringwald static int led_state = 0; 113*ecde56a6SMatthias Ringwald void hal_led_toggle(void){ 114*ecde56a6SMatthias Ringwald led_state = 1 - led_state; 115*ecde56a6SMatthias Ringwald printf("LED State %u\n", led_state); 116*ecde56a6SMatthias Ringwald } 117*ecde56a6SMatthias Ringwald 118*ecde56a6SMatthias Ringwald static void phase2(int status){ 119*ecde56a6SMatthias Ringwald 120*ecde56a6SMatthias Ringwald if (status){ 121*ecde56a6SMatthias Ringwald printf("Download firmware failed\n"); 122*ecde56a6SMatthias Ringwald return; 123*ecde56a6SMatthias Ringwald } 124*ecde56a6SMatthias Ringwald 125*ecde56a6SMatthias Ringwald printf("Phase 2: Main app\n"); 126*ecde56a6SMatthias Ringwald 127*ecde56a6SMatthias Ringwald // init HCI 128*ecde56a6SMatthias Ringwald const hci_transport_t * transport = hci_transport_h4_instance(uart_driver); 129*ecde56a6SMatthias Ringwald const btstack_link_key_db_t * link_key_db = btstack_link_key_db_fs_instance(); 130*ecde56a6SMatthias Ringwald hci_init(transport, (void*) &transport_config); 131*ecde56a6SMatthias Ringwald hci_set_link_key_db(link_key_db); 132*ecde56a6SMatthias Ringwald 133*ecde56a6SMatthias Ringwald // inform about BTstack state 134*ecde56a6SMatthias Ringwald hci_event_callback_registration.callback = &packet_handler; 135*ecde56a6SMatthias Ringwald hci_add_event_handler(&hci_event_callback_registration); 136*ecde56a6SMatthias Ringwald 137*ecde56a6SMatthias Ringwald // handle CTRL-c 138*ecde56a6SMatthias Ringwald signal(SIGINT, sigint_handler); 139*ecde56a6SMatthias Ringwald 140*ecde56a6SMatthias Ringwald // setup app 141*ecde56a6SMatthias Ringwald btstack_main(main_argc, main_argv); 142*ecde56a6SMatthias Ringwald } 143*ecde56a6SMatthias Ringwald 144*ecde56a6SMatthias Ringwald 145*ecde56a6SMatthias Ringwald int main(int argc, const char * argv[]){ 146*ecde56a6SMatthias Ringwald 147*ecde56a6SMatthias Ringwald /// GET STARTED with BTstack /// 148*ecde56a6SMatthias Ringwald btstack_memory_init(); 149*ecde56a6SMatthias Ringwald btstack_run_loop_init(btstack_run_loop_posix_get_instance()); 150*ecde56a6SMatthias Ringwald 151*ecde56a6SMatthias Ringwald // use logger: format HCI_DUMP_PACKETLOGGER, HCI_DUMP_BLUEZ or HCI_DUMP_STDOUT 152*ecde56a6SMatthias Ringwald const char * pklg_path = "/tmp/hci_dump.pklg"; 153*ecde56a6SMatthias Ringwald hci_dump_open(pklg_path, HCI_DUMP_PACKETLOGGER); 154*ecde56a6SMatthias Ringwald printf("Packet Log: %s\n", pklg_path); 155*ecde56a6SMatthias Ringwald 156*ecde56a6SMatthias Ringwald // pick serial port and configure uart block driver 157*ecde56a6SMatthias Ringwald transport_config.device_name = "/dev/tty.usbmodem1461"; 158*ecde56a6SMatthias Ringwald uart_driver = btstack_uart_block_posix_instance(); 159*ecde56a6SMatthias Ringwald 160*ecde56a6SMatthias Ringwald // extract UART config from transport config, but overide initial uart speed 161*ecde56a6SMatthias Ringwald uart_config.baudrate = 57600; 162*ecde56a6SMatthias Ringwald uart_config.flowcontrol = transport_config.flowcontrol; 163*ecde56a6SMatthias Ringwald uart_config.device_name = transport_config.device_name; 164*ecde56a6SMatthias Ringwald uart_driver->init(&uart_config); 165*ecde56a6SMatthias Ringwald 166*ecde56a6SMatthias Ringwald main_argc = argc; 167*ecde56a6SMatthias Ringwald main_argv = argv; 168*ecde56a6SMatthias Ringwald 169*ecde56a6SMatthias Ringwald // phase #1 download firmware 170*ecde56a6SMatthias Ringwald printf("Phase 1: Download firmware\n"); 171*ecde56a6SMatthias Ringwald 172*ecde56a6SMatthias Ringwald // phase #2 start main app 173*ecde56a6SMatthias Ringwald btstack_chipset_da14581_download_firmware(uart_driver, da14581_fw_data, da14581_fw_size, &phase2); 174*ecde56a6SMatthias Ringwald 175*ecde56a6SMatthias Ringwald // go 176*ecde56a6SMatthias Ringwald btstack_run_loop_execute(); 177*ecde56a6SMatthias Ringwald return 0; 178*ecde56a6SMatthias Ringwald } 179