2016-03-29 06:24:54 +00:00
|
|
|
#include "common.h"
|
|
|
|
|
2016-04-06 13:25:53 +00:00
|
|
|
/*
|
|
|
|
* Print out:
|
|
|
|
* <src>:<port> -> <dst> ifa(<id>) <name>: pkt <value>/<count>, ttl <ttl>
|
|
|
|
*/
|
|
|
|
static void
|
2016-04-06 13:46:02 +00:00
|
|
|
rcv_print(sock *sk, struct socktest_packet *pkt)
|
2016-03-29 06:24:54 +00:00
|
|
|
{
|
2016-04-01 07:38:14 +00:00
|
|
|
char ifa_name[IF_NAMESIZE];
|
|
|
|
char buf[1024];
|
2016-04-06 13:25:53 +00:00
|
|
|
char *pos;
|
|
|
|
int unused_size;
|
|
|
|
|
|
|
|
if (!if_indextoname(sk->lifindex, ifa_name))
|
|
|
|
{
|
|
|
|
perror("if_indextoname");
|
|
|
|
snprintf(ifa_name, sizeof(ifa_name), "???");
|
|
|
|
}
|
|
|
|
|
|
|
|
bsnprintf(buf, sizeof(buf), "%I", sk->faddr);
|
|
|
|
pos = buf + strlen(buf);
|
|
|
|
unused_size = sizeof(buf) - (pos - buf);
|
|
|
|
|
|
|
|
if (sk->type != SK_IP)
|
|
|
|
bsnprintf(pos, unused_size, ":%u", sk->fport);
|
|
|
|
pos = buf + strlen(buf);
|
|
|
|
unused_size = sizeof(buf) - (pos - buf);
|
|
|
|
|
|
|
|
bsnprintf(pos, unused_size, " -> %I ifa(%u) %s: ", sk->laddr, sk->lifindex, ifa_name);
|
|
|
|
pos = buf + strlen(buf);
|
|
|
|
unused_size = sizeof(buf) - (pos - buf);
|
|
|
|
|
|
|
|
if (pkt->magic == (u32)PKT_MAGIC)
|
|
|
|
bsnprintf(pos, unused_size, "pkt %d/%d, ttl %d", pkt->value, pkt->count, sk->rcv_ttl);
|
|
|
|
else
|
|
|
|
bsnprintf(pos, unused_size, "magic value does not pass: recv %u, expected %u", pkt->magic, (u32)PKT_MAGIC);
|
|
|
|
|
|
|
|
printf("%s\n", buf);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
rcv_hook(sock *sk, int size)
|
|
|
|
{
|
2016-04-06 13:46:02 +00:00
|
|
|
struct socktest_packet *raw;
|
2016-04-01 07:38:14 +00:00
|
|
|
|
|
|
|
if (cf_count && ++counter > cf_count)
|
|
|
|
exit(0);
|
|
|
|
|
2016-03-29 06:24:54 +00:00
|
|
|
if (sk->type == SK_IP)
|
|
|
|
raw = (void *) sk_rx_buffer(sk, &size);
|
|
|
|
else
|
|
|
|
raw = (void *) sk->rbuf;
|
|
|
|
|
2016-04-06 13:46:02 +00:00
|
|
|
if (size != sizeof(struct socktest_packet))
|
2016-03-29 06:24:54 +00:00
|
|
|
{
|
2016-04-01 07:38:14 +00:00
|
|
|
printf("Received a packet with unexpected length of %d bytes \n", size);
|
2016-03-29 06:24:54 +00:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2016-04-06 13:46:02 +00:00
|
|
|
struct socktest_packet pkt = {
|
2016-03-29 06:24:54 +00:00
|
|
|
.magic = ntohl(raw->magic),
|
|
|
|
.value = ntohl(raw->value),
|
|
|
|
.count = ntohl(raw->count),
|
|
|
|
};
|
|
|
|
|
2016-04-06 13:25:53 +00:00
|
|
|
rcv_print(sk, &pkt);
|
2016-03-29 06:24:54 +00:00
|
|
|
|
2016-04-01 07:38:14 +00:00
|
|
|
/* Clear receive buffer */
|
|
|
|
return 1;
|
2016-03-29 06:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2016-04-01 07:38:14 +00:00
|
|
|
main(int argc, char *argv[])
|
2016-03-29 06:24:54 +00:00
|
|
|
{
|
2016-04-06 13:46:02 +00:00
|
|
|
socktest_bird_init();
|
2016-03-29 06:24:54 +00:00
|
|
|
|
2016-04-06 13:46:02 +00:00
|
|
|
sock *s = socktest_parse_args(argc, argv, 0);
|
2016-03-29 06:24:54 +00:00
|
|
|
s->rx_hook = rcv_hook;
|
|
|
|
s->rbsize = 1500;
|
2016-04-06 13:46:02 +00:00
|
|
|
s->flags |= SKF_LADDR_RX | SKF_TTL_RX;
|
2016-03-29 06:24:54 +00:00
|
|
|
|
2016-04-06 13:46:02 +00:00
|
|
|
socktest_open(s);
|
2016-03-29 06:24:54 +00:00
|
|
|
|
|
|
|
while (1)
|
|
|
|
{
|
|
|
|
sk_read(s);
|
|
|
|
usleep(20000);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|