mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
53 lines
863 B
C
53 lines
863 B
C
#include <string.h>
|
|
#include "of0.h"
|
|
|
|
rpl_of_t rpl_of0 = {
|
|
0x0,
|
|
calc_rank,
|
|
which_parent,
|
|
which_dodag,
|
|
reset,
|
|
NULL
|
|
};
|
|
|
|
rpl_of_t *rpl_get_of0(){
|
|
return &rpl_of0;
|
|
}
|
|
|
|
void reset(rpl_dodag_t *dodag){
|
|
//Nothing to do in OF0
|
|
}
|
|
|
|
uint16_t calc_rank(rpl_parent_t * parent, uint16_t base_rank){
|
|
if(base_rank == 0) {
|
|
if(parent == NULL) {
|
|
return INFINITE_RANK;
|
|
}
|
|
base_rank = parent->rank;
|
|
}
|
|
|
|
uint16_t add;
|
|
if(parent != NULL){
|
|
add = parent->dodag->minhoprankincrease;
|
|
}
|
|
else{
|
|
add = DEFAULT_MIN_HOP_RANK_INCREASE;
|
|
}
|
|
if( base_rank + add < base_rank ){
|
|
return INFINITE_RANK;
|
|
}
|
|
return base_rank + add;
|
|
}
|
|
|
|
//We simply return the Parent with lower rank
|
|
rpl_parent_t * which_parent(rpl_parent_t *p1, rpl_parent_t *p2){
|
|
if(p1->rank < p2->rank){
|
|
return p1;
|
|
}
|
|
return p2;
|
|
}
|
|
|
|
rpl_dodag_t * which_dodag(rpl_dodag_t *d1, rpl_dodag_t *d2){
|
|
return d1;
|
|
}
|