Ignore:
Timestamp:
Sep 21, 2010, 3:57:26 PM (14 years ago)
Author:
Christoph Mayer
Message:
 
File:
1 edited

Legend:

Unmodified
Added
Removed
  • source/ariba/communication/networkinfo/NetworkChangeDetection.cpp

    r6930 r8569  
    196196                        }
    197197
     198                        // somehow all notifications with pid=0 are
     199                        // invalid and occur much too often
     200                        if(header->nlmsg_pid == 0) continue;
     201
    198202                        //
    199203                        // here we evaluate the routing netlink message. for, the following
    200204                        // messages are of interest:
    201                         //      RTM_NEWLINK, RTM_DELLINK -> interface up/down
    202205                        //      RTM_NEWADDR, RTM_DELADDR -> new address on iface, address deleted from iface
    203                         // not interesting are:
    204                         //      RTM_GETLINK, RTM_GETADDR
    205                         //      RTM_NEWROUTE, RTM_DELROUTE, RTM_GETROUTE
    206206                        //
    207207
     
    209209
    210210                        switch( header->nlmsg_type ){
    211 
    212                                 //
    213                                 // handle network interface up/down notifications
    214                                 // --> link layer notifications
    215                                 //
    216 
    217                                 case RTM_NEWLINK:
    218                                 case RTM_DELLINK:
    219 
    220                                         changeInfo = obj->extractInterfaceEvent( header );
    221                                         break;
    222211
    223212                                //
     
    257246}
    258247
    259 NetworkChangeInterface::NetworkChangeInfo NetworkChangeDetection::extractInterfaceEvent(struct nlmsghdr* header){
    260         NetworkChangeInterface::NetworkChangeInfo changeInfo;
    261 
    262         //
    263         // handle network interface up/down notifications
    264         // the differentiation between up/down is _not_
    265         // made using new/del-link in the message!
    266         //
    267 
    268         if( header->nlmsg_type == RTM_NEWLINK ){
    269                 logging_debug("network change message RTM_NEWLINK");
    270         }else if( header->nlmsg_type == RTM_DELLINK ){
    271                 logging_debug("network change message RTM_DELLINK");
    272         }
    273 
    274         if( header->nlmsg_len < NLMSG_LENGTH(sizeof(struct ifinfomsg)) ){
    275                 logging_error( "netlink packet soo small for ifinfomsg" );
    276                 return changeInfo;
    277         }
    278 
    279         //
    280         // get the interface index and through this
    281         // further information about the interface
    282         //
    283 
    284         struct ifinfomsg* detailIface = (struct ifinfomsg*)NLMSG_DATA(header);
    285         changeInfo.interface = networkInformation.getInterface( detailIface->ifi_index );
    286 
    287         //
    288         // check whether device is now up or down
    289         //
    290 
    291         if( changeInfo.interface.isUp && changeInfo.interface.isRunning )
    292                 changeInfo.type = NetworkChangeInterface::EventTypeInterfaceUp;
    293         else
    294                 changeInfo.type = NetworkChangeInterface::EventTypeInterfaceDown;
    295 
    296 
    297         return changeInfo;
    298 }
    299 
    300248NetworkChangeInterface::NetworkChangeInfo NetworkChangeDetection::extractAddressEvent(struct nlmsghdr* header){
    301249        NetworkChangeInterface::NetworkChangeInfo changeInfo;
     
    308256        if( header->nlmsg_type == RTM_NEWADDR ){
    309257                logging_debug("network change message RTM_NEWADDR");
    310                 changeInfo.type = NetworkChangeInterface::EventTypeAddressNew;
     258                changeInfo.type = NetworkChangeInterface::EventTypeInterfaceUp;
    311259        }else if( header->nlmsg_type == RTM_DELADDR ){
    312260                logging_debug("network change message RTM_DELADDR");
    313                 changeInfo.type = NetworkChangeInterface::EventTypeAddressDelete;
     261                changeInfo.type = NetworkChangeInterface::EventTypeInterfaceDown;
    314262        }
    315263
Note: See TracChangeset for help on using the changeset viewer.