ioops: misc: add dup{,2}_or_die to ioops
[netsniff-ng.git] / ioops.c
blob4ac0f3ae0bb2ba30ef6b4b34c32d0b520d95529e
1 #define _GNU_SOURCE
2 #include <unistd.h>
3 #include <sys/types.h>
4 #include <sys/stat.h>
5 #include <sys/ioctl.h>
6 #include <sys/socket.h>
7 #include <fcntl.h>
8 #include <linux/if.h>
9 #include <linux/if_tun.h>
11 #include "die.h"
12 #include "dev.h"
13 #include "ioops.h"
14 #include "str.h"
15 #include "built_in.h"
17 int open_or_die(const char *file, int flags)
19 int ret = open(file, flags);
20 if (ret < 0)
21 panic("Cannot open file %s! %s.\n", file, strerror(errno));
23 return ret;
26 int open_or_die_m(const char *file, int flags, mode_t mode)
28 int ret = open(file, flags, mode);
29 if (ret < 0)
30 panic("Cannot open or create file %s! %s.", file, strerror(errno));
31 return ret;
34 int dup_or_die(int oldfd)
36 int newfd = dup(oldfd);
37 if (unlikely(newfd < 0))
38 panic("Cannot dup old file descriptor!\n");
39 return newfd;
42 void dup2_or_die(int oldfd, int newfd)
44 int ret = dup2(oldfd, newfd);
45 if (unlikely(ret < 0))
46 panic("Cannot dup2 old/new file descriptor!\n");
49 void create_or_die(const char *file, mode_t mode)
51 int fd = open_or_die_m(file, O_WRONLY | O_CREAT, mode);
52 close(fd);
55 void pipe_or_die(int pipefd[2], int flags)
57 int ret = pipe2(pipefd, flags);
58 if (ret < 0)
59 panic("Cannot create pipe2 event fd! %s.\n", strerror(errno));
62 int tun_open_or_die(char *name, int type)
64 int fd, ret;
65 short flags;
66 struct ifreq ifr;
68 if (!name)
69 panic("No name provided for tundev!\n");
71 fd = open_or_die("/dev/net/tun", O_RDWR);
73 memset(&ifr, 0, sizeof(ifr));
74 ifr.ifr_flags = type;
75 strlcpy(ifr.ifr_name, name, IFNAMSIZ);
77 ret = ioctl(fd, TUNSETIFF, &ifr);
78 if (ret < 0)
79 panic("ioctl screwed up! %s.\n", strerror(errno));
81 ret = fcntl(fd, F_SETFL, fcntl(fd, F_GETFL) | O_NONBLOCK);
82 if (ret < 0)
83 panic("fctnl screwed up! %s.\n", strerror(errno));
85 flags = device_get_flags(name);
86 flags |= IFF_UP | IFF_RUNNING;
87 device_set_flags(name, flags);
89 return fd;
92 ssize_t read_or_die(int fd, void *buf, size_t len)
94 ssize_t ret = read(fd, buf, len);
95 if (ret < 0) {
96 if (errno == EPIPE)
97 die();
98 panic("Cannot read from descriptor! %s.\n", strerror(errno));
101 return ret;
104 ssize_t write_or_die(int fd, const void *buf, size_t len)
106 ssize_t ret = write(fd, buf, len);
107 if (ret < 0) {
108 if (errno == EPIPE)
109 die();
110 panic("Cannot write to descriptor! %s.", strerror(errno));
113 return ret;
116 int read_blob_or_die(const char *file, void *blob, size_t count)
118 int fd, ret;
120 fd = open_or_die(file, O_RDONLY);
121 ret = read_or_die(fd, blob, count);
122 close(fd);
124 return ret;
127 int write_blob_or_die(const char *file, const void *blob, size_t count)
129 int fd, ret;
131 fd = open_or_die_m(file, O_WRONLY | O_CREAT | O_TRUNC, S_IRUSR | S_IWUSR);
132 ret = write_or_die(fd, blob, count);
133 fdatasync(fd);
134 close(fd);
136 return ret;