Gibt es eine Möglichkeit, eine Schnittstellen-MTU mithilfe von C unter Linux programmgesteuert festzulegen?

StackOverflow https://stackoverflow.com//questions/25026228

Frage

Im Moment macht mein Programm eine system() Ruf an ifconfig um dies zu tun.

Es scheint ein bisschen chaotisch zu sein – vielleicht ifconfig liegt nicht auf dem Weg oder an einem nicht standardmäßigen Ort.Und dann müsste ich nachsehen iproute2 gleichwertig im Fehlerfall.

Gibt es eine Möglichkeit, dies programmgesteuert mit C festzulegen?

Vielen Dank!

War es hilfreich?

Lösung

Sie können das SIOCSIFMTU-Feld in einem ioctl-Aufruf festlegen, etwa so:

struct ifreq ifr; 
ifr.ifr_addr.sa_family = AF_INET;//address family
strncpy(ifr.ifr_name, "eth0", sizeof(ifr.ifr_name));//interface name where you want to set the MTU
ifr.ifr_mtu = 9100; //your MTU size here
if (ioctl(sockfd, SIOCSIFMTU, (caddr_t)&ifr) < 0)
  //failed to set MTU. handle error.

Der obige Code legt die MTU eines Geräts (wie in ifr.name) mithilfe des Felds ifr_mtu in der ifreq-Struktur fest.

Verweisen: http://linux.die.net/man/7/netdevice

Andere Tipps

Sie können auch verwenden .Das vollständige Beispiel:

#include <stdio.h>
#include <string.h>
#include <net/if.h>
#include <sys/socket.h>
#include <linux/rtnetlink.h>

#define IFACE_NAME "enp5s0"

int main(void) {
     int ret, nl_sock;
     unsigned int mtu = 8000;
     struct rtattr  *rta;
     struct {
          struct nlmsghdr nh;
          struct ifinfomsg  ifinfo;
          char   attrbuf[512];
     } req;

     nl_sock = socket(AF_NETLINK, SOCK_DGRAM, NETLINK_ROUTE);
     if(nl_sock < 0) {
          perror("socket():");
          return -1;
     }

     memset(&req, 0, sizeof req);
     req.nh.nlmsg_len   = NLMSG_LENGTH(sizeof(struct ifinfomsg));
     req.nh.nlmsg_flags = NLM_F_REQUEST;
     req.nh.nlmsg_type  = RTM_NEWLINK; // RTM_SETLINK
     req.ifinfo.ifi_family = AF_UNSPEC;
     req.ifinfo.ifi_index  = if_nametoindex(IFACE_NAME);
     if(!req.ifinfo.ifi_index) {
          perror("if_nametoindex():");
          return -1;
     }
     printf("%s index: %d\n", IFACE_NAME, req.ifinfo.ifi_index);
     req.ifinfo.ifi_change = 0xffffffff;
     rta = (struct rtattr *)(((char *) &req) + NLMSG_ALIGN(req.nh.nlmsg_len));
     rta->rta_type = IFLA_MTU;
     rta->rta_len = RTA_LENGTH(sizeof(unsigned int));
     req.nh.nlmsg_len = NLMSG_ALIGN(req.nh.nlmsg_len) + RTA_LENGTH(sizeof mtu);
     memcpy(RTA_DATA(rta), &mtu, sizeof mtu);

     ret = send(nl_sock, &req, req.nh.nlmsg_len, 0);
     if(ret < 0) {
          perror("send():");
          return -1;
     }

     return 0;
}

Lesen Sie auch: rtnetlink(3), rtnetlink(7)

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top