On Mon, Feb 9, 2009 at 11:10 AM, Greg KH <greg@xxxxxxxxx> wrote: > On Sun, Feb 08, 2009 at 02:06:34PM -0800, Davide Libenzi wrote: >> On Mon, 9 Feb 2009, Michael Kerrisk wrote: >> >> > On Mon, Feb 9, 2009 at 10:50 AM, Davide Libenzi <davidel@xxxxxxxxxxxxxxx> wrote: >> > > On Mon, 9 Feb 2009, Michael Kerrisk wrote: >> > > >> > >> > @@ -186,12 +187,9 @@ SYSCALL_DEFINE2(timerfd_create, int, clo >> > >> > BUILD_BUG_ON(TFD_CLOEXEC != O_CLOEXEC); >> > >> > BUILD_BUG_ON(TFD_NONBLOCK != O_NONBLOCK); >> > >> > >> > >> > - if (flags & ~(TFD_CLOEXEC | TFD_NONBLOCK)) >> > >> > + if ((flags & ~TFD_FLAGS_SET) || >> > >> > + invalid_clockid(clockid)) >> > >> > return -EINVAL; >> > >> >> > >> Oh! Does this mean that in 2.6.2[789] it wasn't possible to use >> > >> TFD_TIMER_ABSTIME? >> > > >> > > No, sorry, my fault. Patch is wrong. In "create" ATM we accept only >> > > FCNTL-like flags. In "settime" we get TFD_TIMER_ABSTIME (that needs a >> > > check too for EINVAL). >> > >> > That last piece should be a separate patch, that also gets pushed back >> > into -stable. Do you agree? >> >> Hmm, it's a check for extra bits that do not cause any harm. Dunno if it >> fits -stable requirements. You should ask Greg. > > If it fixes a bug, it would go into -stable. Does this? Depends on the definition of bug, I guess ;-). The issue is this: a) timerfd_create() (added in kernel 2.6.25) has a flags argument. b) Currently, one such flag is supported: TFD_TIMER_ABSTIME c) Eventually, we may add other flag bits to the flags argument. d) Currently, timerfd_settime() does not check for invalid values in its flags argument (i.e., bits other than TFD_TIMER_ABSTIME) e) If/when new flag bits are added, then applications would like to have a way of determining whether there is support in a given kernel, something like: s = timerfd_settime(fd, TFD_XXX, newval, currval); if (s == 1 && errno == EINVAL) printf("TFD_XXX isn't supported by this kernel\n"); Davide, I think, proposes to add the missing check d) in kernel 2.6.29 (or 30). But, IMO, checks like the above are going to be more useful to userspace the further back in kernel time that we can push them. So, it's a philosophical kind of bug. Your call, I guess. Cheers, Michael -- Michael Kerrisk Linux man-pages maintainer; http://www.kernel.org/doc/man-pages/ git://git.kernel.org/pub/scm/docs/man-pages/man-pages.git man-pages online: http://www.kernel.org/doc/man-pages/online_pages.html Found a bug? http://www.kernel.org/doc/man-pages/reporting_bugs.html -- To unsubscribe from this list: send the line "unsubscribe linux-man" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html