Handle a disconnecting tincd better.
- Try to prevent SIGPIPE from being sent for errors sending to the control socket. We don't outright block the SIGPIPE signal because we still want the tinc CLI to exit when its output is actually sent to a real (broken) pipe. - Don't call exit() from top(), and properly detect when the control socket is closed by the tincd.
This commit is contained in:
parent
09e000ba54
commit
f134bd0c9c
2 changed files with 22 additions and 10 deletions
|
@ -39,6 +39,10 @@
|
||||||
#include "tincctl.h"
|
#include "tincctl.h"
|
||||||
#include "top.h"
|
#include "top.h"
|
||||||
|
|
||||||
|
#ifndef MSG_NOSIGNAL
|
||||||
|
#define MSG_NOSIGNAL 0
|
||||||
|
#endif
|
||||||
|
|
||||||
static char **orig_argv;
|
static char **orig_argv;
|
||||||
static int orig_argc;
|
static int orig_argc;
|
||||||
|
|
||||||
|
@ -529,7 +533,7 @@ bool sendline(int fd, char *format, ...) {
|
||||||
blen++;
|
blen++;
|
||||||
|
|
||||||
while(blen) {
|
while(blen) {
|
||||||
int result = send(fd, p, blen, 0);
|
int result = send(fd, p, blen, MSG_NOSIGNAL);
|
||||||
if(result == -1 && errno == EINTR)
|
if(result == -1 && errno == EINTR)
|
||||||
continue;
|
continue;
|
||||||
else if(result <= 0)
|
else if(result <= 0)
|
||||||
|
@ -741,6 +745,11 @@ bool connect_tincd(bool verbose) {
|
||||||
freeaddrinfo(res);
|
freeaddrinfo(res);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef SO_NOSIGPIPE
|
||||||
|
static const int one = 1;
|
||||||
|
setsockopt(c, SOL_SOCKET, SO_NOSIGPIPE, (void *)&one, sizeof one);
|
||||||
|
#endif
|
||||||
|
|
||||||
char data[4096];
|
char data[4096];
|
||||||
int version;
|
int version;
|
||||||
|
|
||||||
|
|
21
src/top.c
21
src/top.c
|
@ -66,8 +66,10 @@ static float bscale = 1;
|
||||||
static const char *punit = "pkts";
|
static const char *punit = "pkts";
|
||||||
static float pscale = 1;
|
static float pscale = 1;
|
||||||
|
|
||||||
static void update(int fd) {
|
static bool update(int fd) {
|
||||||
sendline(fd, "%d %d", CONTROL, REQ_DUMP_TRAFFIC);
|
if(!sendline(fd, "%d %d", CONTROL, REQ_DUMP_TRAFFIC))
|
||||||
|
return false;
|
||||||
|
|
||||||
gettimeofday(&cur, NULL);
|
gettimeofday(&cur, NULL);
|
||||||
|
|
||||||
timersub(&cur, &prev, &diff);
|
timersub(&cur, &prev, &diff);
|
||||||
|
@ -90,13 +92,10 @@ static void update(int fd) {
|
||||||
int n = sscanf(line, "%d %d %s %"PRIu64" %"PRIu64" %"PRIu64" %"PRIu64, &code, &req, name, &in_packets, &in_bytes, &out_packets, &out_bytes);
|
int n = sscanf(line, "%d %d %s %"PRIu64" %"PRIu64" %"PRIu64" %"PRIu64, &code, &req, name, &in_packets, &in_bytes, &out_packets, &out_bytes);
|
||||||
|
|
||||||
if(n == 2)
|
if(n == 2)
|
||||||
break;
|
return true;
|
||||||
|
|
||||||
if(n != 7) {
|
if(n != 7)
|
||||||
endwin();
|
return false;
|
||||||
fprintf(stderr, "Error receiving traffic information\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
nodestats_t *found = NULL;
|
nodestats_t *found = NULL;
|
||||||
|
|
||||||
|
@ -133,6 +132,8 @@ static void update(int fd) {
|
||||||
found->out_packets = out_packets;
|
found->out_packets = out_packets;
|
||||||
found->out_bytes = out_bytes;
|
found->out_bytes = out_bytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int cmpfloat(float a, float b) {
|
static int cmpfloat(float a, float b) {
|
||||||
|
@ -246,7 +247,9 @@ void top(int fd) {
|
||||||
bool running = true;
|
bool running = true;
|
||||||
|
|
||||||
while(running) {
|
while(running) {
|
||||||
update(fd);
|
if(!update(fd))
|
||||||
|
break;
|
||||||
|
|
||||||
redraw();
|
redraw();
|
||||||
|
|
||||||
switch(getch()) {
|
switch(getch()) {
|
||||||
|
|
Loading…
Reference in a new issue