X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FNetdeviceController.cc;h=fc43cc1ddfdd770c4f98b8dc589e5a81ee08a666;hb=63f4ccfd1186c135b54d3f8d8679c18118dda946;hp=5f6ab52f28f4065ebbf7ed845f5817ba9fb4d092;hpb=a1a6c76a214ad1935032826713cabaf9ac57bf07;p=senf.git diff --git a/Socket/NetdeviceController.cc b/Socket/NetdeviceController.cc index 5f6ab52..fc43cc1 100644 --- a/Socket/NetdeviceController.cc +++ b/Socket/NetdeviceController.cc @@ -52,6 +52,7 @@ prefix_ senf::NetdeviceController::NetdeviceController(int interface_index) } prefix_ std::string senf::NetdeviceController::interfaceName() + const { struct ifreq ifr; ifrName( ifr); @@ -59,6 +60,7 @@ prefix_ std::string senf::NetdeviceController::interfaceName() } prefix_ senf::MACAddress senf::NetdeviceController::hardwareAddress() + const { struct ifreq ifr; ifrName( ifr); @@ -67,6 +69,7 @@ prefix_ senf::MACAddress senf::NetdeviceController::hardwareAddress() } 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( "Could not open socket for NetdeviceController"); } 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( + "NetdeviceController: Could not discover the name of the interface with index ") << ifindex_; } - prefix_ void senf::NetdeviceController::doIoctl(ifreq& ifr, int request) + const { if ( ::ioctl( sockfd_, request, &ifr ) < 0 ) - throwErrno(); + throw SystemException(); } ///////////////////////////////cc.e////////////////////////////////////////