mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-04-16 08:42:28 +00:00
cc256x: add check for manufacturer and lmp_subversion to ports with cc256x
This commit is contained in:
parent
ed5d91bab6
commit
65aee4ee6a
@ -77,9 +77,32 @@ static btstack_packet_callback_registration_t hci_event_callback_registration;
|
|||||||
|
|
||||||
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
|
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
|
||||||
if (packet_type != HCI_EVENT_PACKET) return;
|
if (packet_type != HCI_EVENT_PACKET) return;
|
||||||
if (hci_event_packet_get_type(packet) != BTSTACK_EVENT_STATE) return;
|
switch(hci_event_packet_get_type(packet)){
|
||||||
if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
|
case BTSTACK_EVENT_STATE:
|
||||||
printf("BTstack up and running.\n");
|
if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
|
||||||
|
printf("BTstack up and running.\n");
|
||||||
|
break;
|
||||||
|
case HCI_EVENT_COMMAND_COMPLETE:
|
||||||
|
if (HCI_EVENT_IS_COMMAND_COMPLETE(packet, hci_read_local_version_information)){
|
||||||
|
uint16_t manufacturer = little_endian_read_16(packet, 10);
|
||||||
|
uint16_t lmp_subversion = little_endian_read_16(packet, 12);
|
||||||
|
// assert manufacturer is TI
|
||||||
|
if (manufacturer != COMPANY_ID_TEXAS_INSTRUMENTS_INC){
|
||||||
|
printf("ERROR: Expected Bluetooth Chipset from TI but got manufacturer 0x%04x\n", manufacturer);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// assert correct init script is used based on expected lmp_subversion
|
||||||
|
if (lmp_subversion != btstack_chipset_cc256x_lmp_subversion()){
|
||||||
|
printf("Error: LMP Subversion does not match initscript! ");
|
||||||
|
printf("Your initscripts is for %s chipset\n", btstack_chipset_cc256x_lmp_subversion() < lmp_subversion ? "an older" : "a newer");
|
||||||
|
printf("Please update Makefile to include the appropriate bluetooth_init_cc256???.c file\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// main
|
// main
|
||||||
|
@ -96,9 +96,32 @@ static btstack_packet_callback_registration_t hci_event_callback_registration;
|
|||||||
|
|
||||||
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
|
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
|
||||||
if (packet_type != HCI_EVENT_PACKET) return;
|
if (packet_type != HCI_EVENT_PACKET) return;
|
||||||
if (hci_event_packet_get_type(packet) != BTSTACK_EVENT_STATE) return;
|
switch(hci_event_packet_get_type(packet)){
|
||||||
if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
|
case BTSTACK_EVENT_STATE:
|
||||||
printf("BTstack up and running.\n");
|
if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
|
||||||
|
printf("BTstack up and running.\n");
|
||||||
|
break;
|
||||||
|
case HCI_EVENT_COMMAND_COMPLETE:
|
||||||
|
if (HCI_EVENT_IS_COMMAND_COMPLETE(packet, hci_read_local_version_information)){
|
||||||
|
uint16_t manufacturer = little_endian_read_16(packet, 10);
|
||||||
|
uint16_t lmp_subversion = little_endian_read_16(packet, 12);
|
||||||
|
// assert manufacturer is TI
|
||||||
|
if (manufacturer != COMPANY_ID_TEXAS_INSTRUMENTS_INC){
|
||||||
|
printf("ERROR: Expected Bluetooth Chipset from TI but got manufacturer 0x%04x\n", manufacturer);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// assert correct init script is used based on expected lmp_subversion
|
||||||
|
if (lmp_subversion != btstack_chipset_cc256x_lmp_subversion()){
|
||||||
|
printf("Error: LMP Subversion does not match initscript! ");
|
||||||
|
printf("Your initscripts is for %s chipset\n", btstack_chipset_cc256x_lmp_subversion() < lmp_subversion ? "an older" : "a newer");
|
||||||
|
printf("Please update Makefile to include the appropriate bluetooth_init_cc256???.c file\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void btstack_setup(void){
|
static void btstack_setup(void){
|
||||||
|
@ -100,9 +100,32 @@ static btstack_packet_callback_registration_t hci_event_callback_registration;
|
|||||||
|
|
||||||
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
|
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
|
||||||
if (packet_type != HCI_EVENT_PACKET) return;
|
if (packet_type != HCI_EVENT_PACKET) return;
|
||||||
if (hci_event_packet_get_type(packet) != BTSTACK_EVENT_STATE) return;
|
switch(hci_event_packet_get_type(packet)){
|
||||||
if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
|
case BTSTACK_EVENT_STATE:
|
||||||
printf("BTstack up and running.\n");
|
if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
|
||||||
|
printf("BTstack up and running.\n");
|
||||||
|
break;
|
||||||
|
case HCI_EVENT_COMMAND_COMPLETE:
|
||||||
|
if (HCI_EVENT_IS_COMMAND_COMPLETE(packet, hci_read_local_version_information)){
|
||||||
|
uint16_t manufacturer = little_endian_read_16(packet, 10);
|
||||||
|
uint16_t lmp_subversion = little_endian_read_16(packet, 12);
|
||||||
|
// assert manufacturer is TI
|
||||||
|
if (manufacturer != COMPANY_ID_TEXAS_INSTRUMENTS_INC){
|
||||||
|
printf("ERROR: Expected Bluetooth Chipset from TI but got manufacturer 0x%04x\n", manufacturer);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// assert correct init script is used based on expected lmp_subversion
|
||||||
|
if (lmp_subversion != btstack_chipset_cc256x_lmp_subversion()){
|
||||||
|
printf("Error: LMP Subversion does not match initscript! ");
|
||||||
|
printf("Your initscripts is for %s chipset\n", btstack_chipset_cc256x_lmp_subversion() < lmp_subversion ? "an older" : "a newer");
|
||||||
|
printf("Please update Makefile to include the appropriate bluetooth_init_cc256???.c file\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void btstack_setup(void){
|
static void btstack_setup(void){
|
||||||
|
@ -416,9 +416,32 @@ static const hci_transport_config_uart_t config = {
|
|||||||
|
|
||||||
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
|
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size){
|
||||||
if (packet_type != HCI_EVENT_PACKET) return;
|
if (packet_type != HCI_EVENT_PACKET) return;
|
||||||
if (hci_event_packet_get_type(packet) != BTSTACK_EVENT_STATE) return;
|
switch(hci_event_packet_get_type(packet)){
|
||||||
if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
|
case BTSTACK_EVENT_STATE:
|
||||||
printf("BTstack up and running.\n");
|
if (btstack_event_state_get_state(packet) != HCI_STATE_WORKING) return;
|
||||||
|
printf("BTstack up and running.\n");
|
||||||
|
break;
|
||||||
|
case HCI_EVENT_COMMAND_COMPLETE:
|
||||||
|
if (HCI_EVENT_IS_COMMAND_COMPLETE(packet, hci_read_local_version_information)){
|
||||||
|
uint16_t manufacturer = little_endian_read_16(packet, 10);
|
||||||
|
uint16_t lmp_subversion = little_endian_read_16(packet, 12);
|
||||||
|
// assert manufacturer is TI
|
||||||
|
if (manufacturer != COMPANY_ID_TEXAS_INSTRUMENTS_INC){
|
||||||
|
printf("ERROR: Expected Bluetooth Chipset from TI but got manufacturer 0x%04x\n", manufacturer);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// assert correct init script is used based on expected lmp_subversion
|
||||||
|
if (lmp_subversion != btstack_chipset_cc256x_lmp_subversion()){
|
||||||
|
printf("Error: LMP Subversion does not match initscript! ");
|
||||||
|
printf("Your initscripts is for %s chipset\n", btstack_chipset_cc256x_lmp_subversion() < lmp_subversion ? "an older" : "a newer");
|
||||||
|
printf("Please update Makefile to include the appropriate bluetooth_init_cc256???.c file\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user