tora_api.cc
上传用户:rrhhcc
上传日期:2015-12-11
资源大小:54129k
文件大小:4k
源码类别:

通讯编程

开发平台:

Visual C++

  1. /* -*-  Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- */
  2. /*
  3.  * Copyright (c) 1997 Regents of the University of California.
  4.  * All rights reserved.
  5.  *
  6.  * Redistribution and use in source and binary forms, with or without
  7.  * modification, are permitted provided that the following conditions
  8.  * are met:
  9.  * 1. Redistributions of source code must retain the above copyright
  10.  *    notice, this list of conditions and the following disclaimer.
  11.  * 2. Redistributions in binary form must reproduce the above copyright
  12.  *    notice, this list of conditions and the following disclaimer in the
  13.  *    documentation and/or other materials provided with the distribution.
  14.  * 3. All advertising materials mentioning features or use of this software
  15.  *    must display the following acknowledgement:
  16.  *      This product includes software developed by the Computer Systems
  17.  *      Engineering Group at Lawrence Berkeley Laboratory.
  18.  * 4. Neither the name of the University nor of the Laboratory may be used
  19.  *    to endorse or promote products derived from this software without
  20.  *    specific prior written permission.
  21.  *
  22.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  23.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  24.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  25.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  26.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  27.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  28.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  29.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  30.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  31.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  32.  * SUCH DAMAGE.
  33.  */
  34. /* Ported from CMU/Monarch's code*/
  35. /* 
  36.    tora_api.cc
  37.    $Id: tora_api.cc,v 1.3 1999/09/09 04:02:52 salehi Exp $
  38.    
  39.    Implement the API used by IMEP
  40.    */
  41. #include <tora/tora.h>
  42. #define CURRENT_TIME Scheduler::instance().clock()
  43. void
  44. toraAgent::rtNotifyLinkUP(nsaddr_t index)
  45. {
  46. TORADest *td = dstlist.lh_first;
  47.         /*
  48.          * Update the destination lists...
  49.          */
  50. for( ; td; td = td->link.le_next) {
  51. if(td->nb_find(index) == 0) {
  52.                         (void) td->nb_add(index);
  53. }
  54. if (td->rt_req) 
  55.   { // must send a new query for this dest so the new
  56.     // neighbor can hear it
  57.     // IMEP will take care of aggregating all these into
  58.     // one physical pkt
  59.     trace("T %.9f _%d_ QRY %d for %d (rtreq set)",
  60.   Scheduler::instance().clock(), ipaddr(), 
  61.   td->index, index);
  62.     sendQRY(td->index);
  63.     td->time_tx_qry = CURRENT_TIME;
  64. }
  65. }
  66. }
  67. void
  68. toraAgent::rtNotifyLinkDN(nsaddr_t index)
  69. {
  70. TORADest *td = dstlist.lh_first;
  71.         /*
  72.          *  Purge each Destination's Neighbor List
  73.          */
  74.         for( ; td; td = td->link.le_next) {
  75.                 if(td->nb_del(index)) {
  76.                         /*
  77.                          * Send an UPD packet if you've lost the last
  78.                          * downstream link.
  79.                          */
  80.                         sendUPD(td->index);
  81.                 }
  82.         }
  83. /*
  84.  *  Now purge the Network Interface queues that
  85.  *  may have packets destined for this broken
  86.  *  neighbor.
  87.  */
  88.         {
  89.                 Packet *head = 0;
  90.                 Packet *p;
  91.                 Packet *np = 0;
  92.                 while((p = ifqueue->filter(index))) {
  93.                         p->next_ = head;
  94.                         head = p;
  95.                 }
  96.                 for(p = head; p; p = np) {
  97.                         np = p->next_;
  98.                         /*
  99.                          * This make a lot of sense for TORA since we
  100.                          * will almost always have multiple routes to
  101.                          * a destination.
  102.                          */
  103.                         log_link_layer_recycle(p);
  104.                         rt_resolve(p);
  105.                 }
  106.         }
  107. }
  108. void
  109. toraAgent::rtNotifyLinkStatus(nsaddr_t /* index */, u_int32_t /* status */)
  110. {
  111. abort();
  112. }
  113. void
  114. toraAgent::rtRoutePacket(Packet *p)
  115. {
  116. struct hdr_cmn *ch = HDR_CMN(p);
  117. struct hdr_ip *ip = HDR_IP(p);
  118. // Non-data packets and BROADCAST packets can be dropped.
  119. if(DATA_PACKET(ch->ptype()) == 0 || 
  120.    ip->daddr() == (nsaddr_t) IP_BROADCAST) {
  121. drop(p, DROP_RTR_MAC_CALLBACK);
  122. return;
  123. }
  124. rt_resolve(p);
  125. }