Contiki 2.5
multihop.h
Go to the documentation of this file.
1 /**
2  * \addtogroup rime
3  * @{
4  */
5 
6 /**
7  * \defgroup rimemultihop Best-effort multihop forwarding
8  * @{
9  *
10  * The multihop module implements a multihop forwarding mechanism. Routes
11  * must have already been setup with the route_add() function. Setting
12  * up routes is done with another Rime module such as the \ref
13  * routediscovery "route-discovery module".
14  *
15  * The multihop sends a packet to an identified node in the network by
16  * using multi-hop forwarding at each node in the network. The
17  * application or protocol that uses the multihop primitive supplies a
18  * routing function for selecting the next-hop neighbor. If the
19  * multihop primitive is requested to send a packet for which no
20  * suitable next hop neighbor is found, the caller is immediately
21  * notified of this and may choose to initiate a route discovery
22  * process.
23  *
24  *
25  * \section channels Channels
26  *
27  * The multihop module uses 1 channel.
28  *
29  */
30 
31 /*
32  * Copyright (c) 2006, Swedish Institute of Computer Science.
33  * All rights reserved.
34  *
35  * Redistribution and use in source and binary forms, with or without
36  * modification, are permitted provided that the following conditions
37  * are met:
38  * 1. Redistributions of source code must retain the above copyright
39  * notice, this list of conditions and the following disclaimer.
40  * 2. Redistributions in binary form must reproduce the above copyright
41  * notice, this list of conditions and the following disclaimer in the
42  * documentation and/or other materials provided with the distribution.
43  * 3. Neither the name of the Institute nor the names of its contributors
44  * may be used to endorse or promote products derived from this software
45  * without specific prior written permission.
46  *
47  * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
48  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
49  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
50  * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
51  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
52  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
53  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
54  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
55  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
56  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
57  * SUCH DAMAGE.
58  *
59  * This file is part of the Contiki operating system.
60  *
61  * $Id: multihop.h,v 1.6 2009/03/24 07:15:04 adamdunkels Exp $
62  */
63 
64 /**
65  * \file
66  * Multihop forwarding header file
67  * \author
68  * Adam Dunkels <adam@sics.se>
69  */
70 
71 #ifndef __MULTIHOP_H__
72 #define __MULTIHOP_H__
73 
74 #include "net/rime/unicast.h"
75 #include "net/rime/rimeaddr.h"
76 
77 struct multihop_conn;
78 
79 #define MULTIHOP_ATTRIBUTES { PACKETBUF_ADDR_ESENDER, PACKETBUF_ADDRSIZE }, \
80  { PACKETBUF_ADDR_ERECEIVER, PACKETBUF_ADDRSIZE }, \
81  { PACKETBUF_ATTR_HOPS, PACKETBUF_ATTR_BIT * 5 }, \
82  UNICAST_ATTRIBUTES
83 
84 
85 
86 struct multihop_callbacks {
87  void (* recv)(struct multihop_conn *ptr,
88  const rimeaddr_t *sender,
89  const rimeaddr_t *prevhop,
90  uint8_t hops);
91  rimeaddr_t *(* forward)(struct multihop_conn *ptr,
92  const rimeaddr_t *originator,
93  const rimeaddr_t *dest,
94  const rimeaddr_t *prevhop,
95  uint8_t hops);
96 };
97 
98 struct multihop_conn {
99  struct unicast_conn c;
100  const struct multihop_callbacks *cb;
101 };
102 
103 void multihop_open(struct multihop_conn *c, uint16_t channel,
104  const struct multihop_callbacks *u);
105 void multihop_close(struct multihop_conn *c);
106 int multihop_send(struct multihop_conn *c, const rimeaddr_t *to);
107 void multihop_resend(struct multihop_conn *c, const rimeaddr_t *nexthop);
108 
109 #endif /* __MULTIHOP_H__ */
110 /** @} */
111 /** @} */