xref: /btstack/port/windows-h4-da14585/main.c (revision aaa1682ba28bbe779e8e859f8529b64c4cd5f80d)
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
232fca4dadSMilanka Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BLUEKITCHEN
242fca4dadSMilanka Ringwald  * GMBH 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 
38d5b02eadSMatthias 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 
513c214e8aSMatthias Ringwald #include "btstack_config.h"
523c214e8aSMatthias Ringwald 
53d5b02eadSMatthias Ringwald #include "ble/le_device_db_tlv.h"
54d00ab9e3SMatthias Ringwald #include "btstack_chipset_da145xx.h"
553c214e8aSMatthias Ringwald #include "btstack_debug.h"
563c214e8aSMatthias Ringwald #include "btstack_event.h"
573c214e8aSMatthias Ringwald #include "btstack_memory.h"
583c214e8aSMatthias Ringwald #include "btstack_run_loop.h"
593c214e8aSMatthias Ringwald #include "btstack_run_loop_windows.h"
60d5b02eadSMatthias Ringwald #include "btstack_stdin.h"
61d5b02eadSMatthias Ringwald #include "btstack_stdin_windows.h"
62d5b02eadSMatthias Ringwald #include "btstack_tlv_posix.h"
63d5b02eadSMatthias Ringwald #include "hal_led.h"
643c214e8aSMatthias Ringwald #include "hci.h"
65d5b02eadSMatthias Ringwald #include "hci_585.h"
663c214e8aSMatthias Ringwald #include "hci_dump.h"
677435ec7bSMatthias Ringwald #include "hci_dump_posix_fs.h"
68c8dfe071SMatthias Ringwald #include "hci_transport.h"
69c8dfe071SMatthias Ringwald #include "hci_transport_h4.h"
703c214e8aSMatthias Ringwald 
713c214e8aSMatthias Ringwald static int main_argc;
723c214e8aSMatthias Ringwald static const char ** main_argv;
733c214e8aSMatthias Ringwald static const btstack_uart_block_t * uart_driver;
743c214e8aSMatthias Ringwald static btstack_uart_config_t uart_config;
753c214e8aSMatthias Ringwald 
763c214e8aSMatthias Ringwald #define TLV_DB_PATH_PREFIX "btstack_"
773c214e8aSMatthias Ringwald #define TLV_DB_PATH_POSTFIX ".tlv"
783c214e8aSMatthias Ringwald static char tlv_db_path[100];
793c214e8aSMatthias Ringwald static const btstack_tlv_t * tlv_impl;
803c214e8aSMatthias Ringwald static btstack_tlv_posix_t   tlv_context;
81d5b02eadSMatthias Ringwald static bd_addr_t             local_addr;
82d5b02eadSMatthias Ringwald static bool shutdown_triggered;
833c214e8aSMatthias Ringwald 
843c214e8aSMatthias Ringwald int btstack_main(int argc, const char * argv[]);
853c214e8aSMatthias Ringwald 
863c214e8aSMatthias Ringwald static hci_transport_config_uart_t transport_config = {
873c214e8aSMatthias Ringwald         HCI_TRANSPORT_CONFIG_UART,
883c214e8aSMatthias Ringwald         115200,
893c214e8aSMatthias Ringwald         0,  // main baudrate
903c214e8aSMatthias Ringwald         1,  // flow control
913c214e8aSMatthias Ringwald         NULL,
923c214e8aSMatthias Ringwald };
933c214e8aSMatthias Ringwald 
943c214e8aSMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration;
953c214e8aSMatthias Ringwald 
963c214e8aSMatthias Ringwald static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
973c214e8aSMatthias Ringwald     if (packet_type != HCI_EVENT_PACKET) return;
983c214e8aSMatthias Ringwald     switch (hci_event_packet_get_type(packet)){
993c214e8aSMatthias Ringwald         case BTSTACK_EVENT_STATE:
100d5b02eadSMatthias Ringwald             switch (btstack_event_state_get_state(packet)){
101d5b02eadSMatthias Ringwald                 case HCI_STATE_WORKING:
102d5b02eadSMatthias Ringwald                     gap_local_bd_addr(local_addr);
103d5b02eadSMatthias Ringwald                     printf("BTstack up and running on %s.\n", bd_addr_to_str(local_addr));
1043c214e8aSMatthias Ringwald                     strcpy(tlv_db_path, TLV_DB_PATH_PREFIX);
105d5b02eadSMatthias Ringwald                     strcat(tlv_db_path, bd_addr_to_str(local_addr));
1063c214e8aSMatthias Ringwald                     strcat(tlv_db_path, TLV_DB_PATH_POSTFIX);
1073c214e8aSMatthias Ringwald                     tlv_impl = btstack_tlv_posix_init_instance(&tlv_context, tlv_db_path);
1083c214e8aSMatthias Ringwald                     btstack_tlv_set_instance(tlv_impl, &tlv_context);
109d5b02eadSMatthias Ringwald #ifdef ENABLE_CLASSIC
110d5b02eadSMatthias Ringwald                     hci_set_link_key_db(btstack_link_key_db_tlv_get_instance(tlv_impl, &tlv_context));
111d5b02eadSMatthias Ringwald #endif
112d5b02eadSMatthias Ringwald #ifdef ENABLE_BLE
1133c214e8aSMatthias Ringwald                     le_device_db_tlv_configure(tlv_impl, &tlv_context);
114d5b02eadSMatthias Ringwald #endif
115d5b02eadSMatthias Ringwald                     break;
116d5b02eadSMatthias Ringwald                 case HCI_STATE_OFF:
117d5b02eadSMatthias Ringwald                     btstack_tlv_posix_deinit(&tlv_context);
118d5b02eadSMatthias Ringwald                     if (!shutdown_triggered) break;
119d5b02eadSMatthias Ringwald                     // reset stdin
120d5b02eadSMatthias Ringwald                     btstack_stdin_reset();
121d5b02eadSMatthias Ringwald                     log_info("Good bye, see you.\n");
122d5b02eadSMatthias Ringwald                     exit(0);
123d5b02eadSMatthias Ringwald                     break;
124d5b02eadSMatthias Ringwald                 default:
125d5b02eadSMatthias Ringwald                     break;
126d5b02eadSMatthias Ringwald             }
1273c214e8aSMatthias Ringwald             break;
1283c214e8aSMatthias Ringwald         default:
1293c214e8aSMatthias Ringwald             break;
1303c214e8aSMatthias Ringwald     }
1313c214e8aSMatthias Ringwald }
1323c214e8aSMatthias Ringwald 
133d5b02eadSMatthias Ringwald static void trigger_shutdown(void){
1343c214e8aSMatthias Ringwald     printf("CTRL-C - SIGINT received, shutting down..\n");
1353c214e8aSMatthias Ringwald     log_info("sigint_handler: shutting down");
136d5b02eadSMatthias Ringwald     shutdown_triggered = true;
1373c214e8aSMatthias Ringwald     hci_power_control(HCI_POWER_OFF);
1383c214e8aSMatthias Ringwald }
1393c214e8aSMatthias Ringwald 
1403c214e8aSMatthias Ringwald static int led_state = 0;
1413c214e8aSMatthias Ringwald void hal_led_toggle(void){
1423c214e8aSMatthias Ringwald     led_state = 1 - led_state;
1433c214e8aSMatthias Ringwald     printf("LED State %u\n", led_state);
1443c214e8aSMatthias Ringwald }
1453c214e8aSMatthias Ringwald 
1463c214e8aSMatthias Ringwald static void phase2(int status){
1473c214e8aSMatthias Ringwald 
1483c214e8aSMatthias Ringwald     if (status){
1493c214e8aSMatthias Ringwald         printf("Download firmware failed\n");
1503c214e8aSMatthias Ringwald         return;
1513c214e8aSMatthias Ringwald     }
1523c214e8aSMatthias Ringwald 
1533c214e8aSMatthias Ringwald     printf("Phase 2: Main app\n");
1543c214e8aSMatthias Ringwald 
1553c214e8aSMatthias Ringwald     // init HCI
1563c214e8aSMatthias Ringwald     const hci_transport_t * transport = hci_transport_h4_instance(uart_driver);
1573c214e8aSMatthias Ringwald     hci_init(transport, (void*) &transport_config);
1583c214e8aSMatthias Ringwald 
1593c214e8aSMatthias Ringwald     // inform about BTstack state
1603c214e8aSMatthias Ringwald     hci_event_callback_registration.callback = &packet_handler;
1613c214e8aSMatthias Ringwald     hci_add_event_handler(&hci_event_callback_registration);
1623c214e8aSMatthias Ringwald 
163d5b02eadSMatthias Ringwald     // setup stdin to handle CTRL-c
164d5b02eadSMatthias Ringwald     btstack_stdin_windows_init();
165d5b02eadSMatthias Ringwald     btstack_stdin_window_register_ctrl_c_callback(&trigger_shutdown);
1663c214e8aSMatthias Ringwald 
1673c214e8aSMatthias Ringwald     // setup app
1683c214e8aSMatthias Ringwald     btstack_main(main_argc, main_argv);
1693c214e8aSMatthias Ringwald }
1703c214e8aSMatthias Ringwald 
1713c214e8aSMatthias Ringwald 
1723c214e8aSMatthias Ringwald int main(int argc, const char * argv[]){
1733c214e8aSMatthias Ringwald 
1743c214e8aSMatthias Ringwald     /// GET STARTED with BTstack ///
1753c214e8aSMatthias Ringwald     btstack_memory_init();
1763c214e8aSMatthias Ringwald     btstack_run_loop_init(btstack_run_loop_windows_get_instance());
1773c214e8aSMatthias Ringwald 
1787435ec7bSMatthias Ringwald     // log into file using HCI_DUMP_PACKETLOGGER format
17934c6d5e0SMatthias Ringwald     const char * pklg_path = "hci_dump.pklg";
1807435ec7bSMatthias Ringwald     hci_dump_posix_fs_open(pklg_path, HCI_DUMP_PACKETLOGGER);
1817435ec7bSMatthias Ringwald     const hci_dump_t * hci_dump_impl = hci_dump_posix_fs_get_instance();
1827435ec7bSMatthias Ringwald     hci_dump_init(hci_dump_impl);
1833c214e8aSMatthias Ringwald     printf("Packet Log: %s\n", pklg_path);
1843c214e8aSMatthias Ringwald 
1853c214e8aSMatthias Ringwald     // pick serial port and configure uart block driver
1863c214e8aSMatthias Ringwald     transport_config.device_name = "\\\\.\\COM19";
1873c214e8aSMatthias Ringwald     uart_driver = btstack_uart_block_windows_instance();
1883c214e8aSMatthias Ringwald 
1893c214e8aSMatthias Ringwald     // extract UART config from transport config, but overide initial uart speed
1903c214e8aSMatthias Ringwald     uart_config.baudrate    = 57600;
1913c214e8aSMatthias Ringwald     uart_config.flowcontrol = transport_config.flowcontrol;
1923c214e8aSMatthias Ringwald     uart_config.device_name = transport_config.device_name;
1933c214e8aSMatthias Ringwald     uart_driver->init(&uart_config);
1943c214e8aSMatthias Ringwald 
1953c214e8aSMatthias Ringwald     main_argc = argc;
1963c214e8aSMatthias Ringwald     main_argv = argv;
1973c214e8aSMatthias Ringwald 
1983c214e8aSMatthias Ringwald     // phase #1 download firmware
1993c214e8aSMatthias Ringwald     printf("Phase 1: Download firmware\n");
2003c214e8aSMatthias Ringwald 
2013c214e8aSMatthias Ringwald     // phase #2 start main app
202*aaa1682bSMatthias Ringwald     btstack_chipset_da145xx_download_firmware(uart_driver, da145xx_fw_data, da145xx_fw_size, &phase2);
2033c214e8aSMatthias Ringwald 
2043c214e8aSMatthias Ringwald     // go
2053c214e8aSMatthias Ringwald     btstack_run_loop_execute();
2063c214e8aSMatthias Ringwald     return 0;
2073c214e8aSMatthias Ringwald }
208