xref: /btstack/port/windows-h4-da14585/main.c (revision 7435ec7b56401eb7078a7eabd3a5f90c8697dd4f)
13c214e8aSMatthias Ringwald /*
23c214e8aSMatthias Ringwald  * Copyright (C) 2014 BlueKitchen GmbH
33c214e8aSMatthias Ringwald  *
43c214e8aSMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
53c214e8aSMatthias Ringwald  * modification, are permitted provided that the following conditions
63c214e8aSMatthias Ringwald  * are met:
73c214e8aSMatthias Ringwald  *
83c214e8aSMatthias Ringwald  * 1. Redistributions of source code must retain the above copyright
93c214e8aSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
103c214e8aSMatthias Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
113c214e8aSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
123c214e8aSMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
133c214e8aSMatthias Ringwald  * 3. Neither the name of the copyright holders nor the names of
143c214e8aSMatthias Ringwald  *    contributors may be used to endorse or promote products derived
153c214e8aSMatthias Ringwald  *    from this software without specific prior written permission.
163c214e8aSMatthias Ringwald  * 4. Any redistribution, use, or modification is done solely for
173c214e8aSMatthias Ringwald  *    personal benefit and not for any commercial purpose or for
183c214e8aSMatthias Ringwald  *    monetary gain.
193c214e8aSMatthias Ringwald  *
203c214e8aSMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
213c214e8aSMatthias Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
223c214e8aSMatthias Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
233c214e8aSMatthias Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
243c214e8aSMatthias Ringwald  * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
253c214e8aSMatthias Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
263c214e8aSMatthias Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
273c214e8aSMatthias Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
283c214e8aSMatthias Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
293c214e8aSMatthias Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
303c214e8aSMatthias Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
313c214e8aSMatthias Ringwald  * SUCH DAMAGE.
323c214e8aSMatthias Ringwald  *
333c214e8aSMatthias Ringwald  * Please inquire about commercial licensing options at
343c214e8aSMatthias Ringwald  * [email protected]
353c214e8aSMatthias Ringwald  *
363c214e8aSMatthias Ringwald  */
373c214e8aSMatthias Ringwald 
383c214e8aSMatthias Ringwald #define __BTSTACK_FILE__ "main.c"
393c214e8aSMatthias Ringwald 
403c214e8aSMatthias Ringwald // *****************************************************************************
413c214e8aSMatthias Ringwald //
423c214e8aSMatthias Ringwald // minimal setup for HCI code
433c214e8aSMatthias Ringwald //
443c214e8aSMatthias Ringwald // *****************************************************************************
453c214e8aSMatthias Ringwald 
463c214e8aSMatthias Ringwald #include <stdint.h>
473c214e8aSMatthias Ringwald #include <stdio.h>
483c214e8aSMatthias Ringwald #include <stdlib.h>
493c214e8aSMatthias Ringwald #include <string.h>
503c214e8aSMatthias Ringwald #include <signal.h>
513c214e8aSMatthias Ringwald 
523c214e8aSMatthias Ringwald #include "btstack_config.h"
533c214e8aSMatthias Ringwald 
543c214e8aSMatthias Ringwald #include "btstack_debug.h"
553c214e8aSMatthias Ringwald #include "btstack_event.h"
563c214e8aSMatthias Ringwald #include "btstack_memory.h"
573c214e8aSMatthias Ringwald #include "btstack_run_loop.h"
583c214e8aSMatthias Ringwald #include "btstack_run_loop_windows.h"
593c214e8aSMatthias Ringwald #include "ble/le_device_db_tlv.h"
603c214e8aSMatthias Ringwald #include "hci.h"
613c214e8aSMatthias Ringwald #include "hci_dump.h"
62*7435ec7bSMatthias Ringwald #include "hci_dump_posix_fs.h"
633c214e8aSMatthias Ringwald #include "btstack_stdin.h"
643c214e8aSMatthias Ringwald #include "btstack_tlv_posix.h"
653c214e8aSMatthias Ringwald #include "hal_led.h"
663c214e8aSMatthias Ringwald #include "btstack_chipset_da14581.h"
673c214e8aSMatthias Ringwald #include "hci_585.h"
683c214e8aSMatthias Ringwald 
693c214e8aSMatthias Ringwald static int main_argc;
703c214e8aSMatthias Ringwald static const char ** main_argv;
713c214e8aSMatthias Ringwald static const btstack_uart_block_t * uart_driver;
723c214e8aSMatthias Ringwald static btstack_uart_config_t uart_config;
733c214e8aSMatthias Ringwald 
743c214e8aSMatthias Ringwald #define TLV_DB_PATH_PREFIX "btstack_"
753c214e8aSMatthias Ringwald #define TLV_DB_PATH_POSTFIX ".tlv"
763c214e8aSMatthias Ringwald static char tlv_db_path[100];
773c214e8aSMatthias Ringwald static const btstack_tlv_t * tlv_impl;
783c214e8aSMatthias Ringwald static btstack_tlv_posix_t   tlv_context;
793c214e8aSMatthias Ringwald 
803c214e8aSMatthias Ringwald int btstack_main(int argc, const char * argv[]);
813c214e8aSMatthias Ringwald 
823c214e8aSMatthias Ringwald static hci_transport_config_uart_t transport_config = {
833c214e8aSMatthias Ringwald         HCI_TRANSPORT_CONFIG_UART,
843c214e8aSMatthias Ringwald         115200,
853c214e8aSMatthias Ringwald         0,  // main baudrate
863c214e8aSMatthias Ringwald         1,  // flow control
873c214e8aSMatthias Ringwald         NULL,
883c214e8aSMatthias Ringwald };
893c214e8aSMatthias Ringwald 
903c214e8aSMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration;
913c214e8aSMatthias Ringwald 
923c214e8aSMatthias Ringwald static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
933c214e8aSMatthias Ringwald     bd_addr_t addr;
943c214e8aSMatthias Ringwald     if (packet_type != HCI_EVENT_PACKET) return;
953c214e8aSMatthias Ringwald     switch (hci_event_packet_get_type(packet)){
963c214e8aSMatthias Ringwald         case BTSTACK_EVENT_STATE:
973c214e8aSMatthias Ringwald             if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) break;
983c214e8aSMatthias Ringwald             gap_local_bd_addr(addr);
993c214e8aSMatthias Ringwald             printf("BTstack up and running at %s\n",  bd_addr_to_str(addr));
1003c214e8aSMatthias Ringwald             // setup TLV
1013c214e8aSMatthias Ringwald             strcpy(tlv_db_path, TLV_DB_PATH_PREFIX);
1023c214e8aSMatthias Ringwald             strcat(tlv_db_path, bd_addr_to_str(addr));
1033c214e8aSMatthias Ringwald             strcat(tlv_db_path, TLV_DB_PATH_POSTFIX);
1043c214e8aSMatthias Ringwald             tlv_impl = btstack_tlv_posix_init_instance(&tlv_context, tlv_db_path);
1053c214e8aSMatthias Ringwald             btstack_tlv_set_instance(tlv_impl, &tlv_context);
1063c214e8aSMatthias Ringwald             le_device_db_tlv_configure(tlv_impl, &tlv_context);
1073c214e8aSMatthias Ringwald             break;
1083c214e8aSMatthias Ringwald         default:
1093c214e8aSMatthias Ringwald             break;
1103c214e8aSMatthias Ringwald     }
1113c214e8aSMatthias Ringwald }
1123c214e8aSMatthias Ringwald 
1133c214e8aSMatthias Ringwald static void sigint_handler(int param){
1143c214e8aSMatthias Ringwald     UNUSED(param);
1153c214e8aSMatthias Ringwald 
1163c214e8aSMatthias Ringwald     printf("CTRL-C - SIGINT received, shutting down..\n");
1173c214e8aSMatthias Ringwald     log_info("sigint_handler: shutting down");
1183c214e8aSMatthias Ringwald 
1193c214e8aSMatthias Ringwald     // reset anyway
1203c214e8aSMatthias Ringwald     btstack_stdin_reset();
1213c214e8aSMatthias Ringwald 
1223c214e8aSMatthias Ringwald     // power down
1233c214e8aSMatthias Ringwald     hci_power_control(HCI_POWER_OFF);
1243c214e8aSMatthias Ringwald     hci_close();
1253c214e8aSMatthias Ringwald     log_info("Good bye, see you.\n");
1263c214e8aSMatthias Ringwald     exit(0);
1273c214e8aSMatthias Ringwald }
1283c214e8aSMatthias Ringwald 
1293c214e8aSMatthias Ringwald static int led_state = 0;
1303c214e8aSMatthias Ringwald void hal_led_toggle(void){
1313c214e8aSMatthias Ringwald     led_state = 1 - led_state;
1323c214e8aSMatthias Ringwald     printf("LED State %u\n", led_state);
1333c214e8aSMatthias Ringwald }
1343c214e8aSMatthias Ringwald 
1353c214e8aSMatthias Ringwald static void phase2(int status){
1363c214e8aSMatthias Ringwald 
1373c214e8aSMatthias Ringwald     if (status){
1383c214e8aSMatthias Ringwald         printf("Download firmware failed\n");
1393c214e8aSMatthias Ringwald         return;
1403c214e8aSMatthias Ringwald     }
1413c214e8aSMatthias Ringwald 
1423c214e8aSMatthias Ringwald     printf("Phase 2: Main app\n");
1433c214e8aSMatthias Ringwald 
1443c214e8aSMatthias Ringwald     // init HCI
1453c214e8aSMatthias Ringwald     const hci_transport_t * transport = hci_transport_h4_instance(uart_driver);
1463c214e8aSMatthias Ringwald     hci_init(transport, (void*) &transport_config);
1473c214e8aSMatthias Ringwald 
1483c214e8aSMatthias Ringwald     // inform about BTstack state
1493c214e8aSMatthias Ringwald     hci_event_callback_registration.callback = &packet_handler;
1503c214e8aSMatthias Ringwald     hci_add_event_handler(&hci_event_callback_registration);
1513c214e8aSMatthias Ringwald 
1523c214e8aSMatthias Ringwald     // handle CTRL-c
1533c214e8aSMatthias Ringwald     signal(SIGINT, sigint_handler);
1543c214e8aSMatthias Ringwald 
1553c214e8aSMatthias Ringwald     // setup app
1563c214e8aSMatthias Ringwald     btstack_main(main_argc, main_argv);
1573c214e8aSMatthias Ringwald }
1583c214e8aSMatthias Ringwald 
1593c214e8aSMatthias Ringwald 
1603c214e8aSMatthias Ringwald int main(int argc, const char * argv[]){
1613c214e8aSMatthias Ringwald 
1623c214e8aSMatthias Ringwald     /// GET STARTED with BTstack ///
1633c214e8aSMatthias Ringwald     btstack_memory_init();
1643c214e8aSMatthias Ringwald     btstack_run_loop_init(btstack_run_loop_windows_get_instance());
1653c214e8aSMatthias Ringwald 
166*7435ec7bSMatthias Ringwald     // log into file using HCI_DUMP_PACKETLOGGER format
167*7435ec7bSMatthias Ringwald     const char * pklg_path = "/tmp/hci_dump.pklg";
168*7435ec7bSMatthias Ringwald     hci_dump_posix_fs_open(pklg_path, HCI_DUMP_PACKETLOGGER);
169*7435ec7bSMatthias Ringwald     const hci_dump_t * hci_dump_impl = hci_dump_posix_fs_get_instance();
170*7435ec7bSMatthias Ringwald     hci_dump_init(hci_dump_impl);
1713c214e8aSMatthias Ringwald     printf("Packet Log: %s\n", pklg_path);
1723c214e8aSMatthias Ringwald 
1733c214e8aSMatthias Ringwald     // pick serial port and configure uart block driver
1743c214e8aSMatthias Ringwald     transport_config.device_name = "\\\\.\\COM19";
1753c214e8aSMatthias Ringwald     uart_driver = btstack_uart_block_windows_instance();
1763c214e8aSMatthias Ringwald 
1773c214e8aSMatthias Ringwald     // extract UART config from transport config, but overide initial uart speed
1783c214e8aSMatthias Ringwald     uart_config.baudrate    = 57600;
1793c214e8aSMatthias Ringwald     uart_config.flowcontrol = transport_config.flowcontrol;
1803c214e8aSMatthias Ringwald     uart_config.device_name = transport_config.device_name;
1813c214e8aSMatthias Ringwald     uart_driver->init(&uart_config);
1823c214e8aSMatthias Ringwald 
1833c214e8aSMatthias Ringwald     main_argc = argc;
1843c214e8aSMatthias Ringwald     main_argv = argv;
1853c214e8aSMatthias Ringwald 
1863c214e8aSMatthias Ringwald     // phase #1 download firmware
1873c214e8aSMatthias Ringwald     printf("Phase 1: Download firmware\n");
1883c214e8aSMatthias Ringwald 
1893c214e8aSMatthias Ringwald     // phase #2 start main app
1903c214e8aSMatthias Ringwald     btstack_chipset_da14581_download_firmware(uart_driver, da14581_fw_data, da14581_fw_size, &phase2);
1913c214e8aSMatthias Ringwald 
1923c214e8aSMatthias Ringwald     // go
1933c214e8aSMatthias Ringwald     btstack_run_loop_execute();
1943c214e8aSMatthias Ringwald     return 0;
1953c214e8aSMatthias Ringwald }
196