X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=util.c;h=4ae57bbd65857b684a1136cbe2bef0a8b2f24d80;hb=a04f58d6cb678a574e85a26c453aeb6c7884bb93;hp=9da7d985fa5caacaffac58648f3b533f243b4e72;hpb=67d51650ce3c3741bad8e5dca5d4e03c30f266cd;p=elogind.git diff --git a/util.c b/util.c index 9da7d985f..4ae57bbd6 100644 --- a/util.c +++ b/util.c @@ -32,6 +32,7 @@ #include #include #include +#include #include "macro.h" #include "util.h" @@ -1084,6 +1085,44 @@ bool ignore_file(const char *filename) { endswith(filename, ".swp"); } +int fd_nonblock(int fd, bool nonblock) { + int flags; + + assert(fd >= 0); + + if ((flags = fcntl(fd, F_GETFL, 0)) < 0) + return -errno; + + if (nonblock) + flags |= O_NONBLOCK; + else + flags &= ~O_NONBLOCK; + + if (fcntl(fd, F_SETFL, flags) < 0) + return -errno; + + return 0; +} + +int fd_cloexec(int fd, bool cloexec) { + int flags; + + assert(fd >= 0); + + if ((flags = fcntl(fd, F_GETFD, 0)) < 0) + return -errno; + + if (cloexec) + flags |= FD_CLOEXEC; + else + flags &= ~FD_CLOEXEC; + + if (fcntl(fd, F_SETFD, flags) < 0) + return -errno; + + return 0; +} + static const char *const ioprio_class_table[] = { [IOPRIO_CLASS_NONE] = "none", [IOPRIO_CLASS_RT] = "realtime",