xref: /btstack/port/windows-h4-da14585/main.c (revision 42c5c5581b83a00e2c1de42e4fe687a30b9efa5a)
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"
54*42c5c558SMatthias Ringwald #include "btstack_audio.h"
55d00ab9e3SMatthias Ringwald #include "btstack_chipset_da145xx.h"
563c214e8aSMatthias Ringwald #include "btstack_debug.h"
573c214e8aSMatthias Ringwald #include "btstack_event.h"
583c214e8aSMatthias Ringwald #include "btstack_memory.h"
593c214e8aSMatthias Ringwald #include "btstack_run_loop.h"
603c214e8aSMatthias Ringwald #include "btstack_run_loop_windows.h"
61d5b02eadSMatthias Ringwald #include "btstack_stdin.h"
62d5b02eadSMatthias Ringwald #include "btstack_stdin_windows.h"
633086bcceSMatthias Ringwald #include "btstack_tlv_windows.h"
64d5b02eadSMatthias Ringwald #include "hal_led.h"
653c214e8aSMatthias Ringwald #include "hci.h"
66d5b02eadSMatthias Ringwald #include "hci_585.h"
673c214e8aSMatthias Ringwald #include "hci_dump.h"
683086bcceSMatthias Ringwald #include "hci_dump_windows_fs.h"
69c8dfe071SMatthias Ringwald #include "hci_transport.h"
70c8dfe071SMatthias Ringwald #include "hci_transport_h4.h"
713c214e8aSMatthias Ringwald 
723c214e8aSMatthias Ringwald static int main_argc;
733c214e8aSMatthias Ringwald static const char ** main_argv;
743c214e8aSMatthias Ringwald static const btstack_uart_block_t * uart_driver;
753c214e8aSMatthias Ringwald static btstack_uart_config_t uart_config;
763c214e8aSMatthias Ringwald 
773c214e8aSMatthias Ringwald #define TLV_DB_PATH_PREFIX "btstack_"
783c214e8aSMatthias Ringwald #define TLV_DB_PATH_POSTFIX ".tlv"
793c214e8aSMatthias Ringwald static char tlv_db_path[100];
803c214e8aSMatthias Ringwald static const btstack_tlv_t * tlv_impl;
813086bcceSMatthias Ringwald static btstack_tlv_windows_t   tlv_context;
82d5b02eadSMatthias Ringwald static bd_addr_t             local_addr;
83d5b02eadSMatthias Ringwald static bool shutdown_triggered;
843c214e8aSMatthias Ringwald 
853c214e8aSMatthias Ringwald int btstack_main(int argc, const char * argv[]);
863c214e8aSMatthias Ringwald 
873c214e8aSMatthias Ringwald static hci_transport_config_uart_t transport_config = {
883c214e8aSMatthias Ringwald         HCI_TRANSPORT_CONFIG_UART,
893c214e8aSMatthias Ringwald         115200,
903c214e8aSMatthias Ringwald         0,  // main baudrate
913c214e8aSMatthias Ringwald         1,  // flow control
923c214e8aSMatthias Ringwald         NULL,
933c214e8aSMatthias Ringwald };
943c214e8aSMatthias Ringwald 
953c214e8aSMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration;
963c214e8aSMatthias Ringwald 
packet_handler(uint8_t packet_type,uint16_t channel,uint8_t * packet,uint16_t size)973c214e8aSMatthias Ringwald static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
983c214e8aSMatthias Ringwald     if (packet_type != HCI_EVENT_PACKET) return;
993c214e8aSMatthias Ringwald     switch (hci_event_packet_get_type(packet)){
1003c214e8aSMatthias Ringwald         case BTSTACK_EVENT_STATE:
101d5b02eadSMatthias Ringwald             switch (btstack_event_state_get_state(packet)){
102d5b02eadSMatthias Ringwald                 case HCI_STATE_WORKING:
103d5b02eadSMatthias Ringwald                     gap_local_bd_addr(local_addr);
104d5b02eadSMatthias Ringwald                     printf("BTstack up and running on %s.\n", bd_addr_to_str(local_addr));
10554736c11SMatthias Ringwald                     btstack_strcpy(tlv_db_path, sizeof(tlv_db_path), TLV_DB_PATH_PREFIX);
10654736c11SMatthias Ringwald                     btstack_strcat(tlv_db_path, sizeof(tlv_db_path), bd_addr_to_str_with_delimiter(local_addr, '-'));
10754736c11SMatthias Ringwald                     btstack_strcat(tlv_db_path, sizeof(tlv_db_path), TLV_DB_PATH_POSTFIX);
1083086bcceSMatthias Ringwald                     tlv_impl = btstack_tlv_windows_init_instance(&tlv_context, tlv_db_path);
1093c214e8aSMatthias Ringwald                     btstack_tlv_set_instance(tlv_impl, &tlv_context);
110d5b02eadSMatthias Ringwald #ifdef ENABLE_CLASSIC
111d5b02eadSMatthias Ringwald                     hci_set_link_key_db(btstack_link_key_db_tlv_get_instance(tlv_impl, &tlv_context));
112d5b02eadSMatthias Ringwald #endif
113d5b02eadSMatthias Ringwald #ifdef ENABLE_BLE
1143c214e8aSMatthias Ringwald                     le_device_db_tlv_configure(tlv_impl, &tlv_context);
115d5b02eadSMatthias Ringwald #endif
116d5b02eadSMatthias Ringwald                     break;
117d5b02eadSMatthias Ringwald                 case HCI_STATE_OFF:
1183086bcceSMatthias Ringwald                     btstack_tlv_windows_deinit(&tlv_context);
119d5b02eadSMatthias Ringwald                     if (!shutdown_triggered) break;
120d5b02eadSMatthias Ringwald                     // reset stdin
121d5b02eadSMatthias Ringwald                     btstack_stdin_reset();
122d5b02eadSMatthias Ringwald                     log_info("Good bye, see you.\n");
123d5b02eadSMatthias Ringwald                     exit(0);
124d5b02eadSMatthias Ringwald                     break;
125d5b02eadSMatthias Ringwald                 default:
126d5b02eadSMatthias Ringwald                     break;
127d5b02eadSMatthias Ringwald             }
1283c214e8aSMatthias Ringwald             break;
1293c214e8aSMatthias Ringwald         default:
1303c214e8aSMatthias Ringwald             break;
1313c214e8aSMatthias Ringwald     }
1323c214e8aSMatthias Ringwald }
1333c214e8aSMatthias Ringwald 
trigger_shutdown(void)134d5b02eadSMatthias Ringwald static void trigger_shutdown(void){
1353c214e8aSMatthias Ringwald     printf("CTRL-C - SIGINT received, shutting down..\n");
1363c214e8aSMatthias Ringwald     log_info("sigint_handler: shutting down");
137d5b02eadSMatthias Ringwald     shutdown_triggered = true;
1383c214e8aSMatthias Ringwald     hci_power_control(HCI_POWER_OFF);
1393c214e8aSMatthias Ringwald }
1403c214e8aSMatthias Ringwald 
1413c214e8aSMatthias Ringwald static int led_state = 0;
hal_led_toggle(void)1423c214e8aSMatthias Ringwald void hal_led_toggle(void){
1433c214e8aSMatthias Ringwald     led_state = 1 - led_state;
1443c214e8aSMatthias Ringwald     printf("LED State %u\n", led_state);
1453c214e8aSMatthias Ringwald }
1463c214e8aSMatthias Ringwald 
phase2(int status)1473c214e8aSMatthias Ringwald static void phase2(int status){
1483c214e8aSMatthias Ringwald 
1493c214e8aSMatthias Ringwald     if (status){
1503c214e8aSMatthias Ringwald         printf("Download firmware failed\n");
1513c214e8aSMatthias Ringwald         return;
1523c214e8aSMatthias Ringwald     }
1533c214e8aSMatthias Ringwald 
1543c214e8aSMatthias Ringwald     printf("Phase 2: Main app\n");
1553c214e8aSMatthias Ringwald 
1563c214e8aSMatthias Ringwald     // init HCI
1573c214e8aSMatthias Ringwald     const hci_transport_t * transport = hci_transport_h4_instance(uart_driver);
1583c214e8aSMatthias Ringwald     hci_init(transport, (void*) &transport_config);
1593c214e8aSMatthias Ringwald 
160*42c5c558SMatthias Ringwald #ifdef HAVE_PORTAUDIO
161*42c5c558SMatthias Ringwald     btstack_audio_sink_set_instance(btstack_audio_portaudio_sink_get_instance());
162*42c5c558SMatthias Ringwald     btstack_audio_source_set_instance(btstack_audio_portaudio_source_get_instance());
163*42c5c558SMatthias Ringwald #endif
164*42c5c558SMatthias Ringwald 
1653c214e8aSMatthias Ringwald     // inform about BTstack state
1663c214e8aSMatthias Ringwald     hci_event_callback_registration.callback = &packet_handler;
1673c214e8aSMatthias Ringwald     hci_add_event_handler(&hci_event_callback_registration);
1683c214e8aSMatthias Ringwald 
169d5b02eadSMatthias Ringwald     // setup stdin to handle CTRL-c
170d5b02eadSMatthias Ringwald     btstack_stdin_windows_init();
171d5b02eadSMatthias Ringwald     btstack_stdin_window_register_ctrl_c_callback(&trigger_shutdown);
1723c214e8aSMatthias Ringwald 
1733c214e8aSMatthias Ringwald     // setup app
1743c214e8aSMatthias Ringwald     btstack_main(main_argc, main_argv);
1753c214e8aSMatthias Ringwald }
1763c214e8aSMatthias Ringwald 
1773c214e8aSMatthias Ringwald 
main(int argc,const char * argv[])1783c214e8aSMatthias Ringwald int main(int argc, const char * argv[]){
1793c214e8aSMatthias Ringwald 
1803c214e8aSMatthias Ringwald     /// GET STARTED with BTstack ///
1813c214e8aSMatthias Ringwald     btstack_memory_init();
1823c214e8aSMatthias Ringwald     btstack_run_loop_init(btstack_run_loop_windows_get_instance());
1833c214e8aSMatthias Ringwald 
1847435ec7bSMatthias Ringwald     // log into file using HCI_DUMP_PACKETLOGGER format
18534c6d5e0SMatthias Ringwald     const char * pklg_path = "hci_dump.pklg";
1863086bcceSMatthias Ringwald     hci_dump_windows_fs_open(pklg_path, HCI_DUMP_PACKETLOGGER);
1873086bcceSMatthias Ringwald     const hci_dump_t * hci_dump_impl = hci_dump_windows_fs_get_instance();
1887435ec7bSMatthias Ringwald     hci_dump_init(hci_dump_impl);
1893c214e8aSMatthias Ringwald     printf("Packet Log: %s\n", pklg_path);
1903c214e8aSMatthias Ringwald 
1913c214e8aSMatthias Ringwald     // pick serial port and configure uart block driver
1923c214e8aSMatthias Ringwald     transport_config.device_name = "\\\\.\\COM19";
1933c214e8aSMatthias Ringwald     uart_driver = btstack_uart_block_windows_instance();
1943c214e8aSMatthias Ringwald 
1953c214e8aSMatthias Ringwald     // extract UART config from transport config, but overide initial uart speed
1963c214e8aSMatthias Ringwald     uart_config.baudrate    = 57600;
1973c214e8aSMatthias Ringwald     uart_config.flowcontrol = transport_config.flowcontrol;
1983c214e8aSMatthias Ringwald     uart_config.device_name = transport_config.device_name;
1993c214e8aSMatthias Ringwald     uart_driver->init(&uart_config);
2003c214e8aSMatthias Ringwald 
2013c214e8aSMatthias Ringwald     main_argc = argc;
2023c214e8aSMatthias Ringwald     main_argv = argv;
2033c214e8aSMatthias Ringwald 
2043c214e8aSMatthias Ringwald     // phase #1 download firmware
2053c214e8aSMatthias Ringwald     printf("Phase 1: Download firmware\n");
2063c214e8aSMatthias Ringwald 
2073c214e8aSMatthias Ringwald     // phase #2 start main app
208aaa1682bSMatthias Ringwald     btstack_chipset_da145xx_download_firmware(uart_driver, da145xx_fw_data, da145xx_fw_size, &phase2);
2093c214e8aSMatthias Ringwald 
2103c214e8aSMatthias Ringwald     // go
2113c214e8aSMatthias Ringwald     btstack_run_loop_execute();
2123c214e8aSMatthias Ringwald     return 0;
2133c214e8aSMatthias Ringwald }
214