Update task pool so tasks and timer are allocated statically.

This commit is contained in:
Richard Barry 2019-07-23 01:46:59 +00:00
parent 1840d38abf
commit 7af8756c97
17 changed files with 102 additions and 1465 deletions

View file

@ -24,34 +24,62 @@
#ifndef IOT_CONFIG_H_
#define IOT_CONFIG_H_
/* How long the MQTT library will wait for PINGRESPs or PUBACKs. */
#define IOT_MQTT_RESPONSE_WAIT_MS ( 10000 )
/* Use platform types on FreeRTOS. */
#include "FreeRTOS.h"
#include "platform/iot_platform_types_freertos.h" //_RB_Makes common config file FreeRTOS specific
/* MQTT demo configuration. */
#define IOT_DEMO_MQTT_PUBLISH_BURST_COUNT ( 10 )
#define IOT_DEMO_MQTT_PUBLISH_BURST_SIZE ( 2 )
/*
* Set this to the number of recyclable tasks for the task pool to cache.
*
* Caching dynamically allocated tasks (recyclable tasks) helps the application
* to limit the number of allocations at runtime. Caching recyclable tasks may
* help making the application more responsive and predictable, by removing a
* potential for memory allocation failures, but it may also have negative
* repercussions on the amount of memory available at any given time. It is up
* to the application developer to strike the correct balance these competing
* needs. The task pool will cache when the application calling
* IotTaskPool_RecycleJob. Any recycled tasks in excess of
* IOT_TASKPOOL_JOBS_RECYCLE_LIMIT will be destroyed and its memory will be
* release.
*
* Default value (if undefined): 8
*/
#define IOT_TASKPOOL_JOBS_RECYCLE_LIMIT 8
/* Shadow demo configuration. The demo publishes periodic Shadow updates and responds
* to changing Shadows. */
#define AWS_IOT_DEMO_SHADOW_UPDATE_COUNT ( 20 ) /* Number of updates to publish. */
#define AWS_IOT_DEMO_SHADOW_UPDATE_PERIOD_MS ( 3000 ) /* Period of Shadow updates. */
/*
* Set this to 1 to perform sanity checks when using the task pool library.
*
* Asserts are useful for debugging, but should be disabled in production code.
* If this is set to 1, IotTaskPool_Assert can be defined to set the assertion
* function; otherwise, the standard library's assert function will be used.
*
* Possible values: 0 (asserts disabled) or 1 (asserts enabled)
* Recommended values: 1 when debugging; 0 in production code.
* Default value (if undefined): 0
*/
#define IOT_TASKPOOL_ENABLE_ASSERTS 1
/* Library logging configuration. IOT_LOG_LEVEL_GLOBAL provides a global log
* level for all libraries; the library-specific settings override the global
* setting. If both the library-specific and global settings are undefined,
* no logs will be printed. */
#define IOT_LOG_LEVEL_GLOBAL IOT_LOG_INFO
#define IOT_LOG_LEVEL_DEMO IOT_LOG_INFO
#define IOT_LOG_LEVEL_PLATFORM IOT_LOG_NONE
#define IOT_LOG_LEVEL_NETWORK IOT_LOG_INFO
#define IOT_LOG_LEVEL_TASKPOOL IOT_LOG_NONE
#define IOT_LOG_LEVEL_MQTT IOT_LOG_INFO
#define AWS_IOT_LOG_LEVEL_SHADOW IOT_LOG_INFO
#define AWS_IOT_LOG_LEVEL_DEFENDER IOT_LOG_INFO
/*
* Set the log level of the task pool library.
*
* Log messages from the task pool library at or below this setting will be
* printed.
*
* Possible values: One of the Log levels.
* Default value (if undefined): IOT_LOG_LEVEL_GLOBAL; if that is undefined,
* then IOT_LOG_NONE.
*/
#define IOT_LOG_LEVEL_TASKPOOL IOT_LOG_INFO
/* Platform thread stack size and priority. */
#define IOT_THREAD_DEFAULT_STACK_SIZE 2048
#define IOT_THREAD_DEFAULT_PRIORITY 5
/*
*
*/
#define IOT_TASKPOOL_NUMBER_OF_WORKERS 3
/*
*
*/
#define IOT_TASKPOOL_WORKER_STACK_SIZE_BYTES 2048
/* Include the common configuration file for FreeRTOS. */
#include "iot_config_common.h"