AWS IoT Over-the-air Update
v3.0.0
Client library for AWS IoT OTA
|
|
Go to the documentation of this file.
41 #ifndef OTA_DO_NOT_USE_CUSTOM_CONFIG
42 #include "ota_config.h"
54 #define LOG2_BITS_PER_BYTE 3U
55 #define BITS_PER_BYTE ( ( uint32_t ) 1U << LOG2_BITS_PER_BYTE )
56 #define OTA_FILE_BLOCK_SIZE ( ( uint32_t ) 1U << otaconfigLOG2_FILE_BLOCK_SIZE )
57 #define OTA_MAX_FILES 1U
58 #define OTA_MAX_BLOCK_BITMAP_SIZE 128U
59 #define OTA_REQUEST_MSG_MAX_SIZE ( 3U * OTA_MAX_BLOCK_BITMAP_SIZE )
60 #define OTA_REQUEST_URL_MAX_SIZE ( 1500 )
61 #define OTA_ERASED_BLOCKS_VAL 0xffU
62 #ifdef configOTA_NUM_MSG_Q_ENTRIES
63 #define OTA_NUM_MSG_Q_ENTRIES configOTA_NUM_MSG_Q_ENTRIES
65 #define OTA_NUM_MSG_Q_ENTRIES 20U
74 #define OTA_MAX_JSON_TOKENS 64U
75 #define OTA_MAX_JSON_STR_LEN 256U
76 #define OTA_DOC_MODEL_MAX_PARAMS 32U
77 #define OTA_JOB_PARAM_REQUIRED ( bool ) true
78 #define OTA_JOB_PARAM_OPTIONAL ( bool ) false
79 #define OTA_DONT_STORE_PARAM 0xffff
80 #define OTA_STORE_NESTED_JSON 0x1fffU
81 #define OTA_DATA_BLOCK_SIZE ( ( 1U << otaconfigLOG2_FILE_BLOCK_SIZE ) + OTA_REQUEST_URL_MAX_SIZE + 30 )
89 #define OTA_EVT_MASK_JOB_MSG_READY 0x00000001UL
90 #define OTA_EVT_MASK_DATA_MSG_READY 0x00000002UL
91 #define OTA_EVT_MASK_SHUTDOWN 0x00000004UL
92 #define OTA_EVT_MASK_REQ_TIMEOUT 0x00000008UL
93 #define OTA_EVT_MASK_USER_ABORT 0x000000016UL
94 #define OTA_EVT_MASK_ALL_EVENTS ( OTA_EVT_MASK_JOB_MSG_READY | OTA_EVT_MASK_DATA_MSG_READY | OTA_EVT_MASK_SHUTDOWN | OTA_EVT_MASK_REQ_TIMEOUT | OTA_EVT_MASK_USER_ABORT )
101 #define OTA_NUM_JOB_PARAMS ( 21 )
107 #define OTA_JOB_ID_MAX_SIZE ( 72UL + 1UL )
113 #define OTA_PROTOCOL_BUFFER_SIZE 20U
120 #define kOTA_MaxSignatureSize 256
133 #define OTA_JSON_SEPARATOR "."
134 #define OTA_JSON_CLIENT_TOKEN_KEY "clientToken"
135 #define OTA_JSON_TIMESTAMP_KEY "timestamp"
136 #define OTA_JSON_EXECUTION_KEY "execution"
137 #define OTA_JSON_JOB_ID_KEY OTA_JSON_EXECUTION_KEY OTA_JSON_SEPARATOR "jobId"
138 #define OTA_JSON_STATUS_DETAILS_KEY OTA_JSON_EXECUTION_KEY OTA_JSON_SEPARATOR "statusDetails"
139 #define OTA_JSON_SELF_TEST_KEY OTA_JSON_STATUS_DETAILS_KEY OTA_JSON_SEPARATOR "self_test"
140 #define OTA_JSON_UPDATED_BY_KEY OTA_JSON_STATUS_DETAILS_KEY OTA_JSON_SEPARATOR "updatedBy"
141 #define OTA_JSON_UPDATED_BY_KEY_ONLY "updatedBy"
142 #define OTA_JSON_SELF_TEST_KEY_ONLY "self_test"
143 #define OTA_JSON_JOB_DOC_KEY OTA_JSON_EXECUTION_KEY OTA_JSON_SEPARATOR "jobDocument"
144 #define OTA_JSON_OTA_UNIT_KEY OTA_JSON_JOB_DOC_KEY OTA_JSON_SEPARATOR "afr_ota"
145 #define OTA_JSON_PROTOCOLS_KEY OTA_JSON_OTA_UNIT_KEY OTA_JSON_SEPARATOR "protocols"
146 #define OTA_JSON_FILE_GROUP_KEY OTA_JSON_OTA_UNIT_KEY OTA_JSON_SEPARATOR "files"
147 #define OTA_JSON_STREAM_NAME_KEY OTA_JSON_OTA_UNIT_KEY OTA_JSON_SEPARATOR "streamname"
148 #define OTA_JSON_FILE_PATH_KEY "filepath"
149 #define OTA_JSON_FILE_SIZE_KEY "filesize"
150 #define OTA_JSON_FILE_ID_KEY "fileid"
151 #define OTA_JSON_FILE_ATTRIBUTE_KEY "attr"
152 #define OTA_JSON_FILE_CERT_NAME_KEY "certfile"
153 #define OTA_JSON_UPDATE_DATA_URL_KEY "update_data_url"
154 #define OTA_JSON_AUTH_SCHEME_KEY "auth_scheme"
155 #define OTA_JSON_FILETYPE_KEY "fileType"
215 ModelParamTypeStringCopy,
216 ModelParamTypeStringInDoc,
217 ModelParamTypeObject,
219 ModelParamTypeUInt32,
220 ModelParamTypeSigBase64,
222 ModelParamTypeArrayCopy
232 JobReasonReceiving = 0,
233 JobReasonSigCheckPassed,
234 JobReasonSelfTestActive,
288 typedef struct OtaAgentStatistics
311 typedef enum OtaImageState
328 typedef enum OtaPalImageState
342 typedef enum OtaEvent
379 typedef struct OtaFileContext
383 #if defined( WIN32 ) || defined( __linux__ )
419 typedef struct OtaEventData
431 typedef struct OtaEventMsg
@ IngestResultFileCloseFail
Definition: ota_private.h:169
uint32_t contextSize
Definition: ota_private.h:277
@ OtaAgentEventCreateFile
Event to create a file.
Definition: ota_private.h:348
This represents the default values for the configuration macros for the OTA library.
uint8_t * pJobName
The job name associated with this file from the job service.
Definition: ota_private.h:392
JSON document parameter to store the details of keys and where to store them.
Definition: ota_private.h:253
JSON document model to store the details of parameters expected in the job document.
Definition: ota_private.h:275
uint32_t paramsReceivedBitmap
Definition: ota_private.h:280
@ DocParseErrNullModelPointer
Definition: ota_private.h:199
uint16_t jobNameMaxSize
Maximum size of the job name.
Definition: ota_private.h:393
OTA File Context Information.
Definition: ota_private.h:380
uint32_t paramsRequiredBitmap
Definition: ota_private.h:281
OtaImageState_t
OTA Image states.
Definition: ota_private.h:312
@ OtaAgentEventSuspend
Event to suspend ota task.
Definition: ota_private.h:353
uint8_t * pUpdateUrlPath
Url for the file.
Definition: ota_private.h:400
uint32_t decodeMemMaxSize
Maximum size of the decode memory.
Definition: ota_private.h:409
@ DocParseErrTooManyParams
Definition: ota_private.h:202
@ IngestResultSigCheckFail
Definition: ota_private.h:168
uint8_t * pCertFilepath
Pathname of the certificate file used to validate the receive file.
Definition: ota_private.h:398
OtaJobReason_t
Gives the reason to set for job parsing operation.
Definition: ota_private.h:231
@ OtaPalImageStatePendingCommit
OTA PAL Image awaiting update.
Definition: ota_private.h:331
uint32_t fileSize
The size of the file in bytes.
Definition: ota_private.h:388
#define OTA_DATA_BLOCK_SIZE
Header is 19 bytes.
Definition: ota_private.h:81
uint32_t dataLength
Definition: ota_private.h:422
Sig256_t * pSignature
Pointer to the file's signature structure.
Definition: ota_private.h:411
@ DocParseErrUserBufferInsuffcient
Definition: ota_private.h:192
uint16_t pDestSizeOffset
Definition: ota_private.h:257
This is the OTA statistics structure to hold useful info.
Definition: ota_private.h:289
@ DocParseErrOutOfMemory
Definition: ota_private.h:191
@ DocParseErrInvalidNumChar
Definition: ota_private.h:195
@ OtaAgentEventStart
Start the OTA state machine.
Definition: ota_private.h:344
@ DocParseErr_InvalidJSONBuffer
Definition: ota_private.h:198
uint8_t * pDecodeMem
Decode memory.
Definition: ota_private.h:408
@ IngestResultWriteBlockFailed
Definition: ota_private.h:175
@ OtaAgentEventRequestFileBlock
Event to request file blocks.
Definition: ota_private.h:349
@ IngestResultAccepted_Continue
Definition: ota_private.h:178
@ OtaImageStateAccepted
The state of the OTA MCU Image post successful download and successful self_test.
Definition: ota_private.h:315
uint8_t * pAuthScheme
Authorization scheme.
Definition: ota_private.h:402
uint32_t otaPacketsDropped
Definition: ota_private.h:293
void * contextBase
Definition: ota_private.h:276
@ DocParseErrUnknown
Definition: ota_private.h:189
@ IngestResultFileComplete
Definition: ota_private.h:167
uint8_t * pProtocols
Authorization scheme.
Definition: ota_private.h:406
@ DocParseErrBase64Decode
Definition: ota_private.h:194
@ OtaAgentEventRequestJobDocument
Event for requesting job document.
Definition: ota_private.h:346
uint8_t * pFilePath
Update file pathname.
Definition: ota_private.h:381
@ OtaAgentEventShutdown
Event to trigger ota shutdown.
Definition: ota_private.h:356
uint32_t otaPacketsReceived
Definition: ota_private.h:290
The OTA Agent event and data structures.
Definition: ota_private.h:420
@ DocParseErrNone
Definition: ota_private.h:190
uint16_t streamNameMaxSize
Maximum size of the stream name.
Definition: ota_private.h:395
uint16_t certFilePathMaxSize
Maximum certificate path size.
Definition: ota_private.h:399
uint32_t fileType
The file type id set when creating the OTA job.
Definition: ota_private.h:410
@ IngestResultBadData
Definition: ota_private.h:174
uint32_t otaPacketsQueued
Definition: ota_private.h:291
@ OtaAgentEventReceivedFileBlock
Event to trigger when file block is received.
Definition: ota_private.h:350
@ OtaAgentEventResume
Event to resume suspended task.
Definition: ota_private.h:354
@ DocParseErrDuplicatesNotAllowed
Definition: ota_private.h:196
OtaEvent_t eventId
Definition: ota_private.h:434
uint16_t updateUrlMaxSize
Maximum size of the url.
Definition: ota_private.h:401
uint32_t otaPacketsProcessed
Definition: ota_private.h:292
const JsonDocParam_t * pBodyDef
Definition: ota_private.h:278
@ OtaPalImageStateUnknown
The initial state of the OTA PAL Image.
Definition: ota_private.h:330
@ DocParseErrFieldTypeMismatch
Definition: ota_private.h:193
const bool required
Definition: ota_private.h:255
@ OtaImageStateUnknown
The initial state of the OTA MCU Image.
Definition: ota_private.h:313
Stores information about the event message.
Definition: ota_private.h:432
uint16_t protocolMaxSize
Maximum size of the supported protocols string.
Definition: ota_private.h:407
@ IngestResultNullInput
Definition: ota_private.h:170
OtaPalImageState_t
OTA Platform Image State.
Definition: ota_private.h:329
@ IngestResultUninitialized
Definition: ota_private.h:177
const ModelParamType_t modelParamType
Definition: ota_private.h:258
@ OtaAgentEventCloseFile
Event to trigger closing file.
Definition: ota_private.h:352
IngestResult_t
Data ingest results.
Definition: ota_private.h:166
uint32_t fileAttributes
Flags specific to the file being received (e.g. secure, bundle, archive).
Definition: ota_private.h:390
bool isInSelfTest
True if the job is in self test mode.
Definition: ota_private.h:405
OtaEvent_t
OTA Agent Events.
Definition: ota_private.h:343
@ DocParseErrParamKeyNotInModel
Definition: ota_private.h:203
DocParseErr_t
Generic JSON document parser errors.
Definition: ota_private.h:188
@ OtaImageStateAborted
The state of the OTA MCU Image after a timeout publish to the stream request fails....
Definition: ota_private.h:317
uint16_t filePathMaxSize
Maximum size of the update file path.
Definition: ota_private.h:382
@ OtaAgentEventRequestTimer
Event to request event timer.
Definition: ota_private.h:351
#define kOTA_MaxSignatureSize
A composite cryptographic signature structure able to hold our largest supported signature.
Definition: ota_private.h:120
@ OtaAgentEventReceivedJobDocument
Event when job document is received.
Definition: ota_private.h:347
@ OtaImageStateTesting
The state of the OTA MCU Image post successful download and reboot.
Definition: ota_private.h:314
uint16_t pDestOffset
Definition: ota_private.h:256
@ IngestResultBadFileHandle
Definition: ota_private.h:171
ModelParamType_t
Document model parameter types used by the JSON document parser.
Definition: ota_private.h:214
bool bufferUsed
Definition: ota_private.h:423
@ DocParseErrNullDocPointer
Definition: ota_private.h:201
uint16_t numModelParams
Definition: ota_private.h:279
OTA File Signature info.
Definition: ota_private.h:367
uint32_t serverFileID
The file is referenced by this numeric ID in the OTA job.
Definition: ota_private.h:391
OtaEventData_t * pEventData
Definition: ota_private.h:433
@ OtaAgentEventMax
Last event specifier.
Definition: ota_private.h:357
uint16_t blockBitmapMaxSize
Maximum size of the block bitmap.
Definition: ota_private.h:397
@ IngestResultDuplicate_Continue
Definition: ota_private.h:179
@ DocParseErrMalformedDoc
Definition: ota_private.h:197
const char * pSrcKey
Definition: ota_private.h:254
@ OtaAgentEventStartSelfTest
Event to trigger self test.
Definition: ota_private.h:345
@ OtaPalImageStateInvalid
OTA PAL Image is invalid.
Definition: ota_private.h:333
@ IngestResultUnexpectedBlock
Definition: ota_private.h:172
uint32_t updaterVersion
Used by OTA self-test detection, the version of Firmware that did the update.
Definition: ota_private.h:404
@ DocParseErrNullBodyPointer
Definition: ota_private.h:200
uint8_t * pRxBlockBitmap
Bitmap of blocks received (for deduplicating and missing block request).
Definition: ota_private.h:396
@ IngestResultBlockOutOfRange
Definition: ota_private.h:173
@ OtaPalImageStateValid
OTA PAL Image is valid.
Definition: ota_private.h:332
uint32_t blocksRemaining
How many blocks remain to be received (a code optimization).
Definition: ota_private.h:389
@ OtaAgentEventUserAbort
Event triggered by user to stop agent.
Definition: ota_private.h:355
@ OtaImageStateRejected
The state of the OTA MCU Image when the job has been rejected.
Definition: ota_private.h:316
uint8_t * pFile
File type is RAM/Flash image pointer after file is open for write.
Definition: ota_private.h:386
@ DocParseErrInvalidToken
Definition: ota_private.h:205
@ IngestResultNoDecodeMemory
Definition: ota_private.h:176
uint16_t authSchemeMaxSize
Maximum size of the auth scheme.
Definition: ota_private.h:403
uint16_t size
Size, in bytes, of the signature.
Definition: ota_private.h:368
@ DocParseErrInvalidModelParamType
Definition: ota_private.h:204
uint8_t * pStreamName
The stream associated with this file from the OTA service.
Definition: ota_private.h:394