aboutsummaryrefslogtreecommitdiff
path: root/libbb
diff options
context:
space:
mode:
authorBjørn Mork <bjorn@mork.no>2015-05-15 10:25:21 +0200
committerBjørn Mork <bjorn@mork.no>2015-05-15 10:25:21 +0200
commitb8c5c3b44362778c099531f7a905c56a0423bcef (patch)
treee9ccaff5d19f39e7bc58734e1b5babf4025a3a9c /libbb
parentb1b227fa5e00d08af047ab9a012211b66c6b0f13 (diff)
ripe-atlas-fw: imported version 46504650
Signed-off-by: Bjørn Mork <bjorn@mork.no>
Diffstat (limited to 'libbb')
-rw-r--r--libbb/Kbuild2
-rw-r--r--libbb/atlas_timesync.c19
-rw-r--r--libbb/bind_interface.c42
3 files changed, 63 insertions, 0 deletions
diff --git a/libbb/Kbuild b/libbb/Kbuild
index 178347d..0b77f72 100644
--- a/libbb/Kbuild
+++ b/libbb/Kbuild
@@ -10,6 +10,7 @@ lib-y += appletlib.o
lib-y += ask_confirmation.o
lib-y += atlas_bb64.o
lib-y += atlas_probe.o
+lib-y += atlas_timesync.o
lib-y += bb_askpass.o
lib-y += bb_basename.o
lib-y += bb_do_delay.o
@@ -17,6 +18,7 @@ lib-y += bb_pwd.o
lib-y += bb_qsort.o
lib-y += bb_strtod.o
lib-y += bb_strtonum.o
+lib-y += bind_interface.o
lib-y += change_identity.o
lib-y += chomp.o
lib-y += compare_string_array.o
diff --git a/libbb/atlas_timesync.c b/libbb/atlas_timesync.c
new file mode 100644
index 0000000..3434493
--- /dev/null
+++ b/libbb/atlas_timesync.c
@@ -0,0 +1,19 @@
+/*
+ * Copyright (c) 2013 RIPE NCC <atlas@ripe.net>
+ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
+ */
+
+#include "libbb.h"
+int get_timesync(void)
+{
+ FILE *fh;
+ int lastsync;
+
+ fh= fopen(ATLAS_TIMESYNC_FILE, "r");
+ if (!fh)
+ return -1;
+ fscanf(fh, "%d", &lastsync);
+ fclose(fh);
+ return time(NULL)-lastsync;
+}
+
diff --git a/libbb/bind_interface.c b/libbb/bind_interface.c
new file mode 100644
index 0000000..1eb4414
--- /dev/null
+++ b/libbb/bind_interface.c
@@ -0,0 +1,42 @@
+/*
+ * Copyright (c) 2014 RIPE NCC <atlas@ripe.net>
+ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
+ */
+
+#include "libbb.h"
+
+int bind_interface(int socket, int af, char *name)
+{
+ struct sockaddr_storage sa;
+
+ memset(&sa, '\0', sizeof(sa));
+
+ if (af == AF_INET)
+ {
+ sa.ss_family= AF_INET;
+ if (inet_pton(af, name,
+ &((struct sockaddr_in *)&sa)->sin_addr) == 1)
+ {
+ return bind(socket, (struct sockaddr *)&sa,
+ sizeof(sa));
+ }
+ }
+ else
+ {
+ sa.ss_family= AF_INET6;
+ if (inet_pton(af, name,
+ &((struct sockaddr_in6 *)&sa)->sin6_addr) == 1)
+ {
+ return bind(socket, (struct sockaddr *)&sa,
+ sizeof(sa));
+ }
+ }
+ if (setsockopt(socket, SOL_SOCKET, SO_BINDTODEVICE, name,
+ strlen(name)+1) == -1)
+ {
+ return -1;
+ }
+
+ return 0;
+}
+