BGAPI Functions#
Functions provided by the BGAPI protocol.
Functions#
Lock the BGAPI for exclusive access.
Release the lock obtained by sl_bgapi_lock.
Handle a BGAPI command in binary format.
Get the response of a handled BGAPI command.
Set a generic error response to the specified buffer.
Function Documentation#
sl_bgapi_lock#
sl_status_t sl_bgapi_lock (void )
Lock the BGAPI for exclusive access.
N/A |
NOTE: This function is provided for NCP/CPC components that need to handle BGAPI commands and responses in their binary format in an application that uses an RTOS. Normal application code that issues BGAPI commands by calling API functions defined by protocol stacks must never call this function directly.
See the documentation of sl_bgapi_handle_command for the full sequence that must be followed when processing commands in their binary format.
Returns
SL_STATUS_OK if the lock has been obtained, otherwise an error code
245
of file include/sl_bgapi.h
sl_bgapi_unlock#
void sl_bgapi_unlock (void )
Release the lock obtained by sl_bgapi_lock.
N/A |
NOTE: This function is provided for NCP/CPC components that need to handle BGAPI commands and responses in their binary format in an application that uses an RTOS. Normal application code that issues BGAPI commands by calling API functions defined by protocol stacks must never call this function directly.
See the documentation of sl_bgapi_handle_command for the full sequence that must be followed when processing commands in their binary format.
259
of file include/sl_bgapi.h
sl_bgapi_handle_command#
void sl_bgapi_handle_command (uint32_t hdr, const void * data)
Handle a BGAPI command in binary format.
[in] | hdr | The BGAPI command header |
[in] | data | The payload data associated with the command |
NOTE: This function is provided for NCP/CPC components that need to handle BGAPI commands and responses in their binary format. Normal application code that issues BGAPI commands by calling API functions defined by protocol stacks must never call this function directly.
If the application uses an RTOS, the caller must protect the BGAPI handling by obtaining the BGAPI lock with sl_bgapi_lock, handle the command with sl_bgapi_handle_command, read the response from the buffer returned by sl_bgapi_get_command_response, and then release the lock with sl_bgapi_unlock. Here's an example of the full sequence that's required:
// Lock BGAPI for exclusive access
sl_status_t status = sl_bgapi_lock();
if (status != SL_STATUS_OK) {
// Locking will only fail if there are fatal unrecoverable errors with the
// RTOS primitives, so caller may choose to just assert in case of errors.
}
// Process the command
sl_bgapi_handle_command(hdr, data);
// Read the response
void *rsp = sl_bgapi_get_command_response();
uint32_t rsp_header = *((uint32_t *)rsp);
size_t rsp_len = SL_BGAPI_MSG_LEN(rsp_header) + SL_BGAPI_MSG_HEADER_LEN;
// Send the `rsp_len` bytes of response starting from `rsp`
// Finally unlock the BGAPI to allow other commands to proceed
sl_bgapi_unlock();
Empty stub implementations are provided for sl_bgapi_lock and sl_bgapi_unlock, so the same sequence can be used for all NCP/CPC implementations even if an RTOS is not present.
303
of file include/sl_bgapi.h
sl_bgapi_get_command_response#
void * sl_bgapi_get_command_response (void )
Get the response of a handled BGAPI command.
N/A |
NOTE: This function is provided for NCP/CPC components that need to handle BGAPI commands and responses in their binary format. Normal application code that issues BGAPI commands by calling API functions defined by protocol stacks must never call this function directly.
See the documentation of sl_bgapi_handle_command for the full sequence that must be followed when processing commands in their binary format.
Returns
Pointer to the BGAPI response structure that was filled when the command was executed in sl_bgapi_handle_command.
319
of file include/sl_bgapi.h
sl_bgapi_set_error_response#
void sl_bgapi_set_error_response (uint32_t command_hdr, uint16_t result, void * response, size_t response_buf_size)
Set a generic error response to the specified buffer.
[in] | command_hdr | The header of the command that we are responding to. It is possible in certain types of failures that the NCP implementation does not even have the full command header. In these cases it is recommended that the NCP implementation sets the unavailable bytes of the header to value zero to avoid transmitting uninitialized bytes. BGAPI commands are processed one command at a time and the recipient will be able to handle the error response even if it's missing the device ID, the class ID, or the command ID. |
[in] | result | The value to set to the |
[out] | response | The response buffer to fill |
[in] | response_buf_size | The size of the response buffer. The caller must provide a buffer that has at least SL_BGAPI_MSG_HEADER_LEN + SL_BGAPI_MSG_ERROR_PAYLOAD_LEN bytes available. |
NOTE: This function is provided for NCP/CPC components that need to handle BGAPI commands and responses in their binary format. Normal application code that issues BGAPI commands by calling API functions defined by protocol stacks must never call this function directly.
This function is available for NCP components that have detected fatal errors in command processing (for example have failed to receive a complete command message from the NCP host) and need to generate an error response without going through the normal BGAPI command processing.
352
of file include/sl_bgapi.h