implemeted SDP PANU and GN service record

This commit is contained in:
mila@ringwald.ch 2014-10-16 15:27:02 +00:00
parent 254e71e6e7
commit 5dc81bdaad
2 changed files with 75 additions and 30 deletions

View File

@ -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);
}

View File

@ -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
}