See http://marc.info/?l=linux-mm&m=142122902313315&w=2 for more
information.

On Mon 19-01-15 14:17:43, long.wanglong wrote:
> Hi all:
> 
> In the latest kernel, i set the memory limit (4096) in a test cgroup. and add 
> the test task.
> the test code code is:
> 
> testcase 1: mmap with MAP_LOCKED flag(memsize = 8192)
> 
> 185                 p = mmap(NULL, memsize, PROT_WRITE | PROT_READ,
> 186                          MAP_PRIVATE | MAP_ANONYMOUS | MAP_LOCKED, 0, 0);
> 187                 if (p == MAP_FAILED)
> 188                         err(1, "mmap(lock) failed");
>                                       
> expect: invoke OOM killer.
> result: not invoke OOM killer.
> 
> 
> testcase 2: mmap without MAP_LOCKED flag and the call mlock (memsize = 8192)
> 
> 185                 p = mmap(NULL, memsize, PROT_WRITE | PROT_READ,
> 186                          MAP_PRIVATE | MAP_ANONYMOUS, 0, 0);
> 187                 if (p == MAP_FAILED)
> 188                         err(1, "mmap(lock) failed");
> 189
> 190                 if (mlock(p, memsize) == -1)
> 191                         err(1, "mlock failed")
> 
> expect: invoke OOM killer.
> result: invoke OOM killer.
> 
> in the Linux Programmer's Manual:
> 
> MAP_LOCKED (since Linux 2.5.37)
>               Lock the pages of the mapped region into memory in the manner
>               of mlock(2).  This flag is ignored in older kernels.
>       
> and
>        mlock() locks pages in the address range starting at addr and
>        continuing for len bytes.  All pages that contain a part of the
>        specified address range are guaranteed to be resident in RAM when the
>        call returns successfully; the pages are guaranteed to stay in RAM
>        until later unlocked.
>       
> According to the description in the manual, the two testcases are equivalent.
> 
> why the first testcase does not invoke OOM killer?
> does the mmap with MAP_LOCKED flag will not immediately allocate physical 
> memory?
> 
> 
> Best Regards
> Wang Long
> 

-- 
Michal Hocko
SUSE Labs
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to