Compare commits
5 Commits
v0.0.95-mu
...
v0.0.96-mu
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7c50a9d162 | ||
|
|
6538d301d1 | ||
|
|
63831d6efc | ||
|
|
cbb498bb74 | ||
|
|
e2706aecdb |
2
mud
2
mud
Submodule mud updated: b809bf0785...b53248b6da
@@ -257,10 +257,10 @@ gt_bind(int argc, char **argv)
|
|||||||
res.ret = EAGAIN;
|
res.ret = EAGAIN;
|
||||||
|
|
||||||
for (unsigned i = 0; i < count; i++) {
|
for (unsigned i = 0; i < count; i++) {
|
||||||
if (i && sendto(ctl_fd, &res, sizeof(res), 0,
|
memcpy(&res.path_status, &paths[i], sizeof(struct mud_path));
|
||||||
|
if (sendto(ctl_fd, &res, sizeof(res), 0,
|
||||||
(const struct sockaddr *)&ss, sl) == -1)
|
(const struct sockaddr *)&ss, sl) == -1)
|
||||||
perror("sendto(ctl)");
|
perror("sendto(ctl)");
|
||||||
memcpy(&res.path_status, &paths[i], sizeof(struct mud_path));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
res.ret = 0;
|
res.ret = 0;
|
||||||
|
|||||||
@@ -108,5 +108,6 @@ gt_toaddr(char *str, size_t size, struct sockaddr *sa)
|
|||||||
&((struct sockaddr_in6 *)sa)->sin6_addr, str, size);
|
&((struct sockaddr_in6 *)sa)->sin6_addr, str, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
errno = EAFNOSUPPORT;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|||||||
19
src/path.c
19
src/path.c
@@ -21,11 +21,20 @@ gt_path_status(int fd)
|
|||||||
if (recv(fd, &res, sizeof(struct ctl_msg), 0) == -1)
|
if (recv(fd, &res, sizeof(struct ctl_msg), 0) == -1)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
if (res.type != req.type)
|
||||||
|
return -2;
|
||||||
|
|
||||||
|
if (!res.ret)
|
||||||
|
return 0;
|
||||||
|
|
||||||
char bindstr[INET6_ADDRSTRLEN] = {0};
|
char bindstr[INET6_ADDRSTRLEN] = {0};
|
||||||
|
char publstr[INET6_ADDRSTRLEN] = {0};
|
||||||
char peerstr[INET6_ADDRSTRLEN] = {0};
|
char peerstr[INET6_ADDRSTRLEN] = {0};
|
||||||
|
|
||||||
if (gt_toaddr(bindstr, sizeof(bindstr),
|
if (gt_toaddr(bindstr, sizeof(bindstr),
|
||||||
(struct sockaddr *)&res.path_status.local_addr) ||
|
(struct sockaddr *)&res.path_status.local_addr) ||
|
||||||
|
gt_toaddr(publstr, sizeof(publstr),
|
||||||
|
(struct sockaddr *)&res.path_status.r_addr) ||
|
||||||
gt_toaddr(peerstr, sizeof(peerstr),
|
gt_toaddr(peerstr, sizeof(peerstr),
|
||||||
(struct sockaddr *)&res.path_status.addr))
|
(struct sockaddr *)&res.path_status.addr))
|
||||||
return -2;
|
return -2;
|
||||||
@@ -41,10 +50,14 @@ gt_path_status(int fd)
|
|||||||
|
|
||||||
printf("path %s\n"
|
printf("path %s\n"
|
||||||
" bind: %s\n"
|
" bind: %s\n"
|
||||||
|
" public: %s port %"PRIu16"\n"
|
||||||
" peer: %s port %"PRIu16"\n"
|
" peer: %s port %"PRIu16"\n"
|
||||||
" rtt: %.3f\n",
|
" mtu: %zu bytes\n"
|
||||||
statestr, bindstr, peerstr,
|
" rtt: %.3f ms\n",
|
||||||
gt_get_port((struct sockaddr *)&res.path_status.addr),
|
statestr, bindstr,
|
||||||
|
publstr, gt_get_port((struct sockaddr *)&res.path_status.r_addr),
|
||||||
|
peerstr, gt_get_port((struct sockaddr *)&res.path_status.addr),
|
||||||
|
res.path_status.mtu.ok + 28U, /* ip+udp hdr */
|
||||||
res.path_status.rtt/(double)1e3);
|
res.path_status.rtt/(double)1e3);
|
||||||
|
|
||||||
} while (res.ret == EAGAIN);
|
} while (res.ret == EAGAIN);
|
||||||
|
|||||||
Reference in New Issue
Block a user