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