mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-01-26 12:35:25 +00:00
added more AD types
This commit is contained in:
parent
65afca2729
commit
da0af357c3
@ -92,7 +92,8 @@ static bd_addr_t gap_reconnection_address;
|
|||||||
|
|
||||||
static int att_default_value_long = 0;
|
static int att_default_value_long = 0;
|
||||||
|
|
||||||
static uint8_t test_irk[] = { 0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF, 0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF };
|
// static uint8_t test_irk[] = { 0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF, 0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF };
|
||||||
|
static uint8_t test_irk[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
|
||||||
|
|
||||||
static char * sm_io_capabilities = NULL;
|
static char * sm_io_capabilities = NULL;
|
||||||
static int sm_mitm_protection = 0;
|
static int sm_mitm_protection = 0;
|
||||||
@ -150,6 +151,18 @@ static uint8_t adv_data_8[] = { 2, 0x0a, 4 };
|
|||||||
static uint8_t adv_data_9[] = { 2, 0x11, 3 };
|
static uint8_t adv_data_9[] = { 2, 0x11, 3 };
|
||||||
// AD TK Value
|
// AD TK Value
|
||||||
static uint8_t adv_data_0[] = { 17, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
|
static uint8_t adv_data_0[] = { 17, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
|
||||||
|
// AD LE Bluetooth Device Address - 66:55:44:33:22:11 public address
|
||||||
|
static uint8_t adv_data_le_bd_addr[] = { 8, 0x1b, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x00};
|
||||||
|
// AD Appearance
|
||||||
|
static uint8_t adv_data_appearance[] = { 3, 0x19, 0x00, 0x00};
|
||||||
|
// AD LE Role - Peripheral only
|
||||||
|
static uint8_t adv_data_le_role[] = {2 , 0x1c, 0x00};
|
||||||
|
// AD Public Target Address
|
||||||
|
static uint8_t adv_data_public_target_address[] = { 7, 0x17, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66};
|
||||||
|
// AD Random Target Address
|
||||||
|
static uint8_t adv_data_random_target_address[] = { 7, 0x18, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66};
|
||||||
|
// AD Advertising Interval
|
||||||
|
static uint8_t adv_data_advertising_interval[] = { 3, 0x1a, 0x00, 0x80};
|
||||||
|
|
||||||
static uint8_t adv_data_len;
|
static uint8_t adv_data_len;
|
||||||
static uint8_t adv_data[32];
|
static uint8_t adv_data[32];
|
||||||
@ -174,6 +187,12 @@ static advertisement_t advertisements[] = {
|
|||||||
ADV(adv_data_7),
|
ADV(adv_data_7),
|
||||||
ADV(adv_data_8),
|
ADV(adv_data_8),
|
||||||
ADV(adv_data_9),
|
ADV(adv_data_9),
|
||||||
|
ADV(adv_data_le_bd_addr),
|
||||||
|
ADV(adv_data_appearance),
|
||||||
|
ADV(adv_data_le_role),
|
||||||
|
ADV(adv_data_public_target_address),
|
||||||
|
ADV(adv_data_random_target_address),
|
||||||
|
ADV(adv_data_advertising_interval),
|
||||||
};
|
};
|
||||||
|
|
||||||
static int advertisement_index = 2;
|
static int advertisement_index = 2;
|
||||||
@ -604,11 +623,12 @@ void show_usage(){
|
|||||||
printf("x/X - directed connectable off\n");
|
printf("x/X - directed connectable off\n");
|
||||||
printf("y/Y - scannable on/off\n");
|
printf("y/Y - scannable on/off\n");
|
||||||
printf("---\n");
|
printf("---\n");
|
||||||
printf("1 - AD Manufacturer Data | 6 - AD Services\n");
|
printf("1 - AD Manufacturer Data | 7 - AD Slave Preferred... | = - AD Public Target Address\n");
|
||||||
printf("2 - AD Local Name | 7 - AD Slave Preferred Connection Interval Range\n");
|
printf("2 - AD Local Name | 8 - AD Tx Power Level | / - AD Random Target Address\n");
|
||||||
printf("3 - AD flags | 8 - AD Tx Power Level\n");
|
printf("3 - AD flags | 9 - AD SM OOB | # - AD Advertising interval\n");
|
||||||
printf("4 - AD Service Data | 9 - AD SM OOB\n");
|
printf("4 - AD Service Data | 0 - AD SM TK | & - AD LE Role\n");
|
||||||
printf("5 - AD Service Solicitation | 0 - AD SM TK\n");
|
printf("5 - AD Service Solicitation | + - AD LE BD_ADDR\n");
|
||||||
|
printf("6 - AD Services | - - AD Appearance\n");
|
||||||
printf("---\n");
|
printf("---\n");
|
||||||
printf("l/L - default attribute value '%s'/'%s'\n", default_value_short, default_value_long);
|
printf("l/L - default attribute value '%s'/'%s'\n", default_value_short, default_value_long);
|
||||||
printf("p/P - privacy flag off\n");
|
printf("p/P - privacy flag off\n");
|
||||||
@ -766,6 +786,30 @@ int stdin_process(struct data_source *ds){
|
|||||||
advertisement_index = buffer - '0';
|
advertisement_index = buffer - '0';
|
||||||
update_advertisements();
|
update_advertisements();
|
||||||
break;
|
break;
|
||||||
|
case '+':
|
||||||
|
advertisement_index = 10;
|
||||||
|
update_advertisements();
|
||||||
|
break;
|
||||||
|
case '-':
|
||||||
|
advertisement_index = 11;
|
||||||
|
update_advertisements();
|
||||||
|
break;
|
||||||
|
case '&':
|
||||||
|
advertisement_index = 12;
|
||||||
|
update_advertisements();
|
||||||
|
break;
|
||||||
|
case '=':
|
||||||
|
advertisement_index = 13;
|
||||||
|
update_advertisements();
|
||||||
|
break;
|
||||||
|
case '/':
|
||||||
|
advertisement_index = 14;
|
||||||
|
update_advertisements();
|
||||||
|
break;
|
||||||
|
case '#':
|
||||||
|
advertisement_index = 15;
|
||||||
|
update_advertisements();
|
||||||
|
break;
|
||||||
case 's':
|
case 's':
|
||||||
printf("SM: sending security request\n");
|
printf("SM: sending security request\n");
|
||||||
sm_send_security_request();
|
sm_send_security_request();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user