Compare commits

...

3 Commits

Author SHA1 Message Date
Adrien Gallouët
c06abdbe3c Add set option kxtimeout
Signed-off-by: Adrien Gallouët <adrien@gallouet.fr>
2018-03-14 07:57:32 +00:00
Adrien Gallouët
b0a589b792 Use GT_RUNDIR for local sockets
Signed-off-by: Adrien Gallouët <adrien@gallouet.fr>
2018-03-14 07:06:25 +00:00
Adrien Gallouët
66cdcf2ee3 Update mud
Signed-off-by: Adrien Gallouët <adrien@gallouet.fr>
2018-03-14 06:55:37 +00:00
7 changed files with 49 additions and 18 deletions

2
mud

Submodule mud updated: b53248b6da...ef319d2153

View File

@@ -192,7 +192,7 @@ gt_bind(int argc, char **argv)
} }
} }
int ctl_fd = ctl_create("/run/" PACKAGE_NAME, tun_name); int ctl_fd = ctl_create(GT_RUNDIR, tun_name);
if (ctl_fd == -1) { if (ctl_fd == -1) {
perror("ctl_create"); perror("ctl_create");
@@ -267,7 +267,7 @@ gt_bind(int argc, char **argv)
} }
break; break;
case CTL_MTU: case CTL_MTU:
mud_set_mtu(mud, (size_t)req.mtu); mud_set_mtu(mud, req.mtu);
mtu = gt_setup_mtu(mud, tun_name); mtu = gt_setup_mtu(mud, tun_name);
res.mtu = mtu; res.mtu = mtu;
break; break;
@@ -275,12 +275,16 @@ gt_bind(int argc, char **argv)
if (mud_set_tc(mud, req.tc)) if (mud_set_tc(mud, req.tc))
res.ret = errno; res.ret = errno;
break; break;
case CTL_KXTIMEOUT:
if (mud_set_keyx_timeout(mud, req.ms))
res.ret = errno;
break;
case CTL_TIMEOUT: case CTL_TIMEOUT:
if (mud_set_send_timeout(mud, req.timeout)) if (mud_set_send_timeout(mud, req.ms))
res.ret = errno; res.ret = errno;
break; break;
case CTL_TIMETOLERANCE: case CTL_TIMETOLERANCE:
if (mud_set_time_tolerance(mud, req.timetolerance)) if (mud_set_time_tolerance(mud, req.ms))
res.ret = errno; res.ret = errno;
break; break;
case CTL_STATUS: case CTL_STATUS:

View File

@@ -21,6 +21,10 @@
#define PACKAGE_VERSION "0.0.0" #define PACKAGE_VERSION "0.0.0"
#endif #endif
#ifndef GT_RUNDIR
#define GT_RUNDIR "/run/" PACKAGE_NAME
#endif
#define COUNT(x) (sizeof(x)/sizeof(x[0])) #define COUNT(x) (sizeof(x)/sizeof(x[0]))
#define ALIGN_SIZE (1<<4) #define ALIGN_SIZE (1<<4)

View File

@@ -10,6 +10,7 @@ enum ctl_type {
CTL_STATUS, CTL_STATUS,
CTL_MTU, CTL_MTU,
CTL_TC, CTL_TC,
CTL_KXTIMEOUT,
CTL_TIMEOUT, CTL_TIMEOUT,
CTL_TIMETOLERANCE, CTL_TIMETOLERANCE,
CTL_PATH_STATUS, CTL_PATH_STATUS,
@@ -30,10 +31,9 @@ struct ctl_msg {
struct sockaddr_storage bind; struct sockaddr_storage bind;
struct sockaddr_storage peer; struct sockaddr_storage peer;
} status; } status;
int mtu; size_t mtu;
int tc; int tc;
unsigned long timeout; unsigned long ms;
unsigned long timetolerance;
}; };
}; };

View File

