xref: /btstack/port/posix-h4-da14585/main.c (revision ecde56a6a048269638ac22d121db23e848ec4ed6)
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