Memory Map Analyzer
Principle
When the Executable of an Application is built, a Memory Map file is generated. This file can be visualized with the Memory Map Analyzer, an Eclipse IDE plug-in. It displays the memory consumption of different features in the RAM and ROM.
data:image/s3,"s3://crabby-images/a5d43/a5d430c98f3e4eb456a26d67be4a589f00bca6a7" alt="Memory Map Analyzer Process"
Memory Map Analyzer Process
Use
When the Executable file of an Application has been produced,
the Memory Map file is available at build/application/object/soar/<main-class-full-name>.map
.
data:image/s3,"s3://crabby-images/cd9bb/cd9bb243bf67e1a8b6fa1a905d64ec06bda7e4f8" alt="Retrieve Map File"
Memory Map File
You can visualize it by following these steps:
Make sure the Eclipse IDE is installed with the required plugin, then launch it.
Click on File > Open File….
Select the Memory Map file.
data:image/s3,"s3://crabby-images/4a40d/4a40d1c6d7973522e5bbe86485df77a9465617da" alt="Consult Full Memory"
Consult Full Memory
You can select an item (or several) to show the memory used by this item(s) on the right,
or select All
to show the memory used by all items.
This special item performs the same action as selecting all items in the list.
You can also select an item in the list, and expand it to see all symbols used by the item. This view is useful in understanding why a symbol is embedded.
data:image/s3,"s3://crabby-images/7e790/7e790fc8406490f9b7f4edeb92ed4c725fbac838" alt="Detailed view"
Detailed View
Troubleshooting
Memory Map Analyzer may fail while opening a Memory Map file saying Could not read this file.
data:image/s3,"s3://crabby-images/9bcf7/9bcf7ad2c78f643f5c8f3836d522e75cc8fc4eef" alt=""Could not read this file" Error"
Error displayed when Memory Map file could not be read
This may happen if the Memory Map Analyzer cannot find a VEE Port to interpret the Memory Map file. To workaround this, you can open your Memory Map file with a text editor and add the following line:
<property name="jpf.dir" value="/path/to/your/vee"/>
If a line defining the jpf.dir
already exists, check if the value corresponds to a valid path.
Note
The path must be the directory of a built VEE Port. If you build a Kernel Application, the
VEE Port will be available in the build/vee
directory of your Gradle project.