X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FNetdeviceController.cc;h=b93998c044ff21daa3bee505d468bfe45d95be0c;hb=6e4cfeb813b1da364395b2da6e3762e0abd2ac70;hp=d3cf57ad48339f9d4bafbbe049e48b7aa96e22e7;hpb=5473ff920615fdd6d0a45b97baefc9eafe619e8b;p=senf.git diff --git a/Socket/NetdeviceController.cc b/Socket/NetdeviceController.cc index d3cf57a..b93998c 100644 --- a/Socket/NetdeviceController.cc +++ b/Socket/NetdeviceController.cc @@ -1,9 +1,9 @@ // $Id$ // // Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) -// Thorsten Horstmann +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY +// Thorsten Horstmann // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by @@ -30,7 +30,6 @@ // Custom includes #include #include -#include #include "../Utils/Exception.hh" #define prefix_ @@ -53,6 +52,7 @@ prefix_ senf::NetdeviceController::NetdeviceController(int interface_index) } prefix_ std::string senf::NetdeviceController::interfaceName() + const { struct ifreq ifr; ifrName( ifr); @@ -60,13 +60,16 @@ prefix_ std::string senf::NetdeviceController::interfaceName() } prefix_ senf::MACAddress senf::NetdeviceController::hardwareAddress() + const { struct ifreq ifr; + ifrName( ifr); doIoctl( ifr, SIOCGIFHWADDR); return senf::MACAddress::from_data( ifr.ifr_hwaddr.sa_data); } prefix_ int senf::NetdeviceController::mtu() + const { struct ifreq ifr; ifrName( ifr); @@ -75,6 +78,7 @@ prefix_ int senf::NetdeviceController::mtu() } prefix_ void senf::NetdeviceController::mtu(int new_mtu) + const { struct ifreq ifr; ifrName( ifr); @@ -83,6 +87,7 @@ prefix_ void senf::NetdeviceController::mtu(int new_mtu) } prefix_ int senf::NetdeviceController::interfaceIndex() + const { return ifindex_; } @@ -96,22 +101,24 @@ prefix_ void senf::NetdeviceController::openSocket() { sockfd_ = ::socket( PF_INET, SOCK_DGRAM, 0); if ( sockfd_ < 0) - throwErrno(); + throw SystemException(); } prefix_ void senf::NetdeviceController::ifrName(ifreq& ifr) + const { ::memset( &ifr, 0, sizeof(ifr)); ifr.ifr_ifindex = ifindex_; if ( ::ioctl( sockfd_, SIOCGIFNAME, &ifr ) < 0 ) - throwErrno(); + throw SystemException(); } prefix_ void senf::NetdeviceController::doIoctl(ifreq& ifr, int request) + const { if ( ::ioctl( sockfd_, request, &ifr ) < 0 ) - throwErrno(); + throw SystemException(); } ///////////////////////////////cc.e////////////////////////////////////////