flag parameters: NONBLOCK in inotify_init

Previous thread: flag parameters: check magic constants by Linux Kernel Mailing List on Thursday, July 24, 2008 - 4:10 pm. (1 message)

Next thread: serial/8250_gsc.c: add MODULE_LICENSE by Linux Kernel Mailing List on Thursday, July 24, 2008 - 4:10 pm. (1 message)
From: Linux Kernel Mailing List
Date: Thursday, July 24, 2008 - 4:10 pm

Gitweb:     http://git.kernel.org/git/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=510df2...
Commit:     510df2dd482496083e1c3b1a8c9b6afd5fa4c7d7
Parent:     be61a86d7237dd80510615f38ae21d6e1e98660c
Author:     Ulrich Drepper <drepper@redhat.com>
AuthorDate: Wed Jul 23 21:29:41 2008 -0700
Committer:  Linus Torvalds <torvalds@linux-foundation.org>
CommitDate: Thu Jul 24 10:47:29 2008 -0700

    flag parameters: NONBLOCK in inotify_init
    
    This patch adds non-blocking support for inotify_init1.  The
    additional changes needed are minimal.
    
    The following test must be adjusted for architectures other than x86 and
    x86-64 and in case the syscall numbers changed.
    
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    #include <fcntl.h>
    #include <stdio.h>
    #include <unistd.h>
    #include <sys/syscall.h>
    
    #ifndef __NR_inotify_init1
    # ifdef __x86_64__
    #  define __NR_inotify_init1 294
    # elif defined __i386__
    #  define __NR_inotify_init1 332
    # else
    #  error "need __NR_inotify_init1"
    # endif
    #endif
    
    #define IN_NONBLOCK O_NONBLOCK
    
    int
    main (void)
    {
      int fd = syscall (__NR_inotify_init1, 0);
      if (fd == -1)
        {
          puts ("inotify_init1(0) failed");
          return 1;
        }
      int fl = fcntl (fd, F_GETFL);
      if (fl == -1)
        {
          puts ("fcntl failed");
          return 1;
        }
      if (fl & O_NONBLOCK)
        {
          puts ("inotify_init1(0) set non-blocking mode");
          return 1;
        }
      close (fd);
    
      fd = syscall (__NR_inotify_init1, IN_NONBLOCK);
      if (fd == -1)
        {
          puts ("inotify_init1(IN_NONBLOCK) failed");
          return 1;
        }
      fl = fcntl (fd, F_GETFL);
      if (fl == -1)
        {
          puts ("fcntl failed");
          return 1;
        }
      if ((fl & O_NONBLOCK) == 0)
    ...
Previous thread: flag parameters: check magic constants by Linux Kernel Mailing List on Thursday, July 24, 2008 - 4:10 pm. (1 message)

Next thread: serial/8250_gsc.c: add MODULE_LICENSE by Linux Kernel Mailing List on Thursday, July 24, 2008 - 4:10 pm. (1 message)