AnsweredAssumed Answered

adding service return 0x1f error

Question asked by aqib riaz on Jan 12, 2018
Latest reply on Feb 22, 2018 by Winfred Lu

i am using blue nrg-1 on  STEVAL-IDB007V1 and sdk2.5.0. i am trying to add the device information service (0x180A) but it always return 0x1f. my code is given below. please tell me what is wrong with it i have bold the part which i added to add service.

 

 

 

 

/******************** (C) COPYRIGHT 2016 STMicroelectronics ********************
* File Name : BLE_Beacon_main.c
* Author : AMS - VMA RF Application Team
* Version : V1.1.0
* Date : 20-May-2016
* Description : BlueNRG-1 main file for beacon device
********************************************************************************
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
* CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
*******************************************************************************/
/** @addtogroup BlueNRG1_demonstrations_applications
* BlueNRG-1 Beacon demo \see BLE_Beacon_main.c for documentation.
*
*@{
*/

/** @} */
/** \cond DOXYGEN_SHOULD_SKIP_THIS
*/

/* Includes ------------------------------------------------------------------*/
#include <stdio.h>
#include <string.h>
#include "BlueNRG1_it.h"
#include "BlueNRG1_conf.h"
#include "ble_const.h"
#include "bluenrg1_stack.h"
#include "sleep.h"
#include "SDK_EVAL_Config.h"
#include "Beacon_config.h"
#include "OTA_btl.h"
#include "osal.h"
#include "gp_timer.h"

/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
#define BLE_BEACON_VERSION_STRING "1.1.0"

/* Set to 1 for enabling Flags AD Type position at the beginning
of the advertising packet */
#define ENABLE_FLAGS_AD_TYPE_AT_BEGINNING 1

/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
/* Private function prototypes -----------------------------------------------*/
/* Private functions ---------------------------------------------------------*/

 

void Device_Init(void)
{
uint8_t ret;
uint16_t service_handle;
uint16_t dev_name_char_handle;
uint16_t appearance_char_handle;

/* Set the TX Power to -2 dBm */
ret = aci_hal_set_tx_power_level(1,7);
if(ret != 0) {
printf ("Error in aci_hal_set_tx_power_level() 0x%04xr\n", ret);
while(1);
}

/* Init the GATT */
ret = aci_gatt_init();
if (ret != 0)
printf ("Error in aci_gatt_init() 0x%04xr\n", ret);
else
printf ("aci_gatt_init() --> SUCCESS\r\n");

/* Init the GAP */
ret = aci_gap_init(0x01, 0x00, 0x08, &service_handle,
&dev_name_char_handle, &appearance_char_handle);
if (ret != 0)
printf ("Error in aci_gap_init() 0x%04x\r\n", ret);
else
printf ("aci_gap_init() --> SUCCESS\r\n");

}


/**
* @brief Start beaconing
* @param None
* @retval None
*/
static void Start_Beaconing(void)
{
uint8_t ret = BLE_STATUS_SUCCESS;

#if ENABLE_FLAGS_AD_TYPE_AT_BEGINNING
/* Set AD Type Flags at beginning on Advertising packet */
uint8_t adv_data[] = {
/* Advertising data: Flags AD Type */
0x02,
0x01,
0x06,
/* Advertising data: manufacturer specific data */
26, //len
AD_TYPE_MANUFACTURER_SPECIFIC_DATA, //manufacturer type
0x30, 0x00, //Company identifier code (Default is 0x0030 - STMicroelectronics: To be customized for specific identifier)
0x02, // ID
0x15, //Length of the remaining payload
0xE2, 0x0A, 0x39, 0xF4, 0x73, 0xF5, 0x4B, 0xC4, //Location UUID
0xA1, 0x2F, 0x17, 0xD1, 0xAD, 0x07, 0xA9, 0x61,
0x00, 0x00, // Major number
0x00, 0x00, // Minor number
0xC8 //2's complement of the Tx power (-56dB)};
};
#else
uint8_t manuf_data[] = {
26, //len
AD_TYPE_MANUFACTURER_SPECIFIC_DATA, //manufacturer type
0x30, 0x00, //Company identifier code (Default is 0x0030 - STMicroelectronics: To be customized for specific identifier)
0x02, // ID
0x15, //Length of the remaining payload
0xE2, 0x0A, 0x39, 0xF4, 0x73, 0xF5, 0x4B, 0xC4, //Location UUID
0xA1, 0x2F, 0x17, 0xD1, 0xAD, 0x07, 0xA9, 0x61,
0x00, 0x00, // Major number
0x00, 0x00, // Minor number
0xC8 //2's complement of the Tx power (-56dB)};
};
#endif

/* disable scan response */
ret = hci_le_set_scan_response_data(0,NULL);
if (ret != BLE_STATUS_SUCCESS)
{
printf ("Error in hci_le_set_scan_resp_data() 0x%04x\r\n", ret);
return;
}
else
printf ("hci_le_set_scan_resp_data() --> SUCCESS\r\n");

/* put device in non connectable mode */
ret = aci_gap_set_discoverable(ADV_IND, 160, 160, PUBLIC_ADDR, NO_WHITE_LIST_USE,
0, NULL, 0, NULL, 0, 0);
if (ret != BLE_STATUS_SUCCESS)
{
printf ("Error in aci_gap_set_discoverable() 0x%04x\r\n", ret);
return;
}
else
printf ("aci_gap_set_discoverable() --> SUCCESS\r\n");

#if ENABLE_FLAGS_AD_TYPE_AT_BEGINNING
/* Set the ADV data with the Flags AD Type at beginning of the
advertsing packet, followed by the beacon manufacturer specific data */
ret = hci_le_set_advertising_data (sizeof(adv_data), adv_data);
if (ret != BLE_STATUS_SUCCESS)
{
printf ("Error in hci_le_set_advertising_data() 0x%04x\r\n", ret);
return;
}
else
printf ("hci_le_set_advertising_data() --> SUCCESS\r\n");
#else
/* Delete the TX power level information */
ret = aci_gap_delete_ad_type(AD_TYPE_TX_POWER_LEVEL);
if (ret != BLE_STATUS_SUCCESS)
{
printf ("Error in aci_gap_delete_ad_type() 0x%04x\r\n", ret);
return;
}
else
printf ("aci_gap_delete_ad_type() --> SUCCESS\r\n");

/* Update the ADV data with the BEACON manufacturing data */
ret = aci_gap_update_adv_data(27, manuf_data);
if (ret != BLE_STATUS_SUCCESS)
{
printf ("Error in aci_gap_update_adv_data() 0x%04x\r\n", ret);
return;
}
else
printf ("aci_gap_update_adv_data() --> SUCCESS\r\n");
#endif



/* UUIDS */
Service_UUID_t service_uuid;
service_uuid.Service_UUID_16=0x180A;
Char_UUID_t char_uuid;
char_uuid.Char_UUID_16=0x2a29;

uint16_t ServHandle, CharHandle;

 

ret = aci_gatt_add_service(UUID_TYPE_16, &service_uuid, PRIMARY_SERVICE, 0x07, &ServHandle);
printf("add service 0x%02x\r\n", ret);



ret = aci_gatt_add_char(ServHandle, UUID_TYPE_16, &char_uuid, 1, CHAR_PROP_NOTIFY, ATTR_PERMISSION_NONE, 0,
16, 0, &CharHandle);
printf("add characteristic 0x%02x\r\n", ret);


}

