xref: /btstack/port/posix-h4/main.c (revision 8c768b83f71594a13a07efcf3e830345663dad5f)
18caefee3SMatthias Ringwald /*
28caefee3SMatthias Ringwald  * Copyright (C) 2014 BlueKitchen GmbH
38caefee3SMatthias Ringwald  *
48caefee3SMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
58caefee3SMatthias Ringwald  * modification, are permitted provided that the following conditions
68caefee3SMatthias Ringwald  * are met:
78caefee3SMatthias Ringwald  *
88caefee3SMatthias Ringwald  * 1. Redistributions of source code must retain the above copyright
98caefee3SMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
108caefee3SMatthias Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
118caefee3SMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
128caefee3SMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
138caefee3SMatthias Ringwald  * 3. Neither the name of the copyright holders nor the names of
148caefee3SMatthias Ringwald  *    contributors may be used to endorse or promote products derived
158caefee3SMatthias Ringwald  *    from this software without specific prior written permission.
168caefee3SMatthias Ringwald  * 4. Any redistribution, use, or modification is done solely for
178caefee3SMatthias Ringwald  *    personal benefit and not for any commercial purpose or for
188caefee3SMatthias Ringwald  *    monetary gain.
198caefee3SMatthias Ringwald  *
208caefee3SMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
218caefee3SMatthias Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
228caefee3SMatthias Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
238caefee3SMatthias Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
248caefee3SMatthias Ringwald  * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
258caefee3SMatthias Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
268caefee3SMatthias Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
278caefee3SMatthias Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
288caefee3SMatthias Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
298caefee3SMatthias Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
308caefee3SMatthias Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
318caefee3SMatthias Ringwald  * SUCH DAMAGE.
328caefee3SMatthias Ringwald  *
338caefee3SMatthias Ringwald  * Please inquire about commercial licensing options at
348caefee3SMatthias Ringwald  * [email protected]
358caefee3SMatthias Ringwald  *
368caefee3SMatthias Ringwald  */
378caefee3SMatthias Ringwald 
388caefee3SMatthias Ringwald // *****************************************************************************
398caefee3SMatthias Ringwald //
408caefee3SMatthias Ringwald // minimal setup for HCI code
418caefee3SMatthias Ringwald //
428caefee3SMatthias Ringwald // *****************************************************************************
438caefee3SMatthias Ringwald 
448caefee3SMatthias Ringwald #include <stdint.h>
458caefee3SMatthias Ringwald #include <stdio.h>
468caefee3SMatthias Ringwald #include <stdlib.h>
478caefee3SMatthias Ringwald #include <string.h>
488caefee3SMatthias Ringwald #include <signal.h>
498caefee3SMatthias Ringwald 
507907f069SMatthias Ringwald #include "btstack_config.h"
518caefee3SMatthias Ringwald 
5216ece135SMatthias Ringwald #include "btstack_debug.h"
53e392c21bSMatthias Ringwald #include "btstack_event.h"
5454b584ffSMatthias Ringwald #include "btstack_link_key_db_fs.h"
5554b584ffSMatthias Ringwald #include "btstack_memory.h"
5682636622SMatthias Ringwald #include "btstack_run_loop.h"
578f2a52f4SMatthias Ringwald #include "btstack_run_loop_posix.h"
5854b584ffSMatthias Ringwald #include "hci.h"
5954b584ffSMatthias Ringwald #include "hci_dump.h"
608caefee3SMatthias Ringwald #include "stdin_support.h"
618caefee3SMatthias Ringwald 
62c0cdcfe7SMatthias Ringwald #include "btstack_chipset_bcm.h"
63c0cdcfe7SMatthias Ringwald #include "btstack_chipset_csr.h"
64c0cdcfe7SMatthias Ringwald #include "btstack_chipset_cc256x.h"
65c0cdcfe7SMatthias Ringwald #include "btstack_chipset_em9301.h"
66c0cdcfe7SMatthias Ringwald #include "btstack_chipset_stlc2500d.h"
67c0cdcfe7SMatthias Ringwald #include "btstack_chipset_tc3566x.h"
68c0cdcfe7SMatthias Ringwald 
698caefee3SMatthias Ringwald int btstack_main(int argc, const char * argv[]);
708caefee3SMatthias Ringwald 
719796ebeaSMatthias Ringwald static hci_transport_config_uart_t config = {
729796ebeaSMatthias Ringwald     HCI_TRANSPORT_CONFIG_UART,
738caefee3SMatthias Ringwald     115200,
749796ebeaSMatthias Ringwald     0,  // main baudrate
759796ebeaSMatthias Ringwald     1,  // flow control
769796ebeaSMatthias Ringwald     NULL,
778caefee3SMatthias Ringwald };
788caefee3SMatthias Ringwald 
79d356a6daSMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration;
80d356a6daSMatthias Ringwald 
81d356a6daSMatthias Ringwald static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
82d356a6daSMatthias Ringwald     if (packet_type != HCI_EVENT_PACKET) return;
83d356a6daSMatthias Ringwald     if (hci_event_packet_get_type(packet) != BTSTACK_EVENT_STATE) return;
84d356a6daSMatthias Ringwald     if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
85d356a6daSMatthias Ringwald     printf("BTstack up and running.\n");
86d356a6daSMatthias Ringwald }
87d356a6daSMatthias Ringwald 
888caefee3SMatthias Ringwald static void sigint_handler(int param){
898caefee3SMatthias Ringwald 
908caefee3SMatthias Ringwald #ifndef _WIN32
918caefee3SMatthias Ringwald     // reset anyway
928caefee3SMatthias Ringwald     btstack_stdin_reset();
938caefee3SMatthias Ringwald #endif
948caefee3SMatthias Ringwald 
958caefee3SMatthias Ringwald     log_info(" <= SIGINT received, shutting down..\n");
968caefee3SMatthias Ringwald     hci_power_control(HCI_POWER_OFF);
978caefee3SMatthias Ringwald     hci_close();
988caefee3SMatthias Ringwald     log_info("Good bye, see you.\n");
998caefee3SMatthias Ringwald     exit(0);
1008caefee3SMatthias Ringwald }
1018caefee3SMatthias Ringwald 
1028caefee3SMatthias Ringwald static int led_state = 0;
1038caefee3SMatthias Ringwald void hal_led_toggle(void){
1048caefee3SMatthias Ringwald     led_state = 1 - led_state;
1058caefee3SMatthias Ringwald     printf("LED State %u\n", led_state);
1068caefee3SMatthias Ringwald }
1073250103aSMatthias Ringwald static void use_fast_uart(void){
108615ae444SMatthias Ringwald #if defined(HAVE_POSIX_B240000_MAPPED_TO_3000000) || defined(HAVE_POSIX_B600_MAPPED_TO_3000000)
1093250103aSMatthias Ringwald     printf("Using 3000000 baud.\n");
1103250103aSMatthias Ringwald     config.baudrate_main = 3000000;
111615ae444SMatthias Ringwald #elif defined(HAVE_POSIX_B1200_MAPPED_TO_2000000) || defined(HAVE_POSIX_B300_MAPPED_TO_2000000)
1123250103aSMatthias Ringwald     printf("Using 2000000 baud.\n");
1133250103aSMatthias Ringwald     config.baudrate_main = 2000000;
1143250103aSMatthias Ringwald #else
1152c2bf480SMatthias Ringwald     printf("Using 921600 baud.\n");
1162c2bf480SMatthias Ringwald     config.baudrate_main = 921600;
1173250103aSMatthias Ringwald #endif
1182c2bf480SMatthias Ringwald }
1198caefee3SMatthias Ringwald 
120a6ddbcb9SMatthias Ringwald static void local_version_information_callback(uint8_t * packet){
121c0cdcfe7SMatthias Ringwald     printf("Local version information:\n");
122f8fbdce0SMatthias Ringwald     uint16_t hci_version    = little_endian_read_16(packet, 4);
123f8fbdce0SMatthias Ringwald     uint16_t hci_revision   = little_endian_read_16(packet, 6);
124f8fbdce0SMatthias Ringwald     uint16_t lmp_version    = little_endian_read_16(packet, 8);
125f8fbdce0SMatthias Ringwald     uint16_t manufacturer   = little_endian_read_16(packet, 10);
126f8fbdce0SMatthias Ringwald     uint16_t lmp_subversion = little_endian_read_16(packet, 12);
127c0cdcfe7SMatthias Ringwald     printf("- HCI Version  0x%04x\n", hci_version);
128c0cdcfe7SMatthias Ringwald     printf("- HCI Revision 0x%04x\n", hci_revision);
129c0cdcfe7SMatthias Ringwald     printf("- LMP Version  0x%04x\n", lmp_version);
130c0cdcfe7SMatthias Ringwald     printf("- LMP Revision 0x%04x\n", lmp_subversion);
131c0cdcfe7SMatthias Ringwald     printf("- Manufacturer 0x%04x\n", manufacturer);
132c0cdcfe7SMatthias Ringwald     switch (manufacturer){
133c0cdcfe7SMatthias Ringwald         case COMPANY_ID_CAMBRIDGE_SILICON_RADIO:
134c0cdcfe7SMatthias Ringwald             printf("Cambridge Silicon Radio CSR chipset.\n");
1353250103aSMatthias Ringwald             use_fast_uart();
136c0cdcfe7SMatthias Ringwald             hci_set_chipset(btstack_chipset_csr_instance());
137c0cdcfe7SMatthias Ringwald             break;
138c0cdcfe7SMatthias Ringwald         case COMPANY_ID_TEXAS_INSTRUMENTS_INC:
139c0cdcfe7SMatthias Ringwald             printf("Texas Instruments - CC256x compatible chipset.\n");
1403250103aSMatthias Ringwald             use_fast_uart();
141c0cdcfe7SMatthias Ringwald             hci_set_chipset(btstack_chipset_cc256x_instance());
142f6a20ec9SMatthias Ringwald #ifdef ENABLE_EHCILL
143f6a20ec9SMatthias Ringwald             printf("eHCILL enabled.\n");
144*8c768b83SMatthias Ringwald #else
145*8c768b83SMatthias Ringwald             printf("eHCILL disable.\n");
1468a23fc53SMatthias Ringwald #endif
147c0cdcfe7SMatthias Ringwald             break;
148c0cdcfe7SMatthias Ringwald         case COMPANY_ID_BROADCOM_CORPORATION:
149c0cdcfe7SMatthias Ringwald             printf("Broadcom chipset. Not supported yet\n");
150c0cdcfe7SMatthias Ringwald             // hci_set_chipset(btstack_chipset_bcm_instance());
151c0cdcfe7SMatthias Ringwald             break;
152c0cdcfe7SMatthias Ringwald         case COMPANY_ID_ST_MICROELECTRONICS:
153c0cdcfe7SMatthias Ringwald             printf("ST Microelectronics - using STLC2500d driver.\n");
1543250103aSMatthias Ringwald             use_fast_uart();
155c0cdcfe7SMatthias Ringwald             hci_set_chipset(btstack_chipset_stlc2500d_instance());
156c0cdcfe7SMatthias Ringwald             break;
157c0cdcfe7SMatthias Ringwald         case COMPANY_ID_EM_MICROELECTRONICS_MARIN:
158c0cdcfe7SMatthias Ringwald             printf("EM Microelectronics - using EM9301 driver.\n");
159c0cdcfe7SMatthias Ringwald             hci_set_chipset(btstack_chipset_em9301_instance());
160c0cdcfe7SMatthias Ringwald             break;
161c0cdcfe7SMatthias Ringwald         default:
162c0cdcfe7SMatthias Ringwald             printf("Unknown manufacturer / manufacturer not supported yet.\n");
163c0cdcfe7SMatthias Ringwald             break;
164c0cdcfe7SMatthias Ringwald     }
165c0cdcfe7SMatthias Ringwald }
166c0cdcfe7SMatthias Ringwald 
1678caefee3SMatthias Ringwald int main(int argc, const char * argv[]){
1688caefee3SMatthias Ringwald 
1698caefee3SMatthias Ringwald 	/// GET STARTED with BTstack ///
1708caefee3SMatthias Ringwald 	btstack_memory_init();
171528a4a3bSMatthias Ringwald     btstack_run_loop_init(btstack_run_loop_posix_get_instance());
1728caefee3SMatthias Ringwald 
1738caefee3SMatthias Ringwald     // use logger: format HCI_DUMP_PACKETLOGGER, HCI_DUMP_BLUEZ or HCI_DUMP_STDOUT
1748caefee3SMatthias Ringwald     hci_dump_open("/tmp/hci_dump.pklg", HCI_DUMP_PACKETLOGGER);
1758caefee3SMatthias Ringwald 
1768caefee3SMatthias Ringwald     // pick serial port
177c0cdcfe7SMatthias Ringwald     config.device_name = "/dev/tty.usbserial-A900K0VK";
1788caefee3SMatthias Ringwald 
1798caefee3SMatthias Ringwald     // init HCI
180084ad01cSMatthias Ringwald     const btstack_uart_block_t * uart_driver = btstack_uart_block_posix_instance();
181084ad01cSMatthias Ringwald 	const hci_transport_t * transport = hci_transport_h4_instance(uart_driver);
18254b584ffSMatthias Ringwald     const btstack_link_key_db_t * link_key_db = btstack_link_key_db_fs_instance();
1832d5e09d6SMatthias Ringwald 	hci_init(transport, (void*) &config);
1842d5e09d6SMatthias Ringwald     hci_set_link_key_db(link_key_db);
1858caefee3SMatthias Ringwald 
186d356a6daSMatthias Ringwald     // inform about BTstack state
187d356a6daSMatthias Ringwald     hci_event_callback_registration.callback = &packet_handler;
188d356a6daSMatthias Ringwald     hci_add_event_handler(&hci_event_callback_registration);
189d356a6daSMatthias Ringwald 
190a6ddbcb9SMatthias Ringwald     // setup dynamic chipset driver setup
191a6ddbcb9SMatthias Ringwald     hci_set_local_version_information_callback(&local_version_information_callback);
192c0cdcfe7SMatthias Ringwald 
1938caefee3SMatthias Ringwald     // handle CTRL-c
1948caefee3SMatthias Ringwald     signal(SIGINT, sigint_handler);
1958caefee3SMatthias Ringwald 
1968caefee3SMatthias Ringwald     // setup app
1978caefee3SMatthias Ringwald     btstack_main(argc, argv);
1988caefee3SMatthias Ringwald 
1998caefee3SMatthias Ringwald     // go
200528a4a3bSMatthias Ringwald     btstack_run_loop_execute();
2018caefee3SMatthias Ringwald 
2028caefee3SMatthias Ringwald     return 0;
2038caefee3SMatthias Ringwald }
204