Memory usage analysis and optimization

Adam Lackorzynski adam at os.inf.tu-dresden.de
Sun Dec 18 23:45:49 CET 2016


Hi,

On Fri Dec 16, 2016 at 08:38:28 +0000, Jesse-SC Chou (©P®Ñ¥¿) wrote:
> I¡¦m analyzing the memory usage of Fiasco/L4Re/L4Linux.
> On my platform, there are 128MB physical memory.
> L4 bootstrap can detect it correctly.
> ==================================================
> L4 Bootstrapper
>   Build: #164 Îå 12ÔÂ  9 11:39:51 CST 2016, 4.8.4
>   Scanning up to 128 MB RAM, starting at offset 32MB
>   Memory size is 128MB (20000000 - 27ffffff)
>   RAM: 0000000020000000 - 0000000027ffffff: 131072kB
>   Total RAM: 128MB
> ==================================================
> 
> The memory regions after boot up and sigma0 loaded:
> ==================================================
> Regions of list 'regions'
>     [ 20000000,  200001c7] {      1c8} Root   mbi_rt
>     [ 20001000,  20001aff] {      b00} Kern   fiasco
>     [ 20002000,  20092fff] {    91000} Kern   fiasco
>     [ 200c0000,  200c9f43] {     9f44} Sigma0 sigma0
>     [ 200d0000,  200d6177] {     6178} Sigma0 sigma0
>     [ 20140000,  20168c27] {    28c28} Root   moe
>     [ 20170000,  2017b58b] {     b58c} Root   moe
>     [ 21000000,  2100e5e3] {     e5e4} Boot   bootstrap
>     [ 21100000,  21a2dfff] {   92e000} Root   Module
> 
> SIGMA0: Hello!
>   KIP @ 20002000
>   allocated 4KB for maintenance structures
> SIGMA0: Dump of all resource maps
> RAM:------------------------
> [4:20000000;20000fff]
> [0:20093000;200bffff]
> [0:200ca000;200cffff]
> [0:200d7000;2013ffff]
> [4:20140000;20168fff]
> [0:20169000;2016ffff]
> [4:20170000;2017bfff]
> [0:2017c000;210fffff]
> [4:21100000;21a2dfff]
> [0:21a2e000;26ffffff]
> ==================================================
> 
> The largest unused continuous memory region are at ¡§0x21a2e000 ~ 0x26ffffff¡¨, which is about 85MB.
> I would like to make continuous memory region larger and have the following ideas and questions:

Generally: yes, there are tuning possibilities, given that memory and
program sizes are known.

> 1.      The memory used by bootstrap may be freed after the system bring up. If moving ¡§bootstrap¡¨ program to 0x26000000, the ¡§Module¡¨ programs can append to ¡§MOE¡¨ program. The ¡§Module¡¨ will be started ¡§0x207c0000¡¨ (aligned to page size 4KB). Thus, I can get larger continuous memory area that originally separated by ¡§bootstrap¡¨ program. Is this idea correct ?
> 
>     [ 20170000,  2017b58b] {     b58c} Root   moe
>     [ 21000000,  2100e5e3] {     e5e4} Boot   bootstrap
>     [ 21100000,  21a2dfff] {   92e000} Root   Module

Yes, should generally work I think.

> 2.      There are a reserved region ¡§0x27000000 ~ 0x27FFFFFF¡¨ not shown in boot log. When I traced into program, this region seems used by sigma0. What is this memory used for? I think 16MB is a very large chunk in current embedded system. Can we compute the amount this area really use and shrink to a smaller size?

That's the memory taken by Fiasco, see src/kern/arm/config-arm.cpp
KMEMSIZE. Depending on your use case you can make this smaller.


Adam




More information about the l4-hackers mailing list