mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-03-29 22:20:37 +00:00
implemeted SDP PANU and GN service record
This commit is contained in:
parent
254e71e6e7
commit
5dc81bdaad
92
src/pan.c
92
src/pan.c
@ -47,12 +47,21 @@
|
||||
|
||||
#include <btstack/sdp_util.h>
|
||||
|
||||
static const char default_service_name[] = "Network Access Point Service";
|
||||
static const char default_service_desc[] = "Personal Ad-hoc Network Service which provides access to a network";
|
||||
static uint16_t PANU_UUID = 0x1115;
|
||||
static uint16_t NAP_UUID = 0x1116;
|
||||
static uint16_t GN_UUID = 0x1117;
|
||||
|
||||
static const char default_panu_service_name[] = "Personal Ad-hoc User Service";
|
||||
static const char default_panu_service_desc[] = "Personal Ad-hoc User Service";
|
||||
|
||||
void pan_create_nap_service(uint8_t *service, uint16_t net_access_type, uint32_t max_net_access_rate,
|
||||
const char *name, const char *descriptor, const char *IPv4Subnet, const char *IPv6Subnet){
|
||||
static const char default_nap_service_name[] = "Network Access Point Service";
|
||||
static const char default_nap_service_desc[] = "Personal Ad-hoc Network Service which provides access to a network";
|
||||
|
||||
static const char default_gn_service_name[] = "Group Ad-hoc Network Service";
|
||||
static const char default_gn_service_desc[] = "Personal Group Ad-hoc Network Service";
|
||||
|
||||
void pan_create_service(uint16_t service_uuid, uint8_t *service, const char *name, const char *descriptor,
|
||||
const char *IPv4Subnet, const char *IPv6Subnet, uint16_t net_access_type, uint32_t max_net_access_rate){
|
||||
|
||||
uint8_t* attribute;
|
||||
de_create_sequence(service);
|
||||
@ -65,8 +74,8 @@ void pan_create_nap_service(uint8_t *service, uint16_t net_access_type, uint32_t
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, SDP_ServiceClassIDList);
|
||||
attribute = de_push_sequence(service);
|
||||
{
|
||||
// 0x1116 "UUID for NAP"
|
||||
de_add_number(attribute, DE_UUID, DE_SIZE_16, 0x1116 );
|
||||
// "UUID for PAN Service"
|
||||
de_add_number(attribute, DE_UUID, DE_SIZE_16, service_uuid);
|
||||
}
|
||||
de_pop_sequence(service, attribute);
|
||||
|
||||
@ -124,7 +133,7 @@ void pan_create_nap_service(uint8_t *service, uint16_t net_access_type, uint32_t
|
||||
{
|
||||
uint8_t *sppProfile = de_push_sequence(attribute);
|
||||
{
|
||||
de_add_number(sppProfile, DE_UUID, DE_SIZE_16, 0x1116); // UUID for NAP
|
||||
de_add_number(sppProfile, DE_UUID, DE_SIZE_16, service_uuid);
|
||||
de_add_number(sppProfile, DE_UINT, DE_SIZE_16, 0x0100); // Verision 1.0
|
||||
}
|
||||
de_pop_sequence(attribute, sppProfile);
|
||||
@ -136,7 +145,19 @@ void pan_create_nap_service(uint8_t *service, uint16_t net_access_type, uint32_t
|
||||
if (name){
|
||||
de_add_data(service, DE_STRING, strlen(name), (uint8_t *) name);
|
||||
} else {
|
||||
de_add_data(service, DE_STRING, strlen(default_service_name), (uint8_t *) default_service_name);
|
||||
switch (service_uuid){
|
||||
case PANU_UUID:
|
||||
de_add_data(service, DE_STRING, strlen(default_panu_service_name), (uint8_t *) default_panu_service_name);
|
||||
break;
|
||||
case NAP_UUID:
|
||||
de_add_data(service, DE_STRING, strlen(default_nap_service_name), (uint8_t *) default_nap_service_name);
|
||||
break;
|
||||
case GN_UUID:
|
||||
de_add_data(service, DE_STRING, strlen(default_gn_service_name), (uint8_t *) default_gn_service_name);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// 0x0101 "Service Description"
|
||||
@ -144,13 +165,41 @@ void pan_create_nap_service(uint8_t *service, uint16_t net_access_type, uint32_t
|
||||
if (descriptor){
|
||||
de_add_data(service, DE_STRING, strlen(descriptor), (uint8_t *) descriptor);
|
||||
} else {
|
||||
de_add_data(service, DE_STRING, strlen(default_service_desc), (uint8_t *) default_service_desc);
|
||||
switch (service_uuid){
|
||||
case PANU_UUID:
|
||||
de_add_data(service, DE_STRING, strlen(default_panu_service_desc), (uint8_t *) default_panu_service_desc);
|
||||
break;
|
||||
case NAP_UUID:
|
||||
de_add_data(service, DE_STRING, strlen(default_nap_service_desc), (uint8_t *) default_nap_service_desc);
|
||||
break;
|
||||
case GN_UUID:
|
||||
de_add_data(service, DE_STRING, strlen(default_gn_service_desc), (uint8_t *) default_gn_service_desc);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// 0x030A "Security Description"
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, 0x030A);
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, 0x0000);
|
||||
|
||||
if (service_uuid == PANU_UUID) return;
|
||||
|
||||
if (IPv4Subnet){
|
||||
// 0x030D "IPv4Subnet", optional
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, 0x030D);
|
||||
de_add_data(service, DE_STRING, strlen(IPv4Subnet), (uint8_t *) IPv4Subnet);
|
||||
}
|
||||
|
||||
if (IPv6Subnet){
|
||||
// 0x030E "IPv6Subnet", optional
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, 0x030E);
|
||||
de_add_data(service, DE_STRING, strlen(IPv6Subnet), (uint8_t *) IPv6Subnet);
|
||||
}
|
||||
|
||||
if (service_uuid == GN_UUID) return;
|
||||
|
||||
// 0x030B "NetAccessType"
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, 0x030B);
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, net_access_type);
|
||||
@ -159,22 +208,17 @@ void pan_create_nap_service(uint8_t *service, uint16_t net_access_type, uint32_t
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, 0x030C);
|
||||
de_add_number(service, DE_UINT, DE_SIZE_32, max_net_access_rate);
|
||||
|
||||
if (IPv4Subnet){
|
||||
// 0x030D "IPv4Subnet"
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, 0x030D);
|
||||
de_add_data(service, DE_STRING, strlen(IPv4Subnet), (uint8_t *) IPv4Subnet);
|
||||
}
|
||||
|
||||
if (IPv6Subnet){
|
||||
// 0x030E "IPv6Subnet"
|
||||
de_add_number(service, DE_UINT, DE_SIZE_16, 0x030E);
|
||||
de_add_data(service, DE_STRING, strlen(IPv6Subnet), (uint8_t *) IPv6Subnet);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// void pan_create_gn_service(uint8_t *service, uint16_t net_access_type, uint32_t max_net_access_rate,
|
||||
// const char *name, const char *description, const char *IPv4Subnet, const char *IPv6Subnet){}
|
||||
void pan_create_nap_service(uint8_t *service, const char *name, const char *description, uint16_t net_access_type, uint32_t max_net_access_rate, const char *IPv4Subnet, const char *IPv6Subnet){
|
||||
pan_create_service(NAP_UUID, service, name, description, IPv4Subnet, IPv6Subnet, net_access_type, max_net_access_rate);
|
||||
}
|
||||
|
||||
// void pan_create_panu_service(uint8_t *service, uint16_t net_access_type, uint32_t max_net_access_rate,
|
||||
// const char *name, const char *description, const char *IPv4Subnet, const char *IPv6Subnet){}
|
||||
void pan_create_gn_service(uint8_t *service, const char *name, const char *description, const char *IPv4Subnet, const char *IPv6Subnet){
|
||||
pan_create_service(GN_UUID, service, name, description, IPv4Subnet, IPv6Subnet, 0, 0);
|
||||
}
|
||||
|
||||
void pan_create_panu_service(uint8_t *service, const char *name, const char *description){
|
||||
pan_create_service(PANU_UUID, service, name, description, NULL, NULL, 0, 0);
|
||||
}
|
||||
|
13
src/pan.h
13
src/pan.h
@ -51,13 +51,14 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
void pan_create_nap_service(uint8_t *service, uint16_t net_access_type, uint32_t max_net_access_rate,
|
||||
const char *name, const char *description, const char *IPv4Subnet, const char *IPv6Subnet);
|
||||
void pan_create_panu_service(uint8_t *service, const char *name, const char *description);
|
||||
|
||||
void pan_create_gn_service(uint8_t *service, const char *name, const char *description,
|
||||
const char *IPv4Subnet, const char *IPv6Subnet);
|
||||
|
||||
void pan_create_nap_service(uint8_t *service, const char *name, const char *description,
|
||||
uint16_t net_access_type, uint32_t max_net_access_rate, const char *IPv4Subnet, const char *IPv6Subnet);
|
||||
|
||||
// void pan_create_gn_service(uint8_t *service, uint16_t net_access_type, uint32_t max_net_access_rate,
|
||||
// const char *name, const char *description, const char *IPv4Subnet, const char *IPv6Subnet);
|
||||
// void pan_create_panu_service(uint8_t *service, uint16_t net_access_type, uint32_t max_net_access_rate,
|
||||
// const char *name, const char *description, const char *IPv4Subnet, const char *IPv6Subnet);
|
||||
|
||||
#if defined __cplusplus
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user