diff options
author | Stefano Brivio <sbrivio@redhat.com> | 2021-09-01 16:38:49 +0200 |
---|---|---|
committer | Stefano Brivio <sbrivio@redhat.com> | 2021-09-01 16:49:21 +0200 |
commit | 75a7239e5ba16e0cf506a8d41ca747bd964f4937 (patch) | |
tree | 90bfecd79d71aaf4fbbe31619402fca402def847 | |
parent | 353185cd3642d62dadfc9d9be020a4f729400e41 (diff) | |
download | passt-75a7239e5ba16e0cf506a8d41ca747bd964f4937.tar passt-75a7239e5ba16e0cf506a8d41ca747bd964f4937.tar.gz passt-75a7239e5ba16e0cf506a8d41ca747bd964f4937.tar.bz2 passt-75a7239e5ba16e0cf506a8d41ca747bd964f4937.tar.lz passt-75a7239e5ba16e0cf506a8d41ca747bd964f4937.tar.xz passt-75a7239e5ba16e0cf506a8d41ca747bd964f4937.tar.zst passt-75a7239e5ba16e0cf506a8d41ca747bd964f4937.zip |
tap: Make sure we don't receive frames bigger than ETH_MAX_MTU from qemu
And while at it, remove some attributes that are not needed anymore
after introducing command line options.
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
-rw-r--r-- | tap.c | 9 |
1 files changed, 4 insertions, 5 deletions
@@ -322,8 +322,7 @@ static int tap4_handler(struct ctx *c, struct tap_msg *msg, size_t count, static int tap6_handler(struct ctx *c, struct tap_msg *msg, size_t count, struct timespec *now, int first) { - char buf_s[INET6_ADDRSTRLEN] __attribute((__unused__)); - char buf_d[INET6_ADDRSTRLEN] __attribute((__unused__)); + char buf_s[INET6_ADDRSTRLEN], buf_d[INET6_ADDRSTRLEN]; struct ethhdr *eh = (struct ethhdr *)msg[0].start; struct udphdr *uh, *prev_uh = NULL; uint8_t proto = 0, prev_proto = 0; @@ -462,12 +461,12 @@ static int tap_handler_passt(struct ctx *c, struct timespec *now) while (n > (ssize_t)sizeof(uint32_t)) { ssize_t len = ntohl(*(uint32_t *)p); + if (len < (ssize_t)sizeof(*eh) || len > ETH_MAX_MTU) + return 0; + p += sizeof(uint32_t); n -= sizeof(uint32_t); - if (len < (ssize_t)sizeof(*eh)) - return 0; - /* At most one packet might not fit in a single read */ if (len > n) { rem = recv(c->fd_tap, p + n, len - n, MSG_DONTWAIT); |