diff --git a/net/netdev/netdev_ioctl.c b/net/netdev/netdev_ioctl.c index 92aae1b3b1..6d19058fd4 100644 --- a/net/netdev/netdev_ioctl.c +++ b/net/netdev/netdev_ioctl.c @@ -920,13 +920,13 @@ static int netdev_ifr_ioctl(FAR struct socket *psock, int cmd, case SIOCGLIFMTU: /* Get MTU size */ case SIOCGIFMTU: /* Get MTU size */ - req->ifr_mtu = NETDEV_PKTSIZE(dev); + req->ifr_mtu = NETDEV_PKTSIZE(dev) - dev->d_llhdrlen; break; case SIOCSIFMTU: /* Set MTU size */ dev = netdev_ifr_dev(req); if (dev) { - NETDEV_PKTSIZE(dev) = req->ifr_mtu; + NETDEV_PKTSIZE(dev) = req->ifr_mtu + dev->d_llhdrlen; } break; diff --git a/net/procfs/netdev_statistics.c b/net/procfs/netdev_statistics.c index 124d7e7da2..fdc6ea5ab8 100644 --- a/net/procfs/netdev_statistics.c +++ b/net/procfs/netdev_statistics.c @@ -248,7 +248,10 @@ static int netprocfs_linklayer(FAR struct netprocfs_file_s *netfile) } len += snprintf(&netfile->line[len], NET_LINELEN - len, - " at %s\n", status); + " at %s", status); + + len += snprintf(&netfile->line[len], NET_LINELEN - len, + " mtu %d\n", (dev->d_pktsize - dev->d_llhdrlen)); return len; }