The composition of ARM program (referring to the program being executed in the ARM system, not the bin file saved in ROM)
An ARM program consists of 3 parts: RO segment, RW segment and ZI segment
RO is the instructions and constants in the program
RW is the initialized variable in the program
ZI is the uninitialized variable in the program
From the above 3 points, it can be understood that:
RO is readonly,
RW is read/write, and
ZI is zero
The composition of ARM image file
The so-called ARM image file refers to the bin file burned into ROM, also known as image file. It is called Image file below.
Image file contains RO and RW data.
The reason why Image file does not contain ZI data is that ZI data is all 0, so it is not necessary to include it. Just clear the area where ZI data is before running the program. Including it will waste storage space.
Q: Why must Image contain RO and RW?
A: Because the instructions and constants in RO and the initialized variables in RW cannot be "created out of nothing" like ZI. From the above two points, we can know that the image file burned into ROM is not exactly the same as the ARM program in actual operation. Therefore, it is necessary to understand how the ARM program reaches the actual operation state from the image in ROM.
In fact, the instructions in RO should at least have the following functions: 1. Move RW from ROM to RAM, because RW is a variable and variables cannot exist in ROM. 2. Clear all RAM areas where ZI is located, because the ZI area is not in the image, so the program needs to clear the corresponding RAM area according to the ZI address and size given by the compiler. ZI is also a variable. Similarly: variables cannot exist in ROM In the initial stage of program operation, the C program can access variables normally only after the instructions in RO complete these two tasks. Otherwise, only code without variables can be run. After saying the above, you may still be a little confused. What are RO, RW and ZI? Below I will give a few examples to explain what RO, RW, and ZI mean in C in the most intuitive way. 1; RO Look at the following two programs. There is a statement between them. This statement is to declare a character constant. So according to what we said before, they should only differ by one byte in RO data (character constants are 1 byte). Prog1: #include
void main(void)
{
;
}
Prog2:
#include
const char a = 5;
void main(void)
{
;
}
The compiled information of Prog1 is as follows:
===========================================================================================
Code RO Data RW Data ZI Data Debug
948 60 0 96 0 Grand Totals
=====================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB) Total RW Size(RW Data + ZI
Data
) 96 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1008 ( 0.98kB)
=== ...
===================================================================
09
(
0.99kB
)
Total RW Size (RW Data + ZI Data) 96 ( 0.09kB)
Total ROM Size (Code + RO Data + RW
Data
)
1009
(
0.99kB
)
===
...
void main(void)
{
;
}
Prog4:
#include
char a = 5;
void main(void)
{
;
}
The information after compiling Prog3 is as follows:
=======================================================================================
Code RO Data RW Data ZI Data Debug
948 60 0 96 0 Grand Totals
===============================================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB)
Total RW Size(RW Data + ZI Data) 96 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1008 ( 0.98kB)
===========================================================================================
The information compiled by Prog4 is as follows:
======================================================================================================
Code RO Data RW Data ZI Data Debug
948 60 1 96 0 Grand Totals
============================================================================
Total RO Size(Code + RO Data) 1008 (0.98kB)
Total RW Size(RW Data + ZI Data) 97 (0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1009 (0.99kB)
===
...
Prog3:
#include
void main(void)
{
;
}
Prog4:
#include
char a;
void main(void)
{
;
}
The information after compiling Prog3 is as follows:
========================================================================================
Code RO Data RW Data ZI Data Debug
948 60 0 96 0 Grand Totals
======================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB) Total RW Size(RW Data + ZI Data
) 96 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1008 ( 0.98kB)
=== ... =================================================================== 08 ( 0.98kB ) Total RW Size (RW Data + ZI Data) 97 ( 0.09kB) Total ROM Size (Code + RO Data + RW Data) 1008 (0.98kB)
===
...
Appendix:
Program compilation command (assuming the C program is named tst.c):
armcc -c -o tst.o tst.c
armlink -noremove -elf -nodebug -info totals -info sizes -map -list aa.map -o tst.elf
The compiled information of tst.o is in the aa.map file.
ROM mainly refers to: NAND Flash, Nor Flash
RAM mainly refers to: PSRAM, SDRAM, SRAM, DDRAM
Keywords:Keil arm compile DATA
Reference address:Keil arm compile RO RW ZI DATA
An ARM program consists of 3 parts: RO segment, RW segment and ZI segment
RO is the instructions and constants in the program
RW is the initialized variable in the program
ZI is the uninitialized variable in the program
From the above 3 points, it can be understood that:
RO is readonly,
RW is read/write, and
ZI is zero
The composition of ARM image file
The so-called ARM image file refers to the bin file burned into ROM, also known as image file. It is called Image file below.
Image file contains RO and RW data.
The reason why Image file does not contain ZI data is that ZI data is all 0, so it is not necessary to include it. Just clear the area where ZI data is before running the program. Including it will waste storage space.
Q: Why must Image contain RO and RW?
A: Because the instructions and constants in RO and the initialized variables in RW cannot be "created out of nothing" like ZI. From the above two points, we can know that the image file burned into ROM is not exactly the same as the ARM program in actual operation. Therefore, it is necessary to understand how the ARM program reaches the actual operation state from the image in ROM.
In fact, the instructions in RO should at least have the following functions: 1. Move RW from ROM to RAM, because RW is a variable and variables cannot exist in ROM. 2. Clear all RAM areas where ZI is located, because the ZI area is not in the image, so the program needs to clear the corresponding RAM area according to the ZI address and size given by the compiler. ZI is also a variable. Similarly: variables cannot exist in ROM In the initial stage of program operation, the C program can access variables normally only after the instructions in RO complete these two tasks. Otherwise, only code without variables can be run. After saying the above, you may still be a little confused. What are RO, RW and ZI? Below I will give a few examples to explain what RO, RW, and ZI mean in C in the most intuitive way. 1; RO Look at the following two programs. There is a statement between them. This statement is to declare a character constant. So according to what we said before, they should only differ by one byte in RO data (character constants are 1 byte). Prog1: #include
void main(void)
{
;
}
Prog4:
#include
char a = 5;
void main(void)
{
;
}
The information after compiling Prog3 is as follows:
=======================================================================================
Code RO Data RW Data ZI Data Debug
948 60 0 96 0 Grand Totals
===============================================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB)
Total RW Size(RW Data + ZI Data) 96 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1008 ( 0.98kB)
===========================================================================================
The information compiled by Prog4 is as follows:
======================================================================================================
Code RO Data RW Data ZI Data Debug
948 60 1 96 0 Grand Totals
============================================================================
Total RO Size(Code + RO Data) 1008 (0.98kB)
Total RW Size(RW Data + ZI Data) 97 (0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1009 (0.99kB)
===
...
Prog3:
#include
void main(void)
{
;
}
Prog4:
#include
char a;
void main(void)
{
;
}
The information after compiling Prog3 is as follows:
========================================================================================
Code RO Data RW Data ZI Data Debug
948 60 0 96 0 Grand Totals
======================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB) Total RW Size(RW Data + ZI Data
) 96 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1008 ( 0.98kB)
=== ... =================================================================== 08 ( 0.98kB ) Total RW Size (RW Data + ZI Data) 97 ( 0.09kB) Total ROM Size (Code + RO Data + RW Data) 1008 (0.98kB)
===
...
Appendix:
Program compilation command (assuming the C program is named tst.c):
armcc -c -o tst.o tst.c
armlink -noremove -elf -nodebug -info totals -info sizes -map -list aa.map -o tst.elf
The compiled information of tst.o is in the aa.map file.
ROM mainly refers to: NAND Flash, Nor Flash
RAM mainly refers to: PSRAM, SDRAM, SRAM, DDRAM
Previous article:STM32 Getting Started Notes (3)——GPIO
Next article:NAND flash boot of S3C2410X
Recommended ReadingLatest update time:2024-11-16 20:26
Embedded Linux Development (XVIII) Memory Management (2) ARM Memory Management
Hardware memory management armv7v8 ARM is uniformly addressed, that is, peripherals and (memory A) are uniformly addressed, together forming a 4G physical address space (32 bits as an example). The memory controller belongs to peripherals, and the memory belongs to (memory A). The internal and external memory of a soc
[Microcontroller]
Introduction to ARM7 Series LPC2103 MCU
1 Introduction LPC2103 is the latest LPC2103 launched by PHILIPS based on ARM7TDMI-S and LQFP48 package, with a maximum operating speed of 70MHz, 32KB on-chip FLASH program memory and 8K on-chip static RAM. ISP/IAP programming is achieved through the on-chip boot loader. The LPC2103's 10-bit A/D converter provides
[Microcontroller]
Design and implementation of network card interface based on ARM and DM9000
The most basic switched capacitor circuit is composed of electronic switches and capacitors, and its main application is to form various low-pass, high-pass, band-pass, band-stop and other switched-capacitor filters (SCF). The switched capacitor active filter composed of the switched capacitor circuit and the operat
[Microcontroller]
Research on GPS signal acquisition and processing under ARM-Linux platform
Positioning and navigation are important functions of many portable mobile devices and automotive electronic devices, so GPS is widely used in these devices. The embedded platform based on ARM-Linux is becoming the main development platform for various portable devices and vehicle navigation devices due to its opennes
[Microcontroller]
【ARM】The function of BL0 in S5PV210 chip
The functions of BL0 in the S5PV210 chip are as follows:
(1) Turn off the watchdog;
(2) Clear the instruction register;
(3) Initialize the stack area;
(4) Initialize the heap area;
(5) Initialize the block device copy function;
(6) Initialize the PLL and set the system clock;
(7) Copy BL1
[Microcontroller]
ARM and Hopu Investments issued a joint statement on the removal of Wu Xiong'ang
On June 10, 2020, ARM and Hopu Investments jointly issued a statement saying that they had reached a decision to remove Wu Xiong'ang, chairman and CEO of ARM China. The original text is as follows: As the majority shareholder of ARM Technology (China) Co., Ltd. (hereinafter referred to as ARM China), ARM and Hopu
[Semiconductor design/manufacturing]
Introduction to ARM serial communication and parallel communication
Computer communication (data exchange) is mainly divided into: serial communication and parallel communication Serial Communication Concept: Data transmission between a computer and an I/O device is done one bit at a time in sequence. Usually data is transmitted on a single data line or a pair of differential lines.
[Microcontroller]
Redundant Design of ARM Processor in DCS Controller
In many areas of automation, the requirements for effectiveness are getting higher and higher, and thus the requirements for the fault tolerance level of the automation system are also getting higher and higher, especially in situations where the cost of equipment downtime is very high. In order to meet these string
[Microcontroller]
- Popular Resources
- Popular amplifiers
- Virtualization Technology Practice Guide - High-efficiency and low-cost solutions for small and medium-sized enterprises (Wang Chunhai)
- usb_host_device_code
- Multithreaded computing in embedded real-time operating systems - based on ThreadX and ARM
- Detailed explanation of big data technology system: principles, architecture and practice (Dong Xicheng)
Recommended Content
Latest Microcontroller Articles
He Limin Column
Microcontroller and Embedded Systems Bible
Professor at Beihang University, dedicated to promoting microcontrollers and embedded systems for over 20 years.
MoreSelected Circuit Diagrams
MorePopular Articles
- Innolux's intelligent steer-by-wire solution makes cars smarter and safer
- 8051 MCU - Parity Check
- How to efficiently balance the sensitivity of tactile sensing interfaces
- What should I do if the servo motor shakes? What causes the servo motor to shake quickly?
- 【Brushless Motor】Analysis of three-phase BLDC motor and sharing of two popular development boards
- Midea Industrial Technology's subsidiaries Clou Electronics and Hekang New Energy jointly appeared at the Munich Battery Energy Storage Exhibition and Solar Energy Exhibition
- Guoxin Sichen | Application of ferroelectric memory PB85RS2MC in power battery management, with a capacity of 2M
- Analysis of common faults of frequency converter
- In a head-on competition with Qualcomm, what kind of cockpit products has Intel come up with?
- Dalian Rongke's all-vanadium liquid flow battery energy storage equipment industrialization project has entered the sprint stage before production
MoreDaily News
- Allegro MicroSystems Introduces Advanced Magnetic and Inductive Position Sensing Solutions at Electronica 2024
- Car key in the left hand, liveness detection radar in the right hand, UWB is imperative for cars!
- After a decade of rapid development, domestic CIS has entered the market
- Aegis Dagger Battery + Thor EM-i Super Hybrid, Geely New Energy has thrown out two "king bombs"
- A brief discussion on functional safety - fault, error, and failure
- In the smart car 2.0 cycle, these core industry chains are facing major opportunities!
- The United States and Japan are developing new batteries. CATL faces challenges? How should China's new energy battery industry respond?
- Murata launches high-precision 6-axis inertial sensor for automobiles
- Ford patents pre-charge alarm to help save costs and respond to emergencies
- New real-time microcontroller system from Texas Instruments enables smarter processing in automotive and industrial applications
Guess you like
- [Integrated subway security control system based on Raspberry Pi 400] Material unboxing - Raspberry Pi 400
- SinA332.0 development board Linux & Qt adjust VGA resolution to 1280x720
- Single chip microcomputer CPU card programming system main frequency setting
- Award-winning live broadcast: Microchip's trusted platform for the CryptoAuthentication family
- What is the Internet of Things? What is the concept of the Internet of Things?
- DSP 2407 Book Request
- GD32307E-START IO analog SPI control RGBLED (03)
- 【GD32E503 Review】+ cJSON Porting Test
- Is one of the two MOS tubes in the step-down switching power supply chip used to replace the diode?
- The NiMH battery charging circuit is relatively complex, and some SMD components cannot be found in the specification sheet.