int main(void)
{
uint8_t ret;

/* System Init */
SystemInit();

/* Identify BlueNRG-1 platform */
SdkEvalIdentification();

/* Init the UART peripheral */
SdkEvalComUartInit(UART_BAUDRATE);

/* BlueNRG-1 stack init */
ret = BlueNRG_Stack_Initialization(&BlueNRG_Stack_Init_params);
if (ret != BLE_STATUS_SUCCESS) {
printf("Error in BlueNRG_Stack_Initialization() 0x%02x\r\n", ret);
while(1);
}

/* Init the BlueNRG-1 device */
Device_Init();

#if ST_USE_OTA_SERVICE_MANAGER_APPLICATION
/* Initialize the button */
SdkEvalPushButtonInit(BUTTON_1);
#endif /* ST_USE_OTA_SERVICE_MANAGER_APPLICATION */

/* Start Beacon Non Connectable Mode*/
Start_Beaconing();

printf("BlueNRG-1 BLE Beacon Application (version: %s)\r\n", BLE_BEACON_VERSION_STRING);

while(1)
{
/* BlueNRG-1 stack tick */
BTLE_StackTick();

/* Enable Power Save according the Advertising Interval */
BlueNRG_Sleep(SLEEPMODE_NOTIMER, 0, 0);

#if ST_USE_OTA_SERVICE_MANAGER_APPLICATION
if (SdkEvalPushButtonGetState(BUTTON_1) == RESET)
{
OTA_Jump_To_Service_Manager_Application();
}
#endif /* ST_USE_OTA_SERVICE_MANAGER_APPLICATION */
}
}

/****************** BlueNRG-1 Sleep Management Callback ********************************/

SleepModes App_SleepMode_Check(SleepModes sleepMode)
{
if(SdkEvalComIOTxFifoNotEmpty())
return SLEEPMODE_CPU_HALT;

return SLEEPMODE_NOTIMER;
}

/***************************************************************************************/

#ifdef USE_FULL_ASSERT

/**
* @brief Reports the name of the source file and the source line number
* where the assert_param error has occurred.
* @param file: pointer to the source file name
* @param line: assert_param error line source number
*/
void assert_failed(uint8_t* file, uint32_t line)
{
/* User can add his own implementation to report the file name and line number,
ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */

/* Infinite loop */
while (1)
{
}
}

#endif

/******************* (C) COPYRIGHT 2015 STMicroelectronics *****END OF FILE****/
/** \endcond
*/

 

 

 

 

 

 

 

the data on the serial terminal is given below

 

 

aci_gatt_init() --> SUCCESS
aci_gap_init() --> SUCCESS
hci_le_set_scan_resp_data() --> SUCCESS
aci_gap_set_discoverable() --> SUCCESS
hci_le_set_advertising_data() --> SUCCESS
add service 0x1f
add characteristic 0x60
BlueNRG-1 BLE Beacon Application (version: 1.1.0)

Outcomes