mirror of
https://passt.top/passt
synced 2025-01-18 10:25:17 +00:00
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>
This commit is contained in:
parent
353185cd36
commit
75a7239e5b
9
tap.c
9
tap.c
@ -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);
|
||||
|
Loading…
x
Reference in New Issue
Block a user