-
Notifications
You must be signed in to change notification settings - Fork 25
/
msg.h
767 lines (545 loc) · 24.6 KB
/
msg.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
/*
* Copyright (c) 2010 Axel Neumann
* This program is free software; you can redistribute it and/or
* modify it under the terms of version 2 of the GNU General Public
* License as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301, USA
*/
#include <stdint.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <linux/if.h>
#define MIN_UDPD_SIZE 128 //(6+4+(22+8)+32)+184=72+56=128
#define DEF_UDPD_SIZE 512 //512
#define MAX_UDPD_SIZE (XMIN( 1400, MAX_PACKET_SIZE))
#define ARG_UDPD_SIZE "udpDataSize"
#define DEF_TX_TS_TREE_SIZE 150
#define DEF_TX_TS_TREE_PURGE_FK 3
#define DEF_DESC0_CACHE_SIZE 100
#define DEF_DESC0_CACHE_TO 100000
#define MIN_DEV_ADVS_TX_ITERS 1
#define MAX_DEV_ADVS_TX_ITERS 100
#define DEF_DEV_ADVS_TX_ITERS 1
#define ARG_DEV_ADVS_TX_ITERS "devAdvSends"
#define MIN_DEV_ADVS_UNSOLICITED 0
#define MAX_DEV_ADVS_UNSOLICITED 1
#define DEF_DEV_ADV_UNSOLICITED 3
#define ARG_DEV_ADVS_UNSOLICITED "devUnsolicitedSends"
#define MIN_DEV_REQS_TX_ITERS 1
#define MAX_DEV_REQS_TX_ITERS 100
#define DEF_DEV_REQS_TX_ITERS 4
#define ARG_DEV_REQS_TX_ITERS "devReqSends"
#define MIN_LINK_ADVS_TX_ITERS 1
#define MAX_LINK_ADVS_TX_ITERS 100
#define DEF_LINK_ADVS_TX_ITERS 1
#define ARG_LINK_ADVS_TX_ITERS "linkAdvSends"
#define MIN_LINK_ADVS_UNSOLICITED 0
#define MAX_LINK_ADVS_UNSOLICITED 1
#define DEF_LINK_ADV_UNSOLICITED 1
#define ARG_LINK_ADVS_UNSOLICITED "linkUnsolicitedSends"
#define MIN_LINK_REQS_TX_ITERS 1
#define MAX_LINK_REQS_TX_ITERS 100
#define DEF_LINK_REQS_TX_ITERS 4
#define ARG_LINK_REQS_TX_ITERS "linkReqSends"
#define MIN_DSC0_ADVS_TX_ITERS 1
#define MAX_DSC0_ADVS_TX_ITERS 20
#define DEF_DESC_ADV_TX_ITERS 1
#define ARG_DSC0_ADVS_TX_ITERS "descAdvSends"
#define MIN_UNSOLICITED_DESC_ADVS 0
#define MAX_UNSOLICITED_DESC_ADVS 1
#define DEF_DESC_ADV_UNSOLICITED 1
#define ARG_UNSOLICITED_DESC_ADVS "descUnsolicitedSends"
#define MIN_DSC0_REQS_TX_ITERS 1
#define MAX_DSC0_REQS_TX_ITERS 100
#define DEF_DESC_REQ_TX_ITERS 10 //TODO: will blow lndev->tx_task_list[] if new local_ids appeare just for a moment
#define ARG_DSC0_REQS_TX_ITERS "descReqSends"
#define MIN_DHS0_ADVS_TX_ITERS 1
#define MAX_DHS0_ADVS_TX_ITERS 100
#define DEF_DHASH_ADV_TX_ITERS 1
#define ARG_DHS0_ADVS_TX_ITERS "descShaAdvSends"
#define MIN_DHS0_REQS_TX_ITERS 1
#define MAX_DHS0_REQS_TX_ITERS 100
#define DEF_DHASH_REQ_TX_ITERS 10 //TODO: will blow lndev->tx_task_list[] if new local_ids appeare just for a moment
#define ARG_DHS0_REQS_TX_ITERS "descShaReqSends"
#define _DEF_OGM_SQN_DIV 5
#define _MIN_OGM_SQN_RANGE 32
#define _MAX_OGM_SQN_RANGE 8192 // changing this will cause compatibility trouble
#define MIN_OGM_SQN_RANGE _MIN_OGM_SQN_RANGE + (_MIN_OGM_SQN_RANGE/(2*_DEF_OGM_SQN_DIV))
#define MAX_OGM_SQN_RANGE _MAX_OGM_SQN_RANGE - (_MAX_OGM_SQN_RANGE/(2*_DEF_OGM_SQN_DIV))
#define DEF_OGM_SQN_RANGE MAX_OGM_SQN_RANGE
#define ARG_OGM_SQN_RANGE "ogmSqnRange"
#define MIN_OGM_TX_ITERS 0
#define MAX_OGM_TX_ITERS 30
#define DEF_OGM_TX_ITERS 10
#define ARG_OGM_TX_ITERS "ogmAdvSends"
#define DEF_OGM_ACK_TX_ITERS 1
#define MIN_OGM_ACK_TX_ITERS 0
#define MAX_OGM_ACK_TX_ITERS 4
#define ARG_OGM_ACK_TX_ITERS "ogmAckSends"
#define CONTENT_MIN_TX_INTERVAL_MIN 0
#define CONTENT_MIN_TX_INTERVAL__CHECK_FOR_REDUNDANCY 1
#define CONTENT_MIN_TX_INTERVAL_MAX 50000
//TODO: set REQ_TO to 1 (in a non-packet-loss testenvironment this may be set to 1000 for testing)
#define DEF_TX_DESC0_REQ_TO ((DEF_TX_INTERVAL*3)/2)
#define DEF_TX_DESC0_ADV_TO 200
#define DEF_TX_DHASH0_REQ_TO ((DEF_TX_INTERVAL*3)/2)
#define DEF_TX_DHASH0_ADV_TO 200
#define MIN_DESC0_REFERRED_TO 10000
#define MAX_DESC0_REFERRED_TO 100000
#define DEF_DESC0_REFERRED_TO 10000
#define DEF_DESC0_REQ_STONE_OLD_TO 40000
#define MAX_PKT_MSG_SIZE (MAX_UDPD_SIZE - sizeof(struct packet_header) - sizeof(struct frame_header_long))
#define MAX_DESC0_TLV_SIZE (MAX_PKT_MSG_SIZE - sizeof(struct msg_description_adv) )
#define FRAME_TYPE_RSVD0 0
#define FRAME_TYPE_PROBLEM_ADV 2 // yet only used to indicate dev_id collisions
#define FRAME_TYPE_TEST_ADV 3 // just for testing zero-message rx/tx_frame_iterator()
#define FRAME_TYPE_HELLO_ADV 4 // most-simple BMX-NG hello (nb-discovery) advertisements
#define FRAME_TYPE_DEV_REQ 6
#define FRAME_TYPE_DEV_ADV 7
#define FRAME_TYPE_LINK_REQ_ADV 8
#define FRAME_TYPE_LINK_ADV 9
#define FRAME_TYPE_RP_ADV 11
#define FRAME_TYPE_DESC_REQ 14
#define FRAME_TYPE_DESC_ADV 15
#define FRAME_TYPE_HASH_REQ 18 // Hash-for-description-of-OG-ID requests
#define FRAME_TYPE_HASH_ADV 19 // Hash-for-description-of-OG-ID advertisements
//#define FRAME_TYPE_HELLO_REPS 21 // most-simple BMX-NG hello (nb-discovery) replies
#define FRAME_TYPE_OGM_ADV 22 // most simple BMX-NG (type 0) OGM advertisements
#define FRAME_TYPE_OGM_ACK 23 // most simple BMX-NG (type 0) OGM advertisements
#define FRAME_TYPE_NOP 24
#define FRAME_TYPE_MAX_KNOWN 24
#define FRAME_TYPE_MAX (FRAME_TYPE_ARRSZ-1)
#define FRAME_TYPE_PROCESS_ALL (255)
#define FRAME_TYPE_PROCESS_NONE (254)
#define ARG_DESCRIPTIONS "descriptions"
#define HLP_DESCRIPTIONS "show node descriptions\n"
#define ARG_DESCRIPTION_NAME "name"
#define ARG_DESCRIPTION_TYPE "type"
#define DEF_DESCRIPTION_TYPE FRAME_TYPE_PROCESS_ALL
#define MIN_DESCRIPTION_TYPE 0
#define MAX_DESCRIPTION_TYPE FRAME_TYPE_PROCESS_ALL
#define HLP_DESCRIPTION_TYPE "show description extension(s) of given type (0..253=type 254=none 255=all) \n"
struct frame_header_short { // 2 bytes
#if __BYTE_ORDER == __LITTLE_ENDIAN
unsigned int type : FRAME_TYPE_BIT_SIZE;
unsigned int is_relevant : FRAME_RELEVANCE_BIT_SIZE;
unsigned int is_short : FRAME_ISSHORT_BIT_SIZE;
#elif __BYTE_ORDER == __BIG_ENDIAN
unsigned int is_short : FRAME_ISSHORT_BIT_SIZE;
unsigned int is_relevant : FRAME_RELEVANCE_BIT_SIZE;
unsigned int type : FRAME_TYPE_BIT_SIZE;
#else
# error "Please fix <bits/endian.h>"
#endif
uint8_t length_TLV_DATA_STEPS; // lenght of frame in TLV_DATA_STEPS Byte steps, including frame_header and variable data field
// uint8_t data[]; // frame-type specific data consisting of 0-1 data headers and 1-n data messages
} __attribute__((packed));
struct frame_header_long { // 4 bytes
#if __BYTE_ORDER == __LITTLE_ENDIAN
unsigned int type : FRAME_TYPE_BIT_SIZE;
unsigned int is_relevant : FRAME_RELEVANCE_BIT_SIZE;
unsigned int is_short : FRAME_ISSHORT_BIT_SIZE;
#elif __BYTE_ORDER == __BIG_ENDIAN
unsigned int is_short : FRAME_ISSHORT_BIT_SIZE;
unsigned int is_relevant : FRAME_RELEVANCE_BIT_SIZE;
unsigned int type : FRAME_TYPE_BIT_SIZE;
#else
# error "Please fix <bits/endian.h>"
#endif
uint8_t reserved;
uint16_t length; // lenght of frame in 1-Byte steps, including frame_header and variable data field
// uint8_t data[]; // frame-type specific data consisting of 0-1 data headers and 1-n data messages
} __attribute__((packed));
#define SHORT_FRAME_DATA_MAX (XMIN( 500, ((int)((((sizeof( ((struct frame_header_short*)NULL)->length_TLV_DATA_STEPS ))<<8)-1)*TLV_DATA_STEPS))))
// iterator return codes:
#define TLV_RX_DATA_BLOCKED (-5) // blocked due to DAD
#define TLV_TX_DATA_FULL (-4) // nothing done! Frame finished or not enough remining data area to write
// only returns from tx-iterations, rx- will return FAILURE
#define TLV_RX_DATA_FAILURE (-3) // syntax error: exit or blacklist
#define TLV_TX_DATA_FAILURE (-3) // syntax error: will fail assertion()
#define TLV_RX_DATA_DONE (-2) // done, nothing more to do
#define TLV_TX_DATA_DONE (-2) // done, nothing more to do
#define TLV_RX_DATA_IGNORED (-1) // unknown, filtered, nothing to send, or ignored due to bad link...
#define TLV_TX_DATA_IGNORED (-1) // unknown, filtered, nothing to send, or ignored due to bad link...
#define TLV_RX_DATA_PROCESSED (0) // >= means succesfully processed returned amount of data
#define TLV_TX_DATA_PROCESSED (0) // >= means succesfully processed returned amount of data
#define TLV_DATA_STEPS (1) // legal data-size steps, never returns
// the smalles legal frame must be:
// - a multiple of two
// - have lenght of frame_header_short plus 2 bytes frame_data
// rx_frame_iterator operation codes:
enum {
TLV_OP_DEL = 0,
TLV_OP_TEST = 1,
// TLV_OP_ADD = 2,
TLV_OP_NEW = 2,
TLV_OP_DEBUG = 3,
TLV_OP_CUSTOM_MIN = 20,
TLV_OP_CUSTOM_MAX = 99,
TLV_OP_PLUGIN_MIN = 100,
TLV_OP_PLUGIN_MAX = 199
};
char *tlv_op_str(uint8_t op);
/*
* this iterator is given the beginning of a frame area (e.g. the end of the packet_header)
* then it iterates over the frames in that area */
struct rx_frame_iterator {
// MUST be initialized:
// remains unchanged:
const char *caller;
struct packet_buff *pb;
struct orig_node *on;
struct ctrl_node *cn;
uint8_t *data;
uint8_t *frames_in;
struct frame_handl *handls;
struct frame_handl *handl;
uint8_t op;
uint8_t process_filter;
uint8_t handl_max;
int32_t frames_length;
// MUST be initialized, updated by rx..iterate(), and consumed by handl[].rx_tlv_handler
int32_t frames_pos;
int8_t frame_type; //init to -1 !!
// set by rx..iterate(), and consumed by handl[].rx_tlv_handler
uint8_t is_short_header;
int32_t frame_data_length;
int32_t frame_msgs_length;
int32_t frame_msgs_fixed;
uint8_t *frame_data;
uint8_t *msg;
// allocated by handl[].rx_tlv_handler and freed by calling function of rx_frame_iterate() (e.g. process_description_tlvs())
// allocated and freed by function calling process_description_tlvs(), eg. process_description(), bmx(), plugins,...
void *custom_data;
};
/*
* this iterator is given a fr_type and a set of handlers,
* then the handlers are supposed to figure out what needs to be done.
* finally the iterator writes ready-to-send frame_header and frame data to *fs_data */
struct tx_frame_iterator {
// MUST be initialized:
// remains unchanged:
const char *caller;
struct list_head *tx_task_list;
struct tx_task_node *ttn;
uint8_t *cache_data_array;
uint8_t *frames_out_ptr;
struct frame_handl *handls;
uint8_t handl_max;
int32_t frames_out_pref;
int32_t frames_out_max;
// updated by fs_caller():
uint8_t frame_type;
// updated by tx..iterate():
int32_t frames_out_pos;
int32_t frames_out_num;
int32_t cache_msgs_size;
//#define tx_iterator_cache_data_space( it ) (((it)->frames_out_max) - ((it)->frames_out_pos + (it)->cache_msg_pos + ((int)(sizeof (struct frame_header_long)))))
//#define tx_iterator_cache_hdr_ptr( it ) ((it)->cache_data_array)
//#define tx_iterator_cache_msg_ptr( it ) ((it)->cache_data_array + (it)->cache_msg_pos)
};
struct frame_handl {
uint8_t is_advertisement; // NO link information required for tx_frame_...(), dev is enough
uint8_t is_destination_specific_frame; // particularly: is NO advertisement AND individual frames are created for each destination
uint8_t is_relevant; // if set to ONE specifies: frame MUST BE processed or in case of unknown frame type, the
// whole super_frame MUST be dropped. If set to ZERO the frame can be ignored.
// if frame->is_relevant==1 and unknown and super_frame->is_relevant==1, then
// the whole super_frame MUST BE dropped as well.
// If irrelevant and unknown frames are rebroadcasted depends on the super_frame logic.
// i.e.: * unknown packet_frames MUST BE dropped.
// * unknown and irrelevant description_tlv_frames MUST BE propagated
uint8_t family;
uint8_t rx_requires_described_neigh;
uint16_t data_header_size;
uint16_t min_msg_size;
uint16_t fixed_msg_size;
uint16_t tx_task_interval_min;
int32_t *tx_iterations;
UMETRIC_T *tx_tp_min;
UMETRIC_T *tx_rp_min;
UMETRIC_T *rx_tp_min;
UMETRIC_T *rx_rp_min;
char *name;
int32_t (*rx_frame_handler) (struct rx_frame_iterator *); // returns: TLV_RX_DATA_code or rcvd frame_msgs_len (without data_header_size)
int32_t (*rx_msg_handler) (struct rx_frame_iterator *); // returns: TLV_RX_DATA_code or rcvd frame_msg_len (without data_header_size)
int32_t (*tx_frame_handler) (struct tx_frame_iterator *); // returns: TLV_TX_DATA_code or send frame_msgs_len (without data_header_size)
int32_t (*tx_msg_handler) (struct tx_frame_iterator *); // returns: TLV_TX_DATA_code or send frame_msg_len (without data_header_size)
const struct field_format *msg_format;
};
static inline uint8_t * tx_iterator_cache_hdr_ptr(struct tx_frame_iterator *it)
{
return it->cache_data_array;
}
static inline uint8_t * tx_iterator_cache_msg_ptr(struct tx_frame_iterator *it)
{
return it->cache_data_array + it->handls[it->frame_type].data_header_size + it->cache_msgs_size;
}
static inline int32_t tx_iterator_cache_data_space_max(struct tx_frame_iterator *it)
{
return it->frames_out_max - (
it->frames_out_pos +
it->handls[it->frame_type].data_header_size +
it->cache_msgs_size +
(int) sizeof(struct frame_header_long));
}
static inline int32_t tx_iterator_cache_data_space_pref(struct tx_frame_iterator *it)
{
return it->frames_out_pref - (
it->frames_out_pos +
it->handls[it->frame_type].data_header_size +
it->cache_msgs_size +
(int) sizeof(struct frame_header_long));
}
static inline int32_t tx_iterator_cache_msg_space_max(struct tx_frame_iterator *it)
{
if (it->handls[it->frame_type].min_msg_size && it->handls[it->frame_type].fixed_msg_size)
return tx_iterator_cache_data_space_max(it) / it->handls[it->frame_type].min_msg_size;
else
return 0;
}
#define FRAME_TYPE_PROBLEM_CODE_MIN 0x01
#define FRAME_TYPE_PROBLEM_CODE_DUP_LINK_ID 0x01
#define FRAME_TYPE_PROBLEM_CODE_MAX 0x01
//struct msg_test_adv { // 1 byte
// uint8_t adv_test;
//} __attribute__((packed));
//
//struct hdr_test_adv { // 1 byte
// uint8_t hdr_test;
// struct msg_test_adv msg[];
//} __attribute__((packed));
struct msg_problem_adv { // 4 bytes
uint8_t code;
uint8_t reserved;
LOCAL_ID_T local_id;
} __attribute__((packed));
struct msg_hello_adv { // 2 bytes
HELLO_SQN_T hello_sqn;
// uint8_t reserved; !!!!!!!!!!!!!!!!!!!!!!!!!!
} __attribute__((packed));
#define DEVADV_MSG_IGNORED -1
struct msg_dev_adv { // 26 byte
DEVADV_IDX_T dev_idx; // 1 byte
uint8_t channel; // 1 byte
FMETRIC_U8_T tx_bitrate_min; // 1 byte
FMETRIC_U8_T tx_bitrate_max; // 1 byte
IPX_T llip; // 16 byte
MAC_T mac; // 6 byte
} __attribute__((packed));
struct hdr_dev_adv { // 2 byte
DEVADV_SQN_T dev_sqn;
struct msg_dev_adv msg[];
} __attribute__((packed));
struct msg_dev_req { // 4 byte
LOCAL_ID_T destination_local_id;
} __attribute__((packed));
// directives indicating the importance for recalculating the link_adv msg array
#define LINKADV_CHANGES_NONE 0
#define LINKADV_CHANGES_REMOVED 1 // recalculate, but at most once each LINKADV_INTERVAL_REMOVED ms
#define LINKADV_CHANGES_NEW 1000 // recalculate, but at most once each LINKADV_INTERVAL_NEW ms
#define LINKADV_CHANGES_CRITICAL 1000000 // recalculate now!
#define LINKADV_INTERVAL_REMOVED 10000
#define LINKADV_INTERVAL_NEW 2000
#define LINKADV_MSG_IGNORED -1 // used to identify links that are currently not announed via link_adv msgs
// used to calculate the relevance of a link compared to the best current link:
#define LINKADV_ADD_RP_4DIF 4
#define LINKADV_ADD_RP_4MIN 2
#define LINKADV_ADD_RP_4MAX 3
struct msg_link_adv { // 6 byte
DEVADV_IDX_T transmitter_dev_idx; // to be combined with dev_id from packet header to resolve transmitters dev_id of reported link
DEVADV_IDX_T peer_dev_idx;
LOCAL_ID_T peer_local_id;
} __attribute__((packed));
struct hdr_link_adv { // 2 byte
//LINK_SQN_T link_sqn; as given in packet_header
DEVADV_SQN_T dev_sqn_ref;
struct msg_link_adv msg[];
} __attribute__((packed));
struct msg_link_req { // 4 byte
LOCAL_ID_T destination_local_id;
} __attribute__((packed));
struct msg_rp_adv { // 1 byte
#if __BYTE_ORDER == __LITTLE_ENDIAN
unsigned int rp_127range : 7;
unsigned int ogm_request : 1;
#elif __BYTE_ORDER == __BIG_ENDIAN
unsigned int ogm_request : 1;
unsigned int rp_127range : 7;
#else
# error "Please fix <bits/endian.h>"
#endif
// uint8_t rp_255range;
} __attribute__((packed));
/* Why knowledge about prev-hop (z) bandwidth is important:
* x,y,z transmit time via link x,y,z
*
* ->-x=3-- x: MAX(x,z) < y+z
* A B C
* ---y=2-- ---z=2--
*
*
* ---x=3--
* A B C
* ->-y=2-- ---z=1-- y: MAX(x,z) >= y+z
*
* */
/*
* Why 2-hops channel knowledge is important for directional links:
*
* (------)--.. ..--(-------)--..
* A B C D
* ..--(------)--..
*
* Why 3-hops channel knowledge is important for omnidirectional links:
*
* *||||||||*)))))))) (((((((((*||||||||*))))))))))
* A B E
* ((((((((*||||||||*)))))))))
* C D
* ((((((((*|||||||||*)))))))))
* */
struct msg_dhash_request { // 2 bytes
IID_T receiverIID4x;
} __attribute__((packed));
struct hdr_dhash_request { // 4 bytes
LOCAL_ID_T destination_local_id;
struct msg_dhash_request msg[];
} __attribute__((packed));
struct msg_dhash_adv { // 2 + X bytes
IID_T transmitterIID4x;
struct description_hash dhash;
} __attribute__((packed));
#define msg_description_request msg_dhash_request
#define hdr_description_request hdr_dhash_request
struct description { // 68 bytes
GLOBAL_ID_T globalId; // 32 bytes name + 20 bytes pkid
uint16_t revision; // 2 bytes //TODO: increase to 4 bytes
uint16_t capabilities; // 2 bytes
DESC_SQN_T descSqn; // 2 bytes
OGM_SQN_T ogmSqnMin; // 2 bytes
OGM_SQN_T ogmSqnRange;// 2 bytes
uint16_t txInterval; // 2 bytes
uint8_t reservedTtl; // 1 byte
uint8_t reserved; // 1 byte
uint16_t extensionLen;// 2 bytes
// uint8_t extensionData[];
} __attribute__((packed));
#define MSG_DESCRIPTION0_ADV_UNHASHED_SIZE 2
#define MSG_DESCRIPTION0_ADV_HASHED_SIZE (sizeof( GLOBAL_ID_T) + (4 * sizeof(uint32_t)))
#define MSG_DESCRIPTION0_ADV_SIZE (MSG_DESCRIPTION0_ADV_UNHASHED_SIZE + MSG_DESCRIPTION0_ADV_HASHED_SIZE)
struct msg_description_adv { // IPv6: >= 92 bytes
// the unhashed part:
IID_T transmitterIID4x; // 2 bytes
// the hashed pard:
struct description desc; // 68 bytes + extension frames (>= (metric-algo:2+16 bytes + hna6: 2+(x*22) bytes ))
} __attribute__((packed));
#define DESCRIPTION_MSG_FORMAT { \
{FIELD_TYPE_UINT, -1, (8*sizeof(IID_T)), 0, FIELD_RELEVANCE_MEDI, "transmitterIid4x"}, \
{FIELD_TYPE_GLOBAL_ID, -1, (8*sizeof(GLOBAL_ID_T)), 1, FIELD_RELEVANCE_HIGH, "globalId"}, \
{FIELD_TYPE_HEX, -1, 16, 0, FIELD_RELEVANCE_MEDI, "revision" }, \
{FIELD_TYPE_HEX, -1, 16, 0, FIELD_RELEVANCE_MEDI, "capabilities" }, \
{FIELD_TYPE_UINT, -1, 16, 0, FIELD_RELEVANCE_MEDI, "descSqn" }, \
{FIELD_TYPE_UINT, -1, (8*sizeof(OGM_SQN_T)), 0, FIELD_RELEVANCE_MEDI, "ogmSqnMin" }, \
{FIELD_TYPE_UINT, -1, (8*sizeof(OGM_SQN_T)), 0, FIELD_RELEVANCE_MEDI, ARG_OGM_SQN_RANGE }, \
{FIELD_TYPE_UINT, -1, 16, 0, FIELD_RELEVANCE_HIGH, ARG_TX_INTERVAL }, \
{FIELD_TYPE_UINT, -1, 8, 1, FIELD_RELEVANCE_LOW, "reservedTtl" }, \
{FIELD_TYPE_UINT, -1, 8, 1, FIELD_RELEVANCE_LOW, "reserved" }, \
{FIELD_TYPE_STRING_SIZE, -1, 16, 0, FIELD_RELEVANCE_LOW, "extensionLen" }, \
{FIELD_TYPE_STRING_BINARY, -1, 0, 1, FIELD_RELEVANCE_LOW, "extensionData" }, \
FIELD_FORMAT_END}
#define OGM_JUMPS_PER_AGGREGATION 10
#define OGMS_PER_AGGREG_MAX \
( (pref_udpd_size - \
(sizeof(struct packet_header) + sizeof(struct frame_header_long) + sizeof(struct hdr_ogm_adv) + \
(OGM_JUMPS_PER_AGGREGATION * sizeof(struct msg_ogm_adv)) ) ) / \
(sizeof(struct msg_ogm_adv)) )
#define OGMS_PER_AGGREG_PREF ( OGMS_PER_AGGREG_MAX / 2 )
#define OGM_IID_RSVD_JUMP (OGM_IIDOFFST_MASK) // 63 //255 // resulting from ((2^transmitterIIDoffset_bit_range)-1)
struct msg_ogm_adv // 4 bytes
{
OGM_MIX_T mix; //uint16_t mix of transmitterIIDoffset, metric_mant, metric_exp
union {
OGM_SQN_T ogm_sqn;
IID_T transmitterIIDabsolute;
} u;
} __attribute__((packed));
struct hdr_ogm_adv { // 2 bytes
AGGREG_SQN_T aggregation_sqn;
uint8_t ogm_dst_field_size;
struct msg_ogm_adv msg[];
} __attribute__((packed));
/*
* reception triggers:
* - (if link <-> neigh <-... is known and orig_sid is NOT known) msg_dhash0_request[ ... orig_did = orig_sid ]
* - else update_orig(orig_sid, orig_sqn)
*/
struct msg_ogm_ack {
// IID_T transmitterIID4x;
OGM_DEST_T ogm_destination; // 1 byte
AGGREG_SQN_T aggregation_sqn; // 1 byte
} __attribute__((packed));
/*
* reception triggers:
* - (if link <-> neigh <-... is known and orig_sid is NOT known) msg_dhash0_request[ ... orig_did = orig_sid ]
* - else update_orig(orig_sid, orig_sqn)
*/
#define BMX_DSC_TLV_METRIC 0x00
#define BMX_DSC_TLV_UHNA4 0x01
#define BMX_DSC_TLV_UHNA6 0x02
#define BMX_DSC_TLV_TUN6_MIN 0x04
#define BMX_DSC_TLV_TUN6_ADV 0x04
#define BMX_DSC_TLV_TUN4IN6_INGRESS_ADV 0x05
#define BMX_DSC_TLV_TUN6IN6_INGRESS_ADV 0x06
#define BMX_DSC_TLV_TUN4IN6_SRC_ADV 0x07
#define BMX_DSC_TLV_TUN6IN6_SRC_ADV 0x08
#define BMX_DSC_TLV_TUN4IN6_NET_ADV 0x09
#define BMX_DSC_TLV_TUN6IN6_NET_ADV 0x0A
#define BMX_DSC_TLV_TUN6_MAX 0x0A
#define BMX_DSC_TLV_TOPOLOGY 0x0F
#define BMX_DSC_TLV_JSON_SMS 0x10
#define BMX_DSC_TLV_MAX_KNOWN 0x10
#define BMX_DSC_TLV_MAX (FRAME_TYPE_ARRSZ-1)
#define BMX_DSC_TLV_ARRSZ (FRAME_TYPE_ARRSZ)
struct description_cache_node {
struct description_hash dhash;
TIME_T timestamp;
struct description *description;
};
extern uint32_t ogm_aggreg_pending;
extern IID_T myIID4me;
extern TIME_T myIID4me_timestamp;
//extern IDM_T my_dev_adv_changed;
extern struct frame_handl packet_frame_handler[FRAME_TYPE_ARRSZ];
extern struct frame_handl description_tlv_handl[BMX_DSC_TLV_ARRSZ];
extern Sha bmx_sha;
/***********************************************************
The core frame/message structures and handlers
************************************************************/
OGM_SQN_T set_ogmSqn_toBeSend_and_aggregated(struct orig_node *on, UMETRIC_T um, OGM_SQN_T to_be_send, OGM_SQN_T aggregated);
void update_my_description_adv( void );
void update_my_dev_adv(void);
void update_my_link_adv(uint32_t changes);
struct dhash_node * process_description(struct packet_buff *pb, struct description *desc, struct description_hash *dhash);
IDM_T process_description_tlvs(struct packet_buff *pb, struct orig_node *on, struct description *desc, uint8_t op,
uint8_t filter, void *custom_data, struct ctrl_node *cn);
void cache_desc_tlv_hashes(uint8_t op, struct orig_node *on, int8_t t_start, int8_t t, uint8_t *t_data, int32_t t_data_len);
void purge_tx_task_list(struct list_head *tx_tasks_list, struct link_node *only_link, struct dev_node *only_dev);
void tx_packets( void *unused );
IDM_T rx_frames(struct packet_buff *pb);
int32_t rx_frame_iterate(struct rx_frame_iterator* it);
#define SCHEDULE_UNKNOWN_MSGS_SIZE 0
#define SCHEDULE_MIN_MSG_SIZE -1
void schedule_tx_task(struct link_dev_node *lndev_out, uint16_t type, int16_t msgs_len,
uint16_t u16, uint32_t u32, IID_T myIID4x, IID_T neighIID4x);
void register_frame_handler(struct frame_handl *array, int pos, struct frame_handl *handl);
struct plugin *msg_get_plugin( void );