Contiki 2.5
Main Page
Related Pages
Modules
Data Structures
Files
Examples
File List
Globals
core
net
rime
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
/** @} */
Generated on Fri Aug 30 2013 12:34:06 for Contiki 2.5 by
1.8.3.1