X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FNetdeviceController.cc;h=b514904ba5378ac49c8b624153a278839812eddd;hb=81f84badf27b66dbadec9890646ca1193e998505;hp=7ce1f953bff4aa0a0582d09098f753442d64fadf;hpb=560113811e6d51fffb4ca004e7342ec362234cd2;p=senf.git diff --git a/Socket/NetdeviceController.cc b/Socket/NetdeviceController.cc index 7ce1f95..b514904 100644 --- a/Socket/NetdeviceController.cc +++ b/Socket/NetdeviceController.cc @@ -115,6 +115,54 @@ prefix_ void senf::NetdeviceController::mtu(int new_mtu) doIoctl( ifr, SIOCSIFMTU); } +prefix_ bool senf::NetdeviceController::promisc() + const +{ + struct ifreq ifr; + ifrName( ifr); + doIoctl( ifr, SIOCGIFFLAGS); + return ifr.ifr_flags & IFF_PROMISC; +} + +prefix_ void senf::NetdeviceController::promisc(bool mode) +{ + struct ifreq ifr; + ifrName( ifr); + doIoctl( ifr, SIOCGIFFLAGS); + if (mode) + ifr.ifr_flags |= IFF_PROMISC; + else + ifr.ifr_flags &= ~IFF_PROMISC; + doIoctl( ifr, SIOCSIFFLAGS); +} + +prefix_ bool senf::NetdeviceController::isUp() + const +{ + struct ifreq ifr; + ifrName(ifr); + doIoctl(ifr, SIOCGIFFLAGS); + return ifr.ifr_flags & IFF_UP; +} + +prefix_ void senf::NetdeviceController::up() +{ + struct ifreq ifr; + ifrName(ifr); + doIoctl(ifr, SIOCGIFFLAGS); + ifr.ifr_flags |= IFF_UP; + doIoctl(ifr, SIOCSIFFLAGS); +} + +prefix_ void senf::NetdeviceController::down() +{ + struct ifreq ifr; + ifrName(ifr); + doIoctl(ifr, SIOCGIFFLAGS); + ifr.ifr_flags &= ~IFF_UP; + doIoctl(ifr, SIOCSIFFLAGS); +} + prefix_ int senf::NetdeviceController::interfaceIndex() const {