Select one of the symbols to view example projects that use it.
 
Outline
...
...
...
...
...
...
#define TX_BYTE_POOL_H
#define TX_BYTE_POOL_ID
#define TX_BYTE_BLOCK_FREE
#define TX_BYTE_BLOCK_MIN
#define TX_BYTE_POOL_MIN
#define TX_BYTE_POOL_INIT
_tx_byte_pool_search(TX_BYTE_POOL *, ULONG);
_tx_byte_pool_cleanup(TX_THREAD *, ULONG);
#define BYTE_POOL_DECLARE
#define BYTE_POOL_DECLARE
_tx_byte_pool_created_ptr
_tx_byte_pool_created_count
#define TX_BYTE_POOL_DELETE_PORT_COMPLETION
Files
loading...
CodeScopeSTM32 Libraries and Samplesthreadxcommon/inc/tx_byte_pool.h
 
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
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/**************************************************************************/ /* */ /* 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 */ /** */ /** Byte Memory */ /** */... /**************************************************************************/ /**************************************************************************/ ... /**************************************************************************/ /* */ /* COMPONENT DEFINITION RELEASE */ /* */ /* tx_byte_pool.h PORTABLE C */ /* 6.1 */ /* AUTHOR */ /* */ /* William E. Lamie, Microsoft Corporation */ /* */ /* DESCRIPTION */ /* */ /* This file defines the ThreadX byte memory management component, */ /* including all data types and external references. It is assumed */ /* that tx_api.h and tx_port.h have already been included. */ /* */ /* RELEASE HISTORY */ /* */ /* DATE NAME DESCRIPTION */ /* */ /* 05-19-2020 William E. Lamie Initial Version 6.0 */ /* 09-30-2020 Yuxin Zhou Modified comment(s), */ /* resulting in version 6.1 */ /* */... /**************************************************************************/ #ifndef TX_BYTE_POOL_H #define TX_BYTE_POOL_H /* Define byte memory control specific data definitions. */ #define TX_BYTE_POOL_ID ((ULONG) 0x42595445) #ifndef TX_BYTE_BLOCK_FREE #define TX_BYTE_BLOCK_FREE ((ULONG) 0xFFFFEEEEUL) #endif #ifndef TX_BYTE_BLOCK_MIN #define TX_BYTE_BLOCK_MIN ((ULONG) 20) #endif #ifndef TX_BYTE_POOL_MIN #define TX_BYTE_POOL_MIN ((ULONG) 100) #endif /* Determine if in-line component initialization is supported by the caller. *//* ... */ #ifdef TX_INVOKE_INLINE_INITIALIZATION /* Yes, in-line initialization is supported, remap the byte memory pool initialization function. *//* ... */ #ifndef TX_BYTE_POOL_ENABLE_PERFORMANCE_INFO #define _tx_byte_pool_initialize() \ _tx_byte_pool_created_ptr = TX_NULL; \ _tx_byte_pool_created_count = TX_EMPTY... /* ... */#else #define _tx_byte_pool_initialize() \ _tx_byte_pool_created_ptr = TX_NULL; \ _tx_byte_pool_created_count = TX_EMPTY; \ _tx_byte_pool_performance_allocate_count = ((ULONG) 0); \ _tx_byte_pool_performance_release_count = ((ULONG) 0); \ _tx_byte_pool_performance_merge_count = ((ULONG) 0); \ _tx_byte_pool_performance_split_count = ((ULONG) 0); \ _tx_byte_pool_performance_search_count = ((ULONG) 0); \ _tx_byte_pool_performance_suspension_count = ((ULONG) 0); \ _tx_byte_pool_performance_timeout_count = ((ULONG) 0)... /* ... */#endif #define TX_BYTE_POOL_INIT /* ... */#else /* No in-line initialization is supported, use standard function call. */ VOID _tx_byte_pool_initialize(VOID);/* ... */ #endif /* Define internal byte memory pool management function prototypes. */ UCHAR *_tx_byte_pool_search(TX_BYTE_POOL *pool_ptr, ULONG memory_size); VOID _tx_byte_pool_cleanup(TX_THREAD *thread_ptr, ULONG suspension_sequence); /* Byte pool management component data declarations follow. */ /* Determine if the initialization function of this component is including this file. If so, make the data definitions really happen. Otherwise, make them extern so other functions in the component can access them. *//* ... */ #ifdef TX_BYTE_POOL_INIT #define BYTE_POOL_DECLARE #else #define BYTE_POOL_DECLARE extern #endif /* Define the head pointer of the created byte pool list. */ BYTE_POOL_DECLARE TX_BYTE_POOL * _tx_byte_pool_created_ptr; /* Define the variable that holds the number of created byte pools. */ BYTE_POOL_DECLARE ULONG _tx_byte_pool_created_count; #ifdef TX_BYTE_POOL_ENABLE_PERFORMANCE_INFO /* Define the total number of allocates. */ BYTE_POOL_DECLARE ULONG _tx_byte_pool_performance_allocate_count; /* Define the total number of releases. */ BYTE_POOL_DECLARE ULONG _tx_byte_pool_performance_release_count; /* Define the total number of adjacent memory fragment merges. */ BYTE_POOL_DECLARE ULONG _tx_byte_pool_performance_merge_count; /* Define the total number of memory fragment splits. */ BYTE_POOL_DECLARE ULONG _tx_byte_pool_performance_split_count; /* Define the total number of memory fragments searched during allocation. */ BYTE_POOL_DECLARE ULONG _tx_byte_pool_performance_search_count; /* Define the total number of byte pool suspensions. */ BYTE_POOL_DECLARE ULONG _tx_byte_pool_performance_suspension_count; /* Define the total number of byte pool timeouts. */ BYTE_POOL_DECLARE ULONG _tx_byte_pool_performance_timeout_count; /* ... */ #endif /* Define default post byte pool delete macro to whitespace, if it hasn't been defined previously (typically in tx_port.h). */ #ifndef TX_BYTE_POOL_DELETE_PORT_COMPLETION #define TX_BYTE_POOL_DELETE_PORT_COMPLETION(p) #endif /* ... */ ...#endif