Could be reproduced with 3.6.9 and current HEAD.

Testcase:

$ uname -r # or 3.6.9-1.x86_64
3.7.0-0.483.ga1f347c0d5b8.x86_64

$ cat openmany.c
#include <errno.h>
#include <fcntl.h>
#include <stdio.h>
#include <sys/stat.h>

int main()
{
  for (int i = 0; i < 10000; i++) {
    char name[32];
    snprintf(name, sizeof(name), "file-%04d.tmp", i);
    errno = 0;
    int fd = open(name, O_WRONLY | O_CREAT | O_EXCL, 0666);
    if (fd >= 0)
      continue;
    printf("open(%s, ...)=%d (errno=%d)\n", name, fd, errno);
    struct stat st;
    printf("stat(%s, ...)=%d\n", name, stat(name, &st));
    break;
  }
  return 0;
}

$ gcc -o openmany openmany.c

$ ls file-*.tmp
ls: cannot access 'file-*.tmp': No such file or directory

$ ulimit -n
3200

$ ./openmany
open(file-3197.tmp, ...)=-1 (errno=24)
stat(file-3197.tmp, ...)=0

$ ls file-*.tmp
file-0000.tmp
file-0001.tmp
...
file-3195.tmp
file-3196.tmp
file-3197.tmp

$ grep -w 24 /usr/include/sys/errno.h
#define EMFILE 24       /* File descriptor value too large */


Looks like the fd is allocated too late.

--
Regards,
Christian


--
Problem reports:      https://cygwin.com/problems.html
FAQ:                  https://cygwin.com/faq/
Documentation:        https://cygwin.com/docs.html
Unsubscribe info:     https://cygwin.com/ml/#unsubscribe-simple

Reply via email to