/** * Objective function 0 for RPL implementation * * Copyright (C) 2013 INRIA. * * This file subject to the terms and conditions of the GNU Lesser General * Public License. See the file LICENSE in the top level directory for more * details. * * @ingroup rpl * @{ * @file of0.c * @brief RPL objective function 0 * @author Eric Engel * @} */ #include #include "of0.h" rpl_of_t rpl_of0 = { 0x0, calc_rank, which_parent, which_dodag, reset, NULL }; rpl_of_t *rpl_get_of0(void) { 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; }