Remove the olsr-specific duplicated types
[olsrd.git] / src / lq_packet.h
1 /*
2  * The olsr.org Optimized Link-State Routing daemon(olsrd)
3  * Copyright (c) 2004, Thomas Lopatic (thomas@lopatic.de)
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  *
10  * * Redistributions of source code must retain the above copyright 
11  *   notice, this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above copyright 
13  *   notice, this list of conditions and the following disclaimer in 
14  *   the documentation and/or other materials provided with the 
15  *   distribution.
16  * * Neither the name of olsr.org, olsrd nor the names of its 
17  *   contributors may be used to endorse or promote products derived 
18  *   from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 
23  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 
24  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 
25  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
26  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 
27  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 
28  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 
30  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
31  * POSSIBILITY OF SUCH DAMAGE.
32  *
33  * Visit http://www.olsr.org for more information.
34  *
35  * If you find this software useful feel free to make a donation
36  * to the project. For more information see the website or contact
37  * the copyright holders.
38  *
39  */
40
41 #ifndef _OLSR_LQ_PACKET_H
42 #define _OLSR_LQ_PACKET_H
43
44 #include "olsr_types.h"
45 #include "packet.h"
46 #include "mantissa.h"
47 #include "ipcalc.h"
48
49 #define LQ_HELLO_MESSAGE      201
50 #define LQ_TC_MESSAGE         202
51
52 /* deserialized OLSR header */
53
54 struct olsr_common {
55   uint8_t          type;
56   uint16_t         size;
57   olsr_reltime       vtime;
58   union olsr_ip_addr orig;
59   uint8_t          ttl;
60   uint8_t          hops;
61   uint16_t         seqno;
62 };
63
64 /* serialized IPv4 OLSR header */
65
66 struct olsr_header_v4 {
67   uint8_t  type;
68   uint8_t  vtime;
69   uint16_t size;
70   uint32_t orig;
71   uint8_t  ttl;
72   uint8_t  hops;
73   uint16_t seqno;
74 };
75
76 /* serialized IPv6 OLSR header */
77
78 struct olsr_header_v6 {
79   uint8_t     type;
80   uint8_t     vtime;
81   uint16_t    size;
82   unsigned char orig[16];
83   uint8_t     ttl;
84   uint8_t     hops;
85   uint16_t    seqno;
86 };
87
88 /* deserialized LQ_HELLO */
89
90 struct lq_hello_neighbor {
91   uint8_t                link_type;
92   uint8_t                neigh_type;
93   union olsr_ip_addr       addr;
94   struct lq_hello_neighbor *next;
95   uint32_t               linkquality[0];
96 };
97
98 struct lq_hello_message {
99   struct olsr_common       comm;
100   olsr_reltime             htime;
101   uint8_t                will;
102   struct lq_hello_neighbor *neigh;
103 };
104
105 /* serialized LQ_HELLO */
106
107 struct lq_hello_info_header {
108   uint8_t  link_code;
109   uint8_t  reserved;
110   uint16_t size;
111 };
112
113 struct lq_hello_header {
114   uint16_t reserved;
115   uint8_t  htime;
116   uint8_t  will;
117 };
118
119 /* deserialized LQ_TC */
120 struct lq_tc_message {
121   struct olsr_common    comm;
122   union olsr_ip_addr    from;
123   uint16_t            ansn;
124   struct tc_mpr_addr    *neigh;
125 };
126
127 /* serialized LQ_TC */
128
129 struct lq_tc_header {
130   uint16_t ansn;
131   uint8_t lower_border;
132   uint8_t upper_border;
133 };
134
135 static INLINE void        pkt_get_u8(const uint8_t **p, uint8_t  *var)         { *var =       *(const uint8_t *)(*p);          *p += sizeof(uint8_t); }
136 static INLINE void       pkt_get_u16(const uint8_t **p, uint16_t *var)         { *var = ntohs(*(const uint16_t *)(*p));        *p += sizeof(uint16_t); }
137 static INLINE void       pkt_get_u32(const uint8_t **p, uint32_t *var)         { *var = ntohl(*(const uint32_t *)(p));         *p += sizeof(uint32_t); }
138 static INLINE void        pkt_get_s8(const uint8_t **p, int8_t  *var)          { *var =       *(const int8_t *)(*p);           *p += sizeof(int8_t); }
139 static INLINE void       pkt_get_s16(const uint8_t **p, int16_t *var)          { *var = ntohs(*(const int16_t *)(*p));         *p += sizeof(int16_t); }
140 static INLINE void       pkt_get_s32(const uint8_t **p, int32_t *var)          { *var = ntohl(*(const int32_t *)(*p));         *p += sizeof(int32_t); }
141 static INLINE void   pkt_get_reltime(const uint8_t **p, olsr_reltime *var)       { *var = me_to_reltime(**p);                       *p += sizeof(uint8_t); }
142 static INLINE void pkt_get_ipaddress(const uint8_t **p, union olsr_ip_addr *var) { memcpy(var, *p, olsr_cnf->ipsize);              *p += olsr_cnf->ipsize; }
143 static INLINE void pkt_get_prefixlen(const uint8_t **p, uint8_t *var)          { *var = netmask_to_prefix(*p, olsr_cnf->ipsize); *p += olsr_cnf->ipsize; }
144
145 static INLINE void        pkt_ignore_u8(const uint8_t **p) { *p += sizeof(uint8_t); }
146 static INLINE void       pkt_ignore_u16(const uint8_t **p) { *p += sizeof(uint16_t); }
147 static INLINE void       pkt_ignore_u32(const uint8_t **p) { *p += sizeof(uint32_t); }
148 static INLINE void        pkt_ignore_s8(const uint8_t **p) { *p += sizeof(int8_t); }
149 static INLINE void       pkt_ignore_s16(const uint8_t **p) { *p += sizeof(int16_t); }
150 static INLINE void       pkt_ignore_s32(const uint8_t **p) { *p += sizeof(int32_t); }
151 static INLINE void pkt_ignore_ipaddress(const uint8_t **p) { *p += olsr_cnf->ipsize; }
152 static INLINE void pkt_ignore_prefixlen(const uint8_t **p) { *p += olsr_cnf->ipsize; }
153
154 static INLINE void        pkt_put_u8(uint8_t **p, uint8_t  var)                { *(uint8_t *)(*p)  = var;          *p += sizeof(uint8_t); }
155 static INLINE void       pkt_put_u16(uint8_t **p, uint16_t var)                { *(uint16_t *)(*p) = htons(var);   *p += sizeof(uint16_t); }
156 static INLINE void       pkt_put_u32(uint8_t **p, uint32_t var)                { *(uint32_t *)(*p) = htonl(var);   *p += sizeof(uint32_t); }
157 static INLINE void        pkt_put_s8(uint8_t **p, int8_t  var)                 { *(int8_t *)(*p)   = var;          *p += sizeof(int8_t); }
158 static INLINE void       pkt_put_s16(uint8_t **p, int16_t var)                 { *(int16_t *)(*p)  = htons(var);   *p += sizeof(int16_t); }
159 static INLINE void       pkt_put_s32(uint8_t **p, int32_t var)                 { *(int32_t *)(*p)  = htonl(var);   *p += sizeof(int32_t); }
160 static INLINE void   pkt_put_reltime(uint8_t **p, olsr_reltime var)              { **p = reltime_to_me(var);           *p += sizeof(uint8_t); }
161 static INLINE void pkt_put_ipaddress(uint8_t **p, const union olsr_ip_addr *var) { memcpy(*p, var, olsr_cnf->ipsize); *p += olsr_cnf->ipsize; }
162 static INLINE void pkt_put_prefixlen(uint8_t **p, uint8_t var)                 { prefix_to_netmask(*p, olsr_cnf->ipsize, var); *p += olsr_cnf->ipsize; }
163
164 void olsr_output_lq_hello(void *para);
165
166 void olsr_output_lq_tc(void *para);
167
168 extern bool lq_tc_pending;
169
170 #endif
171
172 /*
173  * Local Variables:
174  * c-basic-offset: 2
175  * indent-tabs-mode: nil
176  * End:
177  */