Select one of the symbols to view example projects that use it.
 
Outline
...
...
...
...
#define TX_SOURCE_CODE
#define TX_MODULE_MANAGER_INIT
#include "tx_api.h"
#include "tx_initialize.h"
#include "tx_thread.h"
#include "tx_byte_pool.h"
#include "tx_queue.h"
#include "tx_mutex.h"
#include "txm_module.h"
_txm_module_manager_version_id
_txm_module_manager_properties_supported
_txm_module_manager_properties_required
_txm_module_manager_byte_pool
_txm_module_manager_object_pool
_txm_module_manager_object_pool_created
_txm_module_manager_mutex
_txm_module_manager_loaded_list_ptr
_txm_module_manger_loaded_count
_txm_module_manager_ready
_txm_module_manager_callback_total_count
_txm_module_manager_callback_error_count
...
...
_txm_module_manager_initialize(void *, ULONG)
Files
loading...
CodeScopeSTM32 Libraries and Samplesthreadxcommon_modules/module_manager/src/txm_module_manager_initialize.c
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/**************************************************************************/ /* */ /* Copyright (c) Microsoft Corporation. All rights reserved. */ /* */ /* This software is licensed under the Microsoft Software License */ /* Terms for Microsoft Azure RTOS. Full text of the license can be */ /* found in the LICENSE file at https://aka.ms/AzureRTOS_EULA */ /* and in the root directory of this software. */ /* */... /**************************************************************************/ ... /**************************************************************************/ /**************************************************************************/ /** */ /** ThreadX Component */ /** */ /** Module Manager */ /** */... /**************************************************************************/ /**************************************************************************/ #define TX_SOURCE_CODE #define TX_MODULE_MANAGER_INIT #include "tx_api.h" #include "tx_initialize.h" #include "tx_thread.h" #include "tx_byte_pool.h" #include "tx_queue.h" #include "tx_mutex.h" #include "txm_module.h" 7 includes TXM_MODULE_MANAGER_VERSION_ID /* Define global variables associated with the module manager. */ /* Define the module properties supported by this module manager. */ ULONG _txm_module_manager_properties_supported; /* Define the module properties required by this module manager. */ ULONG _txm_module_manager_properties_required; /* Define byte pool that will be used for allocating module data areas. */ TX_BYTE_POOL _txm_module_manager_byte_pool; /* Define byte pool that will be used for allocating external memory for module objects. */ TX_BYTE_POOL _txm_module_manager_object_pool; /* Define the flag indicating that the module manager byte pool is created. */ UINT _txm_module_manager_object_pool_created; /* Define module manager protection mutex. */ TX_MUTEX _txm_module_manager_mutex; /* Define the loaded modules list, which keeps track of all loaded modules. */ TXM_MODULE_INSTANCE *_txm_module_manager_loaded_list_ptr; /* Define the count of loaded modules. */ ULONG _txm_module_manger_loaded_count; /* Define the ready flag, which is checked by other module manager APIs to make sure the manager has been initialized. *//* ... */ UINT _txm_module_manager_ready; /* Define the total callback activation count. This is simply incremented on every callback activation. *//* ... */ ULONG _txm_module_manager_callback_total_count; /* Define the callback activation error count. This occurs when the available callback structures have been exhausted. *//* ... */ ULONG _txm_module_manager_callback_error_count; ... /**************************************************************************/ /* */ /* FUNCTION RELEASE */ /* */ /* _txm_module_manager_initialize PORTABLE C */ /* 6.1 */ /* AUTHOR */ /* */ /* Scott Larson, Microsoft Corporation */ /* */ /* DESCRIPTION */ /* */ /* This function initializes the module manager. */ /* */ /* INPUT */ /* */ /* module_memory_start Start of module area */ /* module_memory_size Size in bytes of module area */ /* */ /* OUTPUT */ /* */ /* status Completion status */ /* */ /* CALLS */ /* */ /* _tx_byte_pool_create Create module memory byte pool */ /* _tx_mutex_create Create module manager */ /* protection mutex */ /* */ /* CALLED BY */ /* */ /* Application code */ /* */ /* RELEASE HISTORY */ /* */ /* DATE NAME DESCRIPTION */ /* */ /* 09-30-2020 Scott Larson Initial Version 6.1 */ /* */... /**************************************************************************/ UINT _txm_module_manager_initialize(VOID *module_memory_start, ULONG module_memory_size) { /* Check for interrupt call. */ if (TX_THREAD_GET_SYSTEM_STATE() != 0) { /* Now, make sure the call is from an interrupt and not initialization. */ if (TX_THREAD_GET_SYSTEM_STATE() < TX_INITIALIZE_IN_PROGRESS) { /* Invalid caller of this function, return appropriate error code. */ return(TX_CALLER_ERROR); }if (TX_THREAD_GET_SYSTEM_STATE() < TX_INITIALIZE_IN_PROGRESS) { ... } }if (TX_THREAD_GET_SYSTEM_STATE() != 0) { ... } /* Setup the module properties supported by this module manager. */ _txm_module_manager_properties_supported = TXM_MODULE_MANAGER_SUPPORTED_OPTIONS; /* Setup the module properties required by this module manager. */ _txm_module_manager_properties_required = TXM_MODULE_MANAGER_REQUIRED_OPTIONS; /* Clear the module manager ready flag. */ _txm_module_manager_ready = TX_FALSE; /* Initialize the empty module list. */ _txm_module_manager_loaded_list_ptr = TX_NULL; /* Clear the number of loaded modules. */ _txm_module_manger_loaded_count = 0; /* Create the module manager protection mutex. */ _tx_mutex_create(&_txm_module_manager_mutex, "Module Manager Protection Mutex", TX_NO_INHERIT); /* Create a byte pool for allocating RAM areas for modules. */ _tx_byte_pool_create(&_txm_module_manager_byte_pool, "Module Manager Byte Pool", module_memory_start, module_memory_size); /* Indicate the module manager object pool has not been created. */ _txm_module_manager_object_pool_created = TX_FALSE; /* Mark the module manager as ready! */ _txm_module_manager_ready = TX_TRUE; /* Return success. */ return(TX_SUCCESS); }{ ... }