Date: Mon, 29 Dec 2008 19:47:53 +0000 (GMT) From: Robert Watson <rwatson@FreeBSD.org> To: Dan Nelson <dnelson@allantgroup.com> Cc: Yuri <yuri@rawbw.com>, freebsd-hackers@freebsd.org Subject: Re: How process size is calculated? Is it always based on the current highest available address in memory space? Message-ID: <alpine.BSF.1.10.0812291947100.9438@fledge.watson.org> In-Reply-To: <20081229154544.GB21654@dan.emsphone.com> References: <49585C75.80203@rawbw.com> <20081229154544.GB21654@dan.emsphone.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, 29 Dec 2008, Dan Nelson wrote:
> In the last episode (Dec 28), Yuri said:
>> malloc(3) can be controlled by MALLOC_OPTIONS to use mmap-based allocation
>> as opposed to sbrk-based allocation. But allocations/deallocations with
>> mmaps can eventually lead to non-continuously mmapped memory (having some
>> non-mmapped gaps).
>>
>> Are these gaps excluded from the process size or size is always linked to
>> the current highest available address in memory space?
>
> It looks like only mapped memory is counted in process size. The test
> program below shows that the reported size goes down, even if a memory range
> inbetween two others is unmapped:
You can use procstat(8), or on older versions of FreeBSD procfs, to explore
the layout of process memory, which may also lend some insight to what's going
on.
Robert N M Watson
Computer Laboratory
University of Cambridge
>
> $ ./mmap
> Before mmap:
> UID PID PPID CPU PRI NI VSZ RSS MWCHAN STAT TT TIME COMMAND
> 1000 48058 62165 0 8 0 1928 824 wait S+ ph 0:00.01 ./mmap
> mmap 64MB A=0x28280000
> UID PID PPID CPU PRI NI VSZ RSS MWCHAN STAT TT TIME COMMAND
> 1000 48058 62165 0 8 0 67464 824 wait S+ ph 0:00.01 ./mmap
> mmap 64MB B=0x2c280000
> UID PID PPID CPU PRI NI VSZ RSS MWCHAN STAT TT TIME COMMAND
> 1000 48058 62165 0 8 0 133000 824 wait S+ ph 0:00.01 ./mmap
> mmap 64MB C=0x30280000
> UID PID PPID CPU PRI NI VSZ RSS MWCHAN STAT TT TIME COMMAND
> 1000 48058 62165 0 8 0 198536 824 wait S+ ph 0:00.01 ./mmap
> munmap B
> UID PID PPID CPU PRI NI VSZ RSS MWCHAN STAT TT TIME COMMAND
> 1000 48058 62165 0 8 0 133000 824 wait S+ ph 0:00.01 ./mmap
>
>
> #include <stdio.h>
> #include <stdlib.h>
> #include <sys/mman.h>
> #include <unistd.h>
>
> int main(void)
> {
> char *cmd;
> void *a, *b, *c;
> asprintf(&cmd, "ps axlp %d", getpid());
> printf("Before mmap:\n");
> system(cmd);
> a = mmap(NULL, 64 * 1024 * 1024, PROT_READ|PROT_WRITE, MAP_ANON, -1, 0);
> printf("mmap 64MB A=%p\n", a);
> system(cmd);
> b = mmap(NULL, 64 * 1024 * 1024, PROT_READ|PROT_WRITE, MAP_ANON, -1, 0);
> printf("mmap 64MB B=%p\n", b);
> system(cmd);
> c = mmap(NULL, 64 * 1024 * 1024, PROT_READ|PROT_WRITE, MAP_ANON, -1, 0);
> printf("mmap 64MB C=%p\n", c);
> system(cmd);
> printf("munmap B\n");
> munmap(b, 64 * 1024 * 1024);
> system(cmd);
> return 0;
> }
>
>
> --
> Dan Nelson
> dnelson@allantgroup.com
> _______________________________________________
> freebsd-hackers@freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
> To unsubscribe, send any mail to "freebsd-hackers-unsubscribe@freebsd.org"
>
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?alpine.BSF.1.10.0812291947100.9438>
