[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <feaf5ed90905080049j78a4ab54x53ce65f22a3ea6a4@mail.gmail.com>
Date: Fri, 8 May 2009 16:49:54 +0900
From: Hiroyuki Machida <Hiroyuki.Mach@...il.com>
To: rohit verma <rohit.170309@...il.com>
Cc: linux-kernel@...r.kernel.org
Subject: epoll_create(0) becomes not to fail (Re: issue with epoll system
call)
Hi Verma,
I think your point is right. but descriptions looks not straight forward.
And title of the message is very confusable.
I think descriptions like following would be easy to understand, and
you should attach a your signed-off patch to fix the bug.
Thanks,
Hiro
----
The following patch changed behavior of epoll_create(0);
http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commitdiff;h=9fe5ad9c8cef9ad5873d8ee55d1cf00d9b607df0;hp=e38b36f325153eaadd1c2a7abc5762079233e540
Before applying the patch,
sys_epoll_create2(int size, int flags)
returned -EINVAL, with size=0;
But, if-condtion which is introduced in sys_epoll_create() by this patch,
looks to fail to consider case of size==0 as follows;
asmlinkage long sys_epoll_create(int size)
{
- return sys_epoll_create2(size, 0);
+ if (size < 0)
+ return -EINVAL;
+
+ return sys_epoll_create1(0);
}
---
Hiroyuki Machida
On Thu, May 7, 2009 at 4:10 PM, rohit verma <rohit.170309@...il.com> wrote:
> hi all,
>
> The man pages of epoll_create says - "Since Linux 2.6.8, the size
> argument is unused. (The kernel dynamically sizes the required data
> structures without needing this initial hint.)" .
>
> Also, it says that the syscall returns EINVAL , when size is not
> positive. (i.e For, any value greater than 0, the kernel dynamically
> sizes the required data stuctures). When size is zero or less than
> zero, it has to return with error as EINVAL.
>
> the link: http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commitdiff;h=9fe5ad9c8cef9ad5873d8ee55d1cf00d9b607df0;hp=e38b36f325153eaadd1c2a7abc5762079233e540
>
> shows the latest patch of the epoll syscall. here , the syscall says:
>
> asmlinkage long sys_epoll_create(int size)
> {
> - return sys_epoll_create2(size,0);
> + if (size < 0)
> + return -EINVAL;
> +
> +return sys_epoll_create1(0);
> }
>
> So if size = 0, it returns success which might not be the expected
> result. So i feel that the condition check should be
> " if (size <= 0) ". could u please check on this and reply me..
>
> Thank you,
>
> Regards,
> rohit
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@...r.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists