Opening a (second) descriptor for (blocking) write sometimes fail
The provided test case sometimes succeed, but quite often fail with ENOENT
(in various indexes)
I haven't dug deeper to find the underlaying cause yet
Have anyone experienced this before ?
Kristian
#include <string.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <stdio.h>
#include <errno.h>
int print_error(const int line, const int index, const int error)
{
printf("%d\t%d\t%s\n", line, index, strerror(error));
return error;
}
#define HANDLE_ERROR(result) do{if(result < 0){return print_error(__LINE__,
idx, errno);}}while(0);
int main()
{
const char *name = "/tmp/my_pipe";
/* just in case it exists */
remove(name);
for (long idx = 0; idx < 1000; ++idx)
{
const int fifo = mkfifo(name, 0666) ? -1 : 0;
HANDLE_ERROR(fifo);
const int rfd = open(name, O_RDONLY | O_NONBLOCK);
HANDLE_ERROR(rfd);
const int wfd = open(name, O_WRONLY);
HANDLE_ERROR(wfd);
HANDLE_ERROR(close(wfd));
HANDLE_ERROR(close(rfd));
HANDLE_ERROR(unlink(name));
}
return 0;
}
--
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