On Fri, 10 Jul 2009, G?nter Leonhardt wrote:

>  
> Hello,
> analysing the memory usage of a process, I found some questions.
> I'am using a system with 128 MB physical RAM, no disk, 2.6.27 kernel.
> 
> Running top, I see 38 MB in use, 90 MB free, but a VSZ for my process of 158 
> MB.
> Looking at /proc/<pid>/maps, I see that the process uses 140 MB without 
> shared libs.
> 
> So how it is possible that the process can allocate more memory than there 
> is, without posibility of swapping?
>
> Why said top that 90 MB free? Does the kernel serve the allocation only if 
> ist really used?
> 

an allocation does not actually set aside any physical ram (unless you do an 
mlock and actually touch the memory) - it only reserves virtual memory areas 
(vma's) and when your process accesses the respective address the OS 
page-faults and prvides the physical RAM as needed (and possible) - if you have 
no swap and you allow overcommitting of memory then you are potentially going 
to see this application failing as soon as it tries to utilize the memory.

This can be set in the system via /proc/sys/vm/overcommit_memory (see
linux/Documentation/vm/overcommit-accounting for details).
 
hofrat
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to