OTA Bootload API
Detailed Description
See OTA Bootload Client Callbacks for the application callbacks associated with the OTA Bootload Client plugin.
Function Documentation
| EmberZclOtaBootloadFileStatus_t emberZclOtaBootloadFetchFileHeaderInfo | ( | const uint8_t * | 
            data,
            | 
| EmberZclOtaBootloadFileHeaderInfo_t * | 
            fileHeaderInfo
            | ||
| ) | 
This function reads an EmberZclOtaBootloadFileHeaderInfo_t from a flat buffer (little-endian).
- Parameters
- 
         dataFlat buffer from which to read a file header info structure fileHeaderInfoFile header info struct to be populated from a flat buffer 
- Returns
- An EmberZclOtaBootloadFileStatus_t value describing if the data is a valid or invalid dotdot OTA data.
| size_t emberZclOtaBootloadFetchFileSpec | ( | const uint8_t * | 
            data,
            | 
| EmberZclOtaBootloadFileSpec_t * | 
            fileSpec
            | ||
| ) | 
This function reads an EmberZclOtaBootloadFileSpec_t from a flat buffer (little-endian).
- Parameters
- 
         dataFlat buffer from which to read a file specification struct fileSpecFile specification struct to be populated from a flat buffer 
- Returns
- The number of bytes read from the flat buffer.
| bool emberZclOtaBootloadFileSpecsAreEqual | ( | const EmberZclOtaBootloadFileSpec_t * | 
            s1,
            | 
| const EmberZclOtaBootloadFileSpec_t * | 
            s2
            | ||
| ) | 
This function compares two OTA file specifications.
- Parameters
- 
         s1OTA file specification to be compared s2OTA file specification to be compared 
- Returns
- 
         trueif both OTA file specifications are equal,falseotherwise.
| void emberZclOtaBootloadInitFileHeaderInfo | ( | EmberZclOtaBootloadFileHeaderInfo_t * | 
            headerInfo
            | ) | 
This function initializes the EmberZclOtaBootloadFileHeaderInfo_t structure.
- Parameters
- 
         headerInfoStructure to be initialized 
| EmberZclOtaBootloadStorageStatus_t emberZclOtaBootloadStorageCreate | ( | const EmberZclOtaBootloadFileSpec_t * | 
            fileSpec
            | ) | 
This function creates a file in the storage module.
- Parameters
- 
         fileSpecA file specification for the file to be created 
- Returns
- 
         One of the following status values.
         - EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_SUCCESS if the file was successfully created
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_INVALID_FILE if the file already exists
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_FAILED if any other failure occured
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_OUT_OF_SPACE if there is not enough space to create this file
 
- Note
- 
         The implementation of this function must adhere to the following specifications:
         - The implementation of this function must be atomic.
- The implementation of this function does not need to be thread-safe.
 
| EmberZclOtaBootloadStorageStatus_t emberZclOtaBootloadStorageDelete | ( | const EmberZclOtaBootloadFileSpec_t * | 
            fileSpec,
            | 
| EmberZclOtaBootloadStorageDeleteCallback | 
            callback
            | ||
| ) | 
This function deletes one or all files in the storage module asynchronously.
- Parameters
- 
         fileSpecA file specification for the file to be deleted, or emberZclOtaBootloadFileSpecNull for all files to be deleted callbackA callback to be called upon completion of this deletion operation 
- Returns
- 
         One of the following status values.
         - EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_SUCCESS if deletion was successfully started on the indicated file/s
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_INVALID_FILE if the file does not exist in the storage module
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_FAILED if any other failure occured
 
- Note
- 
         The implementation of this function must adhere to the following specification:
         - The implementation of this function does not need to be thread-safe.
 
| EmberZclOtaBootloadStorageStatus_t emberZclOtaBootloadStorageFind | ( | const EmberZclOtaBootloadFileSpec_t * | 
            fileSpec,
            | 
| EmberZclOtaBootloadStorageFileInfo_t * | 
            fileInfo
            | ||
| ) | 
This function finds a file in the storage module.
- Parameters
- 
         fileSpecA file specification describing the file to be found fileInfoReturned information about the file to be found; only valid if the function returns EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_SUCCESS 
- Returns
- 
         One of the following status values.
         - EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_SUCCESS if the file was successfully found
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_INVALID_FILE if the file does not exist
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_FAILED if any other failure occured
 
- Note
- 
         The implementation of this function must adhere to the following specifications:
         - The implementation of this function must be safe and idempotent, i.e., contiguous calls to this function with equal fileSpec parameters (as determined by emberZclOtaBootloadFileSpecsAreEqual ) must result in the same returned information and no change in the state of the storage module.
- The implementation of this function does not need to be thread-safe.
 
