xref: /btstack/port/posix-h5/main.c (revision 4b871b9e05ebf59c9f27b393f258d05f96f462ba)
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 
3894a5538cSMatthias Ringwald // *****************************************************************************
3994a5538cSMatthias Ringwald //
4094a5538cSMatthias Ringwald // minimal setup for HCI code
4194a5538cSMatthias Ringwald //
4294a5538cSMatthias Ringwald // *****************************************************************************
4394a5538cSMatthias Ringwald 
4494a5538cSMatthias Ringwald #include <stdint.h>
4594a5538cSMatthias Ringwald #include <stdio.h>
4694a5538cSMatthias Ringwald #include <stdlib.h>
4794a5538cSMatthias Ringwald #include <string.h>
4894a5538cSMatthias Ringwald #include <signal.h>
4994a5538cSMatthias Ringwald 
5094a5538cSMatthias Ringwald #include "btstack_config.h"
5194a5538cSMatthias Ringwald 
5294a5538cSMatthias Ringwald #include "btstack_debug.h"
5394a5538cSMatthias Ringwald #include "btstack_event.h"
5494a5538cSMatthias Ringwald #include "btstack_link_key_db_fs.h"
5594a5538cSMatthias Ringwald #include "btstack_memory.h"
5694a5538cSMatthias Ringwald #include "btstack_run_loop.h"
5794a5538cSMatthias Ringwald #include "btstack_run_loop_posix.h"
5894a5538cSMatthias Ringwald #include "hci.h"
5994a5538cSMatthias Ringwald #include "hci_dump.h"
6094a5538cSMatthias Ringwald #include "stdin_support.h"
6194a5538cSMatthias Ringwald 
6294a5538cSMatthias Ringwald #include "btstack_chipset_bcm.h"
6394a5538cSMatthias Ringwald #include "btstack_chipset_csr.h"
6494a5538cSMatthias Ringwald #include "btstack_chipset_cc256x.h"
6594a5538cSMatthias Ringwald #include "btstack_chipset_em9301.h"
6694a5538cSMatthias Ringwald #include "btstack_chipset_stlc2500d.h"
6794a5538cSMatthias Ringwald #include "btstack_chipset_tc3566x.h"
6894a5538cSMatthias Ringwald 
6994a5538cSMatthias Ringwald int btstack_main(int argc, const char * argv[]);
7094a5538cSMatthias Ringwald 
7194a5538cSMatthias Ringwald static hci_transport_config_uart_t config = {
7294a5538cSMatthias Ringwald     HCI_TRANSPORT_CONFIG_UART,
7394a5538cSMatthias Ringwald     115200,
7494a5538cSMatthias Ringwald     0,  // main baudrate
7594a5538cSMatthias Ringwald     1,  // flow control
7694a5538cSMatthias Ringwald     NULL,
7794a5538cSMatthias Ringwald };
7894a5538cSMatthias Ringwald 
7994a5538cSMatthias Ringwald static btstack_packet_callback_registration_t hci_event_callback_registration;
8094a5538cSMatthias Ringwald 
8194a5538cSMatthias Ringwald static void sigint_handler(int param){
8294a5538cSMatthias Ringwald 
8394a5538cSMatthias Ringwald #ifndef _WIN32
8494a5538cSMatthias Ringwald     // reset anyway
8594a5538cSMatthias Ringwald     btstack_stdin_reset();
8694a5538cSMatthias Ringwald #endif
8794a5538cSMatthias Ringwald 
8894a5538cSMatthias Ringwald     log_info(" <= SIGINT received, shutting down..\n");
8994a5538cSMatthias Ringwald     hci_power_control(HCI_POWER_OFF);
9094a5538cSMatthias Ringwald     hci_close();
9194a5538cSMatthias Ringwald     log_info("Good bye, see you.\n");
9294a5538cSMatthias Ringwald     exit(0);
9394a5538cSMatthias Ringwald }
9494a5538cSMatthias Ringwald 
9594a5538cSMatthias Ringwald static int led_state = 0;
9694a5538cSMatthias Ringwald void hal_led_toggle(void){
9794a5538cSMatthias Ringwald     led_state = 1 - led_state;
9894a5538cSMatthias Ringwald     printf("LED State %u\n", led_state);
9994a5538cSMatthias Ringwald }
10094a5538cSMatthias Ringwald static void use_fast_uart(void){
10194a5538cSMatthias Ringwald     // printf("Using 921600 baud.\n");
10294a5538cSMatthias Ringwald     // config.baudrate_main = 921600;
10394a5538cSMatthias Ringwald }
10494a5538cSMatthias Ringwald 
10594a5538cSMatthias Ringwald static void local_version_information_callback(uint8_t * packet){
10694a5538cSMatthias Ringwald     printf("Local version information:\n");
10794a5538cSMatthias Ringwald     uint16_t hci_version    = little_endian_read_16(packet, 4);
10894a5538cSMatthias Ringwald     uint16_t hci_revision   = little_endian_read_16(packet, 6);
10994a5538cSMatthias Ringwald     uint16_t lmp_version    = little_endian_read_16(packet, 8);
11094a5538cSMatthias Ringwald     uint16_t manufacturer   = little_endian_read_16(packet, 10);
11194a5538cSMatthias Ringwald     uint16_t lmp_subversion = little_endian_read_16(packet, 12);
11294a5538cSMatthias Ringwald     printf("- HCI Version  0x%04x\n", hci_version);
11394a5538cSMatthias Ringwald     printf("- HCI Revision 0x%04x\n", hci_revision);
11494a5538cSMatthias Ringwald     printf("- LMP Version  0x%04x\n", lmp_version);
11594a5538cSMatthias Ringwald     printf("- LMP Revision 0x%04x\n", lmp_subversion);
11694a5538cSMatthias Ringwald     printf("- Manufacturer 0x%04x\n", manufacturer);
11794a5538cSMatthias Ringwald     switch (manufacturer){
11894a5538cSMatthias Ringwald         case COMPANY_ID_CAMBRIDGE_SILICON_RADIO:
11994a5538cSMatthias Ringwald             printf("Cambridge Silicon Radio CSR chipset.\n");
12094a5538cSMatthias Ringwald             use_fast_uart();
12194a5538cSMatthias Ringwald             hci_set_chipset(btstack_chipset_csr_instance());
12294a5538cSMatthias Ringwald             break;
12394a5538cSMatthias Ringwald         case COMPANY_ID_TEXAS_INSTRUMENTS_INC:
12494a5538cSMatthias Ringwald             printf("Texas Instruments - CC256x compatible chipset.\n");
12594a5538cSMatthias Ringwald             use_fast_uart();
12694a5538cSMatthias Ringwald             hci_set_chipset(btstack_chipset_cc256x_instance());
12794a5538cSMatthias Ringwald             break;
12894a5538cSMatthias Ringwald         case COMPANY_ID_BROADCOM_CORPORATION:
12994a5538cSMatthias Ringwald             printf("Broadcom chipset. Not supported yet\n");
13094a5538cSMatthias Ringwald             // hci_set_chipset(btstack_chipset_bcm_instance());
13194a5538cSMatthias Ringwald             break;
13294a5538cSMatthias Ringwald         case COMPANY_ID_ST_MICROELECTRONICS:
13394a5538cSMatthias Ringwald             printf("ST Microelectronics - using STLC2500d driver.\n");
13494a5538cSMatthias Ringwald             use_fast_uart();
13594a5538cSMatthias Ringwald             hci_set_chipset(btstack_chipset_stlc2500d_instance());
13694a5538cSMatthias Ringwald             break;
13794a5538cSMatthias Ringwald         case COMPANY_ID_EM_MICROELECTRONICS_MARIN:
13894a5538cSMatthias Ringwald             printf("EM Microelectronics - using EM9301 driver.\n");
13994a5538cSMatthias Ringwald             hci_set_chipset(btstack_chipset_em9301_instance());
14094a5538cSMatthias Ringwald             break;
14194a5538cSMatthias Ringwald         default:
14294a5538cSMatthias Ringwald             printf("Unknown manufacturer / manufacturer not supported yet.\n");
14394a5538cSMatthias Ringwald             break;
14494a5538cSMatthias Ringwald     }
14594a5538cSMatthias Ringwald }
14694a5538cSMatthias Ringwald 
14794a5538cSMatthias Ringwald static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
14894a5538cSMatthias Ringwald     if (packet_type != HCI_EVENT_PACKET) return;
14994a5538cSMatthias Ringwald     if (hci_event_packet_get_type(packet) != BTSTACK_EVENT_STATE) return;
15094a5538cSMatthias Ringwald     if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
15194a5538cSMatthias Ringwald     printf("BTstack up and running.\n");
15294a5538cSMatthias Ringwald }
15394a5538cSMatthias Ringwald 
15494a5538cSMatthias Ringwald 
15594a5538cSMatthias Ringwald int main(int argc, const char * argv[]){
15694a5538cSMatthias Ringwald 
15794a5538cSMatthias Ringwald 	/// GET STARTED with BTstack ///
15894a5538cSMatthias Ringwald 	btstack_memory_init();
15994a5538cSMatthias Ringwald     btstack_run_loop_init(btstack_run_loop_posix_get_instance());
16094a5538cSMatthias Ringwald 
16194a5538cSMatthias Ringwald     // use logger: format HCI_DUMP_PACKETLOGGER, HCI_DUMP_BLUEZ or HCI_DUMP_STDOUT
16294a5538cSMatthias Ringwald     hci_dump_open("/tmp/hci_dump.pklg", HCI_DUMP_PACKETLOGGER);
16394a5538cSMatthias Ringwald 
16494a5538cSMatthias Ringwald     // pick serial port
16594a5538cSMatthias Ringwald     config.device_name = "/dev/tty.usbserial-A900K0VK";
16694a5538cSMatthias Ringwald 
16794a5538cSMatthias Ringwald     // init HCI
16894a5538cSMatthias Ringwald     const btstack_uart_block_t * uart_driver = btstack_uart_block_posix_instance();
16994a5538cSMatthias Ringwald     const hci_transport_t * transport = hci_transport_h5_instance(uart_driver);
17094a5538cSMatthias Ringwald     const btstack_link_key_db_t * link_key_db = btstack_link_key_db_fs_instance();
17194a5538cSMatthias Ringwald 	hci_init(transport, (void*) &config);
17294a5538cSMatthias Ringwald     hci_set_link_key_db(link_key_db);
17394a5538cSMatthias Ringwald 
174*4b871b9eSMatthias Ringwald     // enable auto-sleep mode
175*4b871b9eSMatthias Ringwald     // hci_transport_h5_set_auto_sleep(300);
176*4b871b9eSMatthias Ringwald 
17794a5538cSMatthias Ringwald     // setup dynamic chipset driver setup
17894a5538cSMatthias Ringwald     hci_set_local_version_information_callback(&local_version_information_callback);
17994a5538cSMatthias Ringwald 
18094a5538cSMatthias Ringwald     // register for HCI events
18194a5538cSMatthias Ringwald     hci_event_callback_registration.callback = &packet_handler;
18294a5538cSMatthias Ringwald     hci_add_event_handler(&hci_event_callback_registration);
18394a5538cSMatthias Ringwald 
18494a5538cSMatthias Ringwald     // handle CTRL-c
18594a5538cSMatthias Ringwald     signal(SIGINT, sigint_handler);
18694a5538cSMatthias Ringwald 
18794a5538cSMatthias Ringwald     // setup app
18894a5538cSMatthias Ringwald     btstack_main(argc, argv);
18994a5538cSMatthias Ringwald 
19094a5538cSMatthias Ringwald     // go
19194a5538cSMatthias Ringwald     btstack_run_loop_execute();
19294a5538cSMatthias Ringwald 
19394a5538cSMatthias Ringwald     return 0;
19494a5538cSMatthias Ringwald }
195