I read the memory management code carefully, and then I read the knowledge of the stack and figured out something I didn't understand before.
First, let's take a look at the memory structure of stm32.
Flash, SRAM registers and I/O ports are organized in the same 4GB linear address space. The accessible memory space is divided into 8 main blocks, each block being 512MB.
FLASH stores downloaded programs.
SRAM is the data stored in the running program.
So, as long as you don't expand the memory, everything in the written program will appear in both memories.
This is a prerequisite!
Stack cognition
1. The stack in STM32.
I have been confused by this, which has led to a lot of logical confusion. The first thing to note is that the MCU is an integrated circuit chip that integrates functions such as CPU, RAM, ROM, various I/O ports and interrupt systems, and timers/counters. The CPU includes various bus circuits, calculation circuits, logic circuits, and various registers. Stm32 has general-purpose registers R0-R15 and some special function registers, including the stack pointer register. When stm32 runs the program normally, an interrupt is generated, and the CPU needs to push the value in the register into RAM, and then store the address where the data is located in the stack register. When the interrupt processing is completed and exited, the data is popped out to the previous register, which is done automatically in the C language.
2. The stack in programming.
In the programming, many times, the stack is mentioned. This is exactly an area in RAM. Let's first take a look at a few notes:
(1) All the contents of the program will only appear in flash, ram (not expanded).
(2) The division of segments is to store similar data types in an area for easy management, but as mentioned above, no matter what segment of data, it is ultimately in flash and ram.
The C language is divided into stack, heap, bss, data, and code segments. Specifically, each segment is specifically storing what data, directly Baidu. Focus on the STM32 and the division of the MDK inside.
MDK under the Code, RO-data, RW-data, ZI-data segments:
Code is the stored program code.
RO-data stores const constants and instructions.
RW-data is a global variable that stores initialization values ​​other than zero.
ZI-data is a global variable that stores uninitialized global variables or has an initialization value of zero.
Flash=Code + RO Data + RW Data;
RAM= RW-data+ZI-data;
This is the size of each segment that can be obtained after MDK is compiled. It can also get the size of the corresponding FLASH and RAM, but there are two data segments that also occupy RAM, but it will be occupied when the program is running. , that is the heap and the stack. In the stm32 startup file .s file, there is a stack setting. In fact, the memory usage of this stack is allocated at the address after the RAM is allocated to RW-data+ZI-data.
Heap: is the area of ​​memory that the compiler calls for dynamic memory allocation.
Stack: It is the place where the local variable is running when the program is running. Therefore, if the local variable is too large, it may cause stack overflow.
The size of the stack is unknown after the compiler is compiled. It is known only when it is running, so it is important to note that it does not cause a stack overflow. . . Otherwise wait for hardfault to find you.
3. The stack in the OS and its memory management.
The stack of the embedded system, no matter what method is used to get the memory, feels his way is similar to the heap in the programming.
Currently I know two ways to get memory:
(1) Enclose a block of memory with a large array of global variables, and then use this memory for memory management and allocation. In this case, the memory occupied by the stack is as mentioned above: if the array is not initialized, or the initialization value of the array is 0, the stack is the ZI-data portion of the RAM occupied; if the array initialization value is not 0, the stack is occupied. The RW-data portion of the RAM. The advantage of this approach is that it is easy to logically know the cause and whereabouts of the data.
(2) is to use the RAM part of the compiler that is not used for memory allocation, that is, to remove some or all of the remaining RAM memory after the RW-data+ZI-data+ compiler heap+compiler stack is removed. Management and distribution. In this case, you only need to know the first address of the remaining part of the memory and the tail address of the memory. Then, how much memory should be used, start digging with the first address, make a linked list, and link the information about memory acquisition and release. Manage the memory in time. There are many kinds of algorithms for memory management. Unexpectedly, in this case, the memory allocation of the OS does not conflict with its own local variables or global variables. I have been entangled in this for a long time, thinking that the variables in the function are also dynamic from the system. Coming in memory. This way I feel more aware of the beginning and end of my address.
I don't think anyone is better in these two methods, because it is just a way to get the memory. The clever thing is the management and allocation of memory.
With the improvement of people's quality of life, people's lifestyles have also become varied. Different kinds of recreational products are starting to appear in people's lives, such as electronic cigarettes. The emergence of e-cigarettes represents a part of young people's thinking and means that electronic products are beginning to show a trend towards diversity.
simply replace the pods. The Pod system uses an integrated pod rather than a tank for higher nicotine strength and provides low power traction. the Pod system is rechargeable and has a longer life and higher battery capacity than disposable electronic cigarettes.
Our company Pod system has a built-in 380mAh battery and a USB charging port on the bottom. In comparison, the Pod system has a built-in battery of only 180mAh, but the Pod system charges much faster.
Our electronic cigarettes are of rechargeable construction. The first time you use the charger to charge, it is recommended to use up the remaining power before filling up, this is to ensure the performance of the battery.
Vape Pod System Oem,Vape Pod Oem,Close Pod Oem,Thc Pod Disposable
Shenzhen MASON VAP Technology Co., Ltd. , https://www.e-cigarettefactory.com