linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Question about mmap syscall and POSIX standard on mips arch
@ 2018-10-18  3:26 Hongzhi, Song
  2018-10-18  4:32 ` Al Viro
  0 siblings, 1 reply; 3+ messages in thread
From: Hongzhi, Song @ 2018-10-18  3:26 UTC (permalink / raw)
  To: linux-kernel, mm-commits

Hi all,

Ltp has a POSIX teatcase about mmap, 24-2.c.

https://github.com/linux-test-project/ltp/blob/e816127e5d8efbff5ae53e9c2292fae22f36838b/testcases/open_posix_testsuite/conformance/interfaces/mmap/24-2.c#L94

-----part of code-----

     pa = mmap(addr, len, PROT_READ | PROT_WRITE, MAP_FIXED | 
MAP_SHARED, fd,
0);
     if (pa == MAP_FAILED && errno == ENOMEM) {
         printf("Got ENOMEM: %s\nTest PASSED\n", strerror(errno));
exit(PTS_PASS);
     }

-----end----------------


Under POSIX standard, the expected errno should be ENOMEM

when the specific [addr+len] exceeds the bound of memory.


But mips returns EINVAL.

https://github.com/torvalds/linux/blob/bab5c80b211035739997ebd361a679fa85b39465/arch/mips/mm/mmap.c#L69

-------part of code-------

     if (flags & MAP_FIXED) {
         /* Even MAP_FIXED mappings must reside within TASK_SIZE */
         if (TASK_SIZE - len < addr)
             return -EINVAL;

-------end------------------


So, can we change EINVAL to ENOMEM to follow POSIX standard?


--Hongzhi


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2018-10-18 23:09 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-10-18  3:26 Question about mmap syscall and POSIX standard on mips arch Hongzhi, Song
2018-10-18  4:32 ` Al Viro
2018-10-18 23:09   ` Paul Burton

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).