| void emberZclOtaBootloadStorageGetInfo | ( | EmberZclOtaBootloadStorageInfo_t * | 
            info,
            | 
| EmberZclOtaBootloadFileSpec_t * | 
            returnedFiles,
            | ||
| size_t | 
            returnedFilesMaxCount
            | ||
| ) | 
This function gets information about the current storage module.
- Parameters
- 
         infoReturned information about the current storage module. returnedFilesThe returned list of files that exist in this module. This parameter can be set to NULL to be ignored by the implementation. returnedFilesMaxCountThe maximum number of entries in the provided returnedFiles parameter. 
- Note
- 
         The implementation of this function must adhere to the following specifications:
         - The implementation of this function must return successfully. If, for any reason, the storage module cannot successfully return the necessary information in the implementation of this function, it should raise the error by calling assert(false) .
- The implementation of this function must be safe and idempotent, i.e., contiguous calls to this function must result in the same returned information and no change in the state of the storage module.
- The implementation of this function does not need to be thread-safe.
 
| EmberZclOtaBootloadStorageStatus_t emberZclOtaBootloadStorageRead | ( | const EmberZclOtaBootloadFileSpec_t * | 
            fileSpec,
            | 
| size_t | 
            offset,
            | ||
| void * | 
            data,
            | ||
| size_t | 
            dataLength
            | ||
| ) | 
This function reads contiguous bytes from a file in the storage module.
- Parameters
- 
         fileSpecA file specification for the file to be read offsetThe offset into the file at which to start reading bytes dataThe buffer into which the bytes will be read dataLengthThe number of bytes to read from the file 
- Returns
- 
         One of the following status values.
         - EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_SUCCESS if dataLength number of bytes were successfully read
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_OUT_OF_RANGE if reading dataLength number of bytes starting at offset would result in reading past the end of the file
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_INVALID_FILE if the file does not exist in the storage module
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_FAILED if any other failure occured
 
- Note
- 
         The implementation of this function must adhere to the following specifications:
         - The implementation of this function must be atomic.
- The implementation of this function must support random read access.
- The implementation of this function must allow for random access reading, i.e., reading from any valid offset must be supported.
- The implementation of this function does not need to be thread-safe.
 
| EmberZclOtaBootloadStorageStatus_t emberZclOtaBootloadStorageWrite | ( | const EmberZclOtaBootloadFileSpec_t * | 
            fileSpec,
            | 
| size_t | 
            offset,
            | ||
| const void * | 
            data,
            | ||
| size_t | 
            dataLength
            | ||
| ) | 
This function writes contiguous bytes to a file in the storage module.
- Parameters
- 
         fileSpecA file specification for the file to be written offsetThe offset into the file at which to start writing bytes dataThe bytes to be written dataLengthThe number of bytes to written to the file 
- Returns
- 
         One of the following status values.
         - EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_SUCCESS if dataLength number of bytes were successfully written
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_OUT_OF_RANGE if writing dataLength number of bytes starting at offset would result in writing past the end of the file
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_INVALID_FILE if the file does not exist in the storage module
- EMBER_ZCL_OTA_BOOTLOAD_STORAGE_STATUS_FAILED if any other failure occured
 
- Note
- 
         The implementation of this function must adhere to the following specifications:
         - The implementation of this function must be atomic.
- The implementation of this function must support sequential write access, but does not need to support random write access.
- The implementation of this function does not need to be thread-safe.
 
| EmberZclOtaBootloadFileStatus_t emberZclOtaBootloadStoreFileHeaderInfo | ( | uint8_t * | 
            data,
            | 
| EmberZclOtaBootloadFileHeaderInfo_t * | 
            fileHeaderInfo,
            | ||
| size_t | 
            imageDataSize
            | ||
| ) | 
This function writes an EmberZclOtaBootloadFileHeaderInfo_t to a flat buffer (little-endian). The fileHeaderInfo->headerSize and fileHeaderInfo->fileSize variables are updated to reflect the stored sizes.
- Parameters
- 
         dataFlat buffer to which to write a file header info structure fileHeaderInfoFile header info struct to be written 
- Returns
- An EmberZclOtaBootloadFileStatus_t value describing if the data is a valid or invalid dotdot OTA data.
| size_t emberZclOtaBootloadStoreFileSpec | ( | const EmberZclOtaBootloadFileSpec_t * | 
            fileSpec,
            | 
| uint8_t * | 
            data
            | ||
| ) | 
This function writes an EmberZclOtaBootloadFileSpec_t to a flat buffer (little-endian).
- Parameters
- 
         fileSpecFile specification struct to be written to a flat buffer dataFlat buffer to which the file specification struct will be written 
- Returns
- The number of bytes written to the flat buffer.