@@ -83,7 +83,7 @@ gt_path(int argc, char **argv)
if (argz(pathz, argc, argv)) if (argz(pathz, argc, argv))
return 1; return 1;
int fd = ctl_connect("/run/" PACKAGE_NAME, dev); int fd = ctl_connect(GT_RUNDIR, dev);
if (fd == -1) { if (fd == -1) {
perror("path"); perror("path");

View File

@@ -22,17 +22,35 @@ gt_set_mtu(int fd, size_t mtu)
return 1; return 1;
} }
printf("mtu set to %i\n", res.mtu); printf("mtu set to %zu\n", res.mtu);
return 0; return 0;
} }
static int static int
gt_set_timeout(int fd, unsigned long timeout) gt_set_kxtimeout(int fd, unsigned long ms)
{
struct ctl_msg res, req = {
.type = CTL_KXTIMEOUT,
.ms = ms,
};
int ret = ctl_reply(fd, &res, &req);
if (ret) {
perror("set kxtimeout");
return 1;
}
return 0;
}
static int
gt_set_timeout(int fd, unsigned long ms)
{ {
struct ctl_msg res, req = { struct ctl_msg res, req = {
.type = CTL_TIMEOUT, .type = CTL_TIMEOUT,
.timeout = timeout, .ms = ms,
}; };
int ret = ctl_reply(fd, &res, &req); int ret = ctl_reply(fd, &res, &req);
@@ -46,11 +64,11 @@ gt_set_timeout(int fd, unsigned long timeout)
} }
static int static int
gt_set_timetolerance(int fd, unsigned long timetolerance) gt_set_timetolerance(int fd, unsigned long ms)
{ {
struct ctl_msg res, req = { struct ctl_msg res, req = {
.type = CTL_TIMETOLERANCE, .type = CTL_TIMETOLERANCE,
.timetolerance = timetolerance, .ms = ms,
}; };
int ret = ctl_reply(fd, &res, &req); int ret = ctl_reply(fd, &res, &req);
@@ -113,13 +131,15 @@ gt_set(int argc, char **argv)
const char *dev = NULL; const char *dev = NULL;
size_t mtu; size_t mtu;
int tc; int tc;
unsigned long timetolerance; unsigned long kxtimeout;
unsigned long timeout; unsigned long timeout;
unsigned long timetolerance;
struct argz pathz[] = { struct argz pathz[] = {
{"dev", "NAME", &dev, argz_str}, {"dev", "NAME", &dev, argz_str},
{"mtu", "BYTES", &mtu, argz_bytes}, {"mtu", "BYTES", &mtu, argz_bytes},
{"tc", "CS|AF|EF", &tc, gt_argz_tc}, {"tc", "CS|AF|EF", &tc, gt_argz_tc},
{"kxtimeout", "SECONDS", &kxtimeout, argz_time},
{"timeout", "SECONDS", &timeout, argz_time}, {"timeout", "SECONDS", &timeout, argz_time},
{"timetolerance", "SECONDS", &timetolerance, argz_time}, {"timetolerance", "SECONDS", &timetolerance, argz_time},
{NULL}}; {NULL}};
@@ -127,7 +147,7 @@ gt_set(int argc, char **argv)
if (argz(pathz, argc, argv)) if (argz(pathz, argc, argv))
return 1; return 1;
int fd = ctl_connect("/run/" PACKAGE_NAME, dev); int fd = ctl_connect(GT_RUNDIR, dev);
if (fd == -1) { if (fd == -1) {
perror("set"); perror("set");
@@ -142,6 +162,9 @@ gt_set(int argc, char **argv)
if (argz_is_set(pathz, "tc")) if (argz_is_set(pathz, "tc"))
ret |= gt_set_tc(fd, tc); ret |= gt_set_tc(fd, tc);
if (argz_is_set(pathz, "kxtimeout"))
ret |= gt_set_kxtimeout(fd, kxtimeout);
if (argz_is_set(pathz, "timeout")) if (argz_is_set(pathz, "timeout"))
ret |= gt_set_timeout(fd, timeout); ret |= gt_set_timeout(fd, timeout);

View File

@@ -56,7 +56,7 @@ gt_show_dev_status(int fd, const char *dev)
static int static int
gt_show_dev(const char *dev) gt_show_dev(const char *dev)
{ {
int fd = ctl_connect("/run/" PACKAGE_NAME, dev); int fd = ctl_connect(GT_RUNDIR, dev);
if (fd == -1) { if (fd == -1) {
perror(dev); perror(dev);
@@ -93,7 +93,7 @@ gt_show(int argc, char **argv)
return 0; return 0;
} }
DIR *dp = opendir("/run/" PACKAGE_NAME); DIR *dp = opendir(GT_RUNDIR);
if (!dp) { if (!dp) {
if (errno == ENOENT) if (errno == ENOENT)