xref: /btstack/port/posix-h5/main.c (revision ab2c6ae4b737d5e801d3defe4117331eb244ebb7)
194a5538cSMatthias Ringwald /*
294a5538cSMatthias Ringwald  * Copyright (C) 2014 BlueKitchen GmbH
394a5538cSMatthias Ringwald  *
494a5538cSMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
594a5538cSMatthias Ringwald  * modification, are permitted provided that the following conditions
694a5538cSMatthias Ringwald  * are met:
794a5538cSMatthias Ringwald  *
894a5538cSMatthias Ringwald  * 1. Redistributions of source code must retain the above copyright
994a5538cSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
1094a5538cSMatthias Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
1194a5538cSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
1294a5538cSMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
1394a5538cSMatthias Ringwald  * 3. Neither the name of the copyright holders nor the names of
1494a5538cSMatthias Ringwald  *    contributors may be used to endorse or promote products derived
1594a5538cSMatthias Ringwald  *    from this software without specific prior written permission.
1694a5538cSMatthias Ringwald  * 4. Any redistribution, use, or modification is done solely for
1794a5538cSMatthias Ringwald  *    personal benefit and not for any commercial purpose or for
1894a5538cSMatthias Ringwald  *    monetary gain.
1994a5538cSMatthias Ringwald  *
2094a5538cSMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
2194a5538cSMatthias Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
2294a5538cSMatthias Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
2394a5538cSMatthias Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
2494a5538cSMatthias Ringwald  * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
2594a5538cSMatthias Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
2694a5538cSMatthias Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
2794a5538cSMatthias Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
2894a5538cSMatthias Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
2994a5538cSMatthias Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
3094a5538cSMatthias Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
3194a5538cSMatthias Ringwald  * SUCH DAMAGE.
3294a5538cSMatthias Ringwald  *
3394a5538cSMatthias Ringwald  * Please inquire about commercial licensing options at
3494a5538cSMatthias Ringwald  * [email protected]
3594a5538cSMatthias Ringwald  *
3694a5538cSMatthias Ringwald  */
3794a5538cSMatthias Ringwald 
38*ab2c6ae4SMatthias Ringwald #define __BTSTACK_FILE__ "main.c"
39*ab2c6ae4SMatthias Ringwald 
4094a5538cSMatthias Ringwald // *****************************************************************************
4194a5538cSMatthias Ringwald //
4294a5538cSMatthias Ringwald // minimal setup for HCI code
4394a5538cSMatthias Ringwald //
4494a5538cSMatthias Ringwald // *****************************************************************************
4594a5538cSMatthias Ringwald 
4694a5538cSMatthias Ringwald #include <stdint.h>
4794a5538cSMatthias Ringwald #include <stdio.h>
4894a5538cSMatthias Ringwald #include <stdlib.h>
4994a5538cSMatthias Ringwald #include <string.h>
5094a5538cSMatthias Ringwald #include <signal.h>
5194a5538cSMatthias Ringwald 
5294a5538cSMatthias Ringwald #include "btstack_config.h"
5394a5538cSMatthias Ringwald 
5494a5538cSMatthias Ringwald #include "btstack_debug.h"
5594a5538cSMatthias Ringwald #include "btstack_event.h"
5694a5538cSMatthias Ringwald #include "btstack_link_key_db_fs.h"
5794a5538cSMatthias Ringwald #include "btstack_memory.h"
5894a5538cSMatthias Ringwald #include "btstack_run_loop.h"
5994a5538cSMatthias Ringwald #include "btstack_run_loop_posix.h"
6094a5538cSMatthias Ringwald #include "hci.h"
6194a5538cSMatthias Ringwald #include "hci_dump.h"
6294a5538cSMatthias Ringwald #include "stdin_support.h"
6394a5538cSMatthias Ringwald 
6494a5538cSMatthias Ringwald #include "btstack_chipset_bcm.h"
6594a5538cSMatthias Ringwald #include "btstack_chipset_csr.h"
6694a5538cSMatthias Ringwald #include "btstack_chipset_cc256x.h"
6794a5538cSMatthias Ringwald #include "btstack_chipset_em9301.h"
6894a5538cSMatthias Ringwald #include "btstack_chipset_stlc2500d.h"
6994a5538cSMatthias Ringwald #include "btstack_chipset_tc3566x.h"
7094a5538cSMatthias Ringwald 
7194a5538cSMatthias Ringwald int btstack_main(int argc, const char * argv[]);
7294a5538cSMatthias Ringwald 
7391858f18SMatthias Ringwald 
7494a5538cSMatthias Ringwald static hci_transport_config_uart_t config = {
7594a5538cSMatthias Ringwald     HCI_TRANSPORT_CONFIG_UART,
7694a5538cSMatthias Ringwald     115200,
7794a5538cSMatthias Ringwald     0,  // main baudrate
7894a5538cSMatthias Ringwald     1,  // flow control
7994a5538cSMatthias Ringwald     NULL,
8094a5538cSMatthias Ringwald };
8194a5538cSMatthias Ringwald 
8291858f18SMatthias Ringwald int is_bcm;
8391858f18SMatthias Ringwald 
8494a5538cSMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration;
8591858f18SMatthias Ringwald static void local_version_information_handler(uint8_t * packet);
8694a5538cSMatthias Ringwald 
8794a5538cSMatthias Ringwald static void sigint_handler(int param){
88b96c8f44SMatthias Ringwald     UNUSED(param);
8994a5538cSMatthias Ringwald 
90b96c8f44SMatthias Ringwald     printf("CTRL-C - SIGINT received, shutting down..\n");
91b96c8f44SMatthias Ringwald     log_info("sigint_handler: shutting down");
92b96c8f44SMatthias Ringwald 
9394a5538cSMatthias Ringwald     // reset anyway
9494a5538cSMatthias Ringwald     btstack_stdin_reset();
9594a5538cSMatthias Ringwald 
96b96c8f44SMatthias Ringwald     // power down
9794a5538cSMatthias Ringwald     hci_power_control(HCI_POWER_OFF);
9894a5538cSMatthias Ringwald     hci_close();
9994a5538cSMatthias Ringwald     log_info("Good bye, see you.\n");
10094a5538cSMatthias Ringwald     exit(0);
10194a5538cSMatthias Ringwald }
10294a5538cSMatthias Ringwald 
10394a5538cSMatthias Ringwald static int led_state = 0;
10494a5538cSMatthias Ringwald void hal_led_toggle(void){
10594a5538cSMatthias Ringwald     led_state = 1 - led_state;
10694a5538cSMatthias Ringwald     printf("LED State %u\n", led_state);
10794a5538cSMatthias Ringwald }
10894a5538cSMatthias Ringwald static void use_fast_uart(void){
10994a5538cSMatthias Ringwald     // printf("Using 921600 baud.\n");
11094a5538cSMatthias Ringwald     // config.baudrate_main = 921600;
11194a5538cSMatthias Ringwald }
11294a5538cSMatthias Ringwald 
11391858f18SMatthias Ringwald static void local_version_information_handler(uint8_t * packet){
11494a5538cSMatthias Ringwald     printf("Local version information:\n");
11594a5538cSMatthias Ringwald     uint16_t hci_version    = little_endian_read_16(packet, 4);
11694a5538cSMatthias Ringwald     uint16_t hci_revision   = little_endian_read_16(packet, 6);
11794a5538cSMatthias Ringwald     uint16_t lmp_version    = little_endian_read_16(packet, 8);
11894a5538cSMatthias Ringwald     uint16_t manufacturer   = little_endian_read_16(packet, 10);
11994a5538cSMatthias Ringwald     uint16_t lmp_subversion = little_endian_read_16(packet, 12);
12094a5538cSMatthias Ringwald     printf("- HCI Version  0x%04x\n", hci_version);
12194a5538cSMatthias Ringwald     printf("- HCI Revision 0x%04x\n", hci_revision);
12294a5538cSMatthias Ringwald     printf("- LMP Version  0x%04x\n", lmp_version);
12394a5538cSMatthias Ringwald     printf("- LMP Revision 0x%04x\n", lmp_subversion);
12494a5538cSMatthias Ringwald     printf("- Manufacturer 0x%04x\n", manufacturer);
12594a5538cSMatthias Ringwald     switch (manufacturer){
12694a5538cSMatthias Ringwald         case COMPANY_ID_CAMBRIDGE_SILICON_RADIO:
12794a5538cSMatthias Ringwald             printf("Cambridge Silicon Radio CSR chipset.\n");
12894a5538cSMatthias Ringwald             use_fast_uart();
12994a5538cSMatthias Ringwald             hci_set_chipset(btstack_chipset_csr_instance());
13094a5538cSMatthias Ringwald             break;
13194a5538cSMatthias Ringwald         case COMPANY_ID_TEXAS_INSTRUMENTS_INC:
13294a5538cSMatthias Ringwald             printf("Texas Instruments - CC256x compatible chipset.\n");
13394a5538cSMatthias Ringwald             use_fast_uart();
13494a5538cSMatthias Ringwald             hci_set_chipset(btstack_chipset_cc256x_instance());
13594a5538cSMatthias Ringwald             break;
13694a5538cSMatthias Ringwald         case COMPANY_ID_BROADCOM_CORPORATION:
13794a5538cSMatthias Ringwald             printf("Broadcom chipset. Not supported yet\n");
13894a5538cSMatthias Ringwald             // hci_set_chipset(btstack_chipset_bcm_instance());
13994a5538cSMatthias Ringwald             break;
14094a5538cSMatthias Ringwald         case COMPANY_ID_ST_MICROELECTRONICS:
14194a5538cSMatthias Ringwald             printf("ST Microelectronics - using STLC2500d driver.\n");
14294a5538cSMatthias Ringwald             use_fast_uart();
14394a5538cSMatthias Ringwald             hci_set_chipset(btstack_chipset_stlc2500d_instance());
14494a5538cSMatthias Ringwald             break;
14594a5538cSMatthias Ringwald         case COMPANY_ID_EM_MICROELECTRONICS_MARIN:
14694a5538cSMatthias Ringwald             printf("EM Microelectronics - using EM9301 driver.\n");
14794a5538cSMatthias Ringwald             hci_set_chipset(btstack_chipset_em9301_instance());
14894a5538cSMatthias Ringwald             break;
14994a5538cSMatthias Ringwald         default:
15094a5538cSMatthias Ringwald             printf("Unknown manufacturer / manufacturer not supported yet.\n");
15194a5538cSMatthias Ringwald             break;
15294a5538cSMatthias Ringwald     }
15394a5538cSMatthias Ringwald }
15494a5538cSMatthias Ringwald 
15594a5538cSMatthias Ringwald static void packet_handler(uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
15694a5538cSMatthias Ringwald     if (packet_type != HCI_EVENT_PACKET) return;
15791858f18SMatthias Ringwald     switch (hci_event_packet_get_type(packet)){
15891858f18SMatthias Ringwald         case BTSTACK_EVENT_STATE:
15991858f18SMatthias Ringwald             if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) break;
16094a5538cSMatthias Ringwald             printf("BTstack up and running.\n");
16191858f18SMatthias Ringwald             break;
16291858f18SMatthias Ringwald         case HCI_EVENT_COMMAND_COMPLETE:
16391858f18SMatthias Ringwald             if (HCI_EVENT_IS_COMMAND_COMPLETE(packet, hci_read_local_name)){
16491858f18SMatthias Ringwald                 if (hci_event_command_complete_get_return_parameters(packet)[0]) break;
16591858f18SMatthias Ringwald                 // terminate, name 248 chars
16691858f18SMatthias Ringwald                 packet[6+248] = 0;
16791858f18SMatthias Ringwald                 printf("Local name: %s\n", &packet[6]);
16891858f18SMatthias Ringwald                 if (is_bcm){
16991858f18SMatthias Ringwald                     btstack_chipset_bcm_set_device_name((const char *)&packet[6]);
17094a5538cSMatthias Ringwald                 }
17191858f18SMatthias Ringwald             }
17291858f18SMatthias Ringwald             if (HCI_EVENT_IS_COMMAND_COMPLETE(packet, hci_read_local_version_information)){
17391858f18SMatthias Ringwald                 local_version_information_handler(packet);
17491858f18SMatthias Ringwald             }
17591858f18SMatthias Ringwald             break;
17691858f18SMatthias Ringwald         default:
17791858f18SMatthias Ringwald             break;
17891858f18SMatthias Ringwald     }
17991858f18SMatthias Ringwald }
18094a5538cSMatthias Ringwald 
18194a5538cSMatthias Ringwald int main(int argc, const char * argv[]){
18294a5538cSMatthias Ringwald 
18394a5538cSMatthias Ringwald 	/// GET STARTED with BTstack ///
18494a5538cSMatthias Ringwald 	btstack_memory_init();
18594a5538cSMatthias Ringwald     btstack_run_loop_init(btstack_run_loop_posix_get_instance());
18694a5538cSMatthias Ringwald 
18794a5538cSMatthias Ringwald     // use logger: format HCI_DUMP_PACKETLOGGER, HCI_DUMP_BLUEZ or HCI_DUMP_STDOUT
18894a5538cSMatthias Ringwald     hci_dump_open("/tmp/hci_dump.pklg", HCI_DUMP_PACKETLOGGER);
18994a5538cSMatthias Ringwald 
19094a5538cSMatthias Ringwald     // pick serial port
19194a5538cSMatthias Ringwald     config.device_name = "/dev/tty.usbserial-A900K0VK";
19294a5538cSMatthias Ringwald 
19394a5538cSMatthias Ringwald     // init HCI
19494a5538cSMatthias Ringwald     const btstack_uart_block_t * uart_driver = btstack_uart_block_posix_instance();
19594a5538cSMatthias Ringwald     const hci_transport_t * transport = hci_transport_h5_instance(uart_driver);
19694a5538cSMatthias Ringwald     const btstack_link_key_db_t * link_key_db = btstack_link_key_db_fs_instance();
19794a5538cSMatthias Ringwald 	hci_init(transport, (void*) &config);
19894a5538cSMatthias Ringwald     hci_set_link_key_db(link_key_db);
19994a5538cSMatthias Ringwald 
2004b871b9eSMatthias Ringwald     // enable auto-sleep mode
2014b871b9eSMatthias Ringwald     // hci_transport_h5_set_auto_sleep(300);
2024b871b9eSMatthias Ringwald 
20394a5538cSMatthias Ringwald     // register for HCI events
20494a5538cSMatthias Ringwald     hci_event_callback_registration.callback = &packet_handler;
20594a5538cSMatthias Ringwald     hci_add_event_handler(&hci_event_callback_registration);
20694a5538cSMatthias Ringwald 
20794a5538cSMatthias Ringwald     // handle CTRL-c
20894a5538cSMatthias Ringwald     signal(SIGINT, sigint_handler);
20994a5538cSMatthias Ringwald 
21094a5538cSMatthias Ringwald     // setup app
21194a5538cSMatthias Ringwald     btstack_main(argc, argv);
21294a5538cSMatthias Ringwald 
21394a5538cSMatthias Ringwald     // go
21494a5538cSMatthias Ringwald     btstack_run_loop_execute();
21594a5538cSMatthias Ringwald 
21694a5538cSMatthias Ringwald     return 0;
21794a5538cSMatthias Ringwald }
218