From df1bcc4229bbb492dba75b3e33666242e81151eb Mon Sep 17 00:00:00 2001 From: raiden00pl Date: Fri, 11 Oct 2019 08:03:44 +0000 Subject: [PATCH] Merged in raiden00/nuttx_sim (pull request #1047) drivers/pipes/fifo.c: mkfifo should return -1 and set errno on failure Approved-by: Gregory Nutt --- drivers/pipes/fifo.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/drivers/pipes/fifo.c b/drivers/pipes/fifo.c index 9ece1f8865..cf32107f0e 100644 --- a/drivers/pipes/fifo.c +++ b/drivers/pipes/fifo.c @@ -110,6 +110,7 @@ static const struct file_operations fifo_fops = int mkfifo2(FAR const char *pathname, mode_t mode, size_t bufsize) { FAR struct pipe_dev_s *dev; + int errcode; int ret; /* Allocate and initialize a new device structure instance */ @@ -117,16 +118,23 @@ int mkfifo2(FAR const char *pathname, mode_t mode, size_t bufsize) dev = pipecommon_allocdev(bufsize); if (!dev) { - return -ENOMEM; + errcode = ENOMEM; + goto errout; } ret = register_driver(pathname, &fifo_fops, mode, (FAR void *)dev); if (ret != 0) { pipecommon_freedev(dev); + errcode = -ret; + goto errout; } - return ret; + return OK; + +errout: + set_errno(errcode); + return ERROR; } #endif /* CONFIG_DEV_FIFO_SIZE > 0 */