diff --git a/sys/netgraph/ng_fec.c b/sys/netgraph/ng_fec.c index 972a00aa45e..e47abab898e 100644 --- a/sys/netgraph/ng_fec.c +++ b/sys/netgraph/ng_fec.c @@ -694,10 +694,28 @@ ng_fec_ioctl(struct ifnet *ifp, u_long command, caddr_t data) /* These two are mostly handled at a higher layer */ case SIOCSIFADDR: case SIOCGIFADDR: - case SIOCSIFMTU: error = ether_ioctl(ifp, command, data); break; + case SIOCSIFMTU: + if (ifr->ifr_mtu >= NG_FEC_MTU_MIN && + ifr->ifr_mtu <= NG_FEC_MTU_MAX) { + struct ng_fec_portlist *p; + struct ifnet *bifp; + + TAILQ_FOREACH(p, &b->ng_fec_ports, fec_list) { + bifp = p->fec_if; + error = (*bifp->if_ioctl)(bifp, SIOCSIFMTU, + data); + if (error != 0) + break; + } + if (error == 0) + ifp->if_mtu = ifr->ifr_mtu; + } else + error = EINVAL; + break; + /* Set flags */ case SIOCSIFFLAGS: /*