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

通讯编程

开发平台:

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. #ifndef __tora_dest_h__
  36. #define __tora_dest_h__
  37. class TORANeighbor;
  38. class toraAgent;
  39. LIST_HEAD(tn_head, TORANeighbor);
  40. class TORADest {
  41. friend class toraAgent;
  42. public:
  43. TORADest(nsaddr_t id, Agent *a);
  44. TORANeighbor* nb_add(nsaddr_t id);
  45. int nb_del(nsaddr_t id);
  46. TORANeighbor* nb_find(nsaddr_t id);
  47. void update_height_nb(TORANeighbor* tn,
  48.  struct hdr_tora_upd *uh);
  49. void update_height(double TAU, nsaddr_t OID,
  50. int R, int DELTA, nsaddr_t ID);
  51. int nb_check_same_ref(void);
  52. /*
  53.  *  Finds the minimum height neighbor whose lnk_stat is DN.
  54.  */
  55. TORANeighbor* nb_find_next_hop();
  56. TORANeighbor* nb_find_height(int R);
  57. TORANeighbor* nb_find_max_height(void);
  58. TORANeighbor* nb_find_min_height(int R);
  59. TORANeighbor* nb_find_min_nonnull_height(Height *h);
  60. void dump(void);
  61. private:
  62. LIST_ENTRY(TORADest) link;
  63. nsaddr_t index; // IP address of destination
  64. Height height; // 5-tuple height of this node
  65. int rt_req; // route required flag
  66. double time_upd; // time last UPD packet was sent
  67. double time_tx_qry; // time sent last QUERY
  68. double time_rt_req; // time rt_req last set - JGB 
  69. tn_head nblist; // List of neighbors.
  70. int num_active; // # active links
  71. int num_down; // # down stream links
  72. int num_up; // # up stream links
  73.         toraAgent     *agent;
  74. };
  75. #endif // __tora_dest_h__