X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=system.c;h=76d80723fad800ec9ce81c0b00c516df888fdafc;hp=c85d0e419d4ca8cf7a2a395016bef3c781a5ea18;hb=3b8673edadc8ce6d1d90c12e6b8e57eeb291c521;hpb=bfe5db1ea8018aaa940dc6e991110fac62b85516 diff --git a/system.c b/system.c index c85d0e4..76d8072 100644 --- a/system.c +++ b/system.c @@ -13,15 +13,26 @@ */ #include "netifd.h" #include "system.h" +#include static const struct blobmsg_policy tunnel_attrs[__TUNNEL_ATTR_MAX] = { [TUNNEL_ATTR_TYPE] = { "mode", BLOBMSG_TYPE_STRING }, [TUNNEL_ATTR_LOCAL] = { "local", BLOBMSG_TYPE_STRING }, [TUNNEL_ATTR_REMOTE] = { "remote", BLOBMSG_TYPE_STRING }, [TUNNEL_ATTR_TTL] = { "ttl", BLOBMSG_TYPE_INT32 }, + [TUNNEL_ATTR_6RD_PREFIX] = { "6rd-prefix", BLOBMSG_TYPE_STRING }, + [TUNNEL_ATTR_6RD_RELAY_PREFIX] = { "6rd-relay-prefix", BLOBMSG_TYPE_STRING }, + [TUNNEL_ATTR_LINK] = { "link", BLOBMSG_TYPE_STRING }, }; const struct config_param_list tunnel_attr_list = { .n_params = __TUNNEL_ATTR_MAX, .params = tunnel_attrs, }; + +void system_fd_set_cloexec(int fd) +{ +#ifdef FD_CLOEXEC + fcntl(fd, F_SETFD, fcntl(fd, F_GETFD) | FD_CLOEXEC); +#endif +}