1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

Merge pull request #2915 from BytesGalore/fib_register_rrp_with_prefix

net/network_layer/fib: added prefix consideration for RRP registration/signaling
This commit is contained in:
Lotte Steenbrink 2015-05-14 12:01:59 +02:00
commit 6a0a2e8bd6
2 changed files with 74 additions and 42 deletions

View File

@ -26,15 +26,15 @@ extern "C" {
#endif #endif
/** /**
* @brief Reactive Routing Protocol (RRP) message content to request/reply route discovery * @brief Routing Protocol (RP) message content to request/reply notification
*/ */
typedef struct rrp_address_msg_t { typedef struct rp_address_msg_t {
uint8_t *address; /**< The pointer to the address */ uint8_t *address; /**< The pointer to the address */
uint8_t address_size; /**< The address size */ uint8_t address_size; /**< The address size */
uint32_t address_flags; /**< The flags for the given address */ uint32_t address_flags; /**< The flags for the given address */
} rrp_address_msg_t; } rp_address_msg_t;
#define FIB_MSG_RRP_SIGNAL (0x99) /**< message type for RRP notifications */ #define FIB_MSG_RP_SIGNAL (0x99) /**< message type for RP notifications */
/** /**
* @brief indicator of a lifetime that does not expire (2^32 - 1) * @brief indicator of a lifetime that does not expire (2^32 - 1)
@ -52,9 +52,16 @@ void fib_init(void);
void fib_deinit(void); void fib_deinit(void);
/** /**
* @brief Registration of reactive routing protocol handler function * @brief Registration of a routing protocol handler function
*
* @param[in] prefix the prefix handled by the according RP
* @param[in] prefix_size the prefix size
* @return 0 on success
* -ENOMEM if the entry cannot be registered (mximum registrations reached)
* -EINVAL if the prefix is NULL or the provided size is 0
*
*/ */
void fib_register_rrp(void); int fib_register_rp(uint8_t *prefix, size_t prefix_size);
/** /**
* @brief Adds a new entry in the corresponding FIB table for global destination and next hop * @brief Adds a new entry in the corresponding FIB table for global destination and next hop

View File

@ -35,20 +35,25 @@
static mutex_t mtx_access = MUTEX_INIT; static mutex_t mtx_access = MUTEX_INIT;
/** /**
* @brief maximum number of handled reactive routing protocols (RRP) * @brief maximum number of handled routing protocols (RP)
* used to notify the saved kernel_pid_t * used to notify the saved kernel_pid_t on ureachable destination
*/ */
#define FIB_MAX_RRP (5) #define FIB_MAX_REGISTERED_RP (5)
/** /**
* @brief registered RRPs for notifications about unreachable destinations * @brief registered RPs for notifications about unreachable destinations
*/ */
static size_t notify_rrp_pos = 0; static size_t notify_rp_pos = 0;
/** /**
* @brief the kernel_pid_t for notifying the RRPs * @brief the kernel_pid_t for notifying the RPs
*/ */
static kernel_pid_t notify_rrp[FIB_MAX_RRP]; static kernel_pid_t notify_rp[FIB_MAX_REGISTERED_RP];
/**
* @brief the prefix handled by the RP
*/
static universal_address_container_t* prefix_rp[FIB_MAX_REGISTERED_RP];
/** /**
* @brief maximum number of FIB tables entries handled * @brief maximum number of FIB tables entries handled
@ -271,8 +276,10 @@ static int fib_remove(fib_entry_t *entry)
} }
/** /**
* @brief signals (sends a message to) all registered RRPs * @brief signals (sends a message to) all registered routing protocols
* to start a route discovery for the provided destination. * registered with a matching prefix (usually this should be only one).
* The message informs the recipient that no next-hop is available for the
* requested destination address.
* The receiver MUST copy the content, i.e. the address before reply. * The receiver MUST copy the content, i.e. the address before reply.
* *
* @param[in] dst the destination address * @param[in] dst the destination address
@ -281,29 +288,32 @@ static int fib_remove(fib_entry_t *entry)
* @return 0 on a new available entry, * @return 0 on a new available entry,
* -ENOENT if no suiting entry is provided. * -ENOENT if no suiting entry is provided.
*/ */
static int fib_signal_rrp(uint8_t *dst, size_t dst_size, uint32_t dst_flags) static int fib_signal_rp(uint8_t *dst, size_t dst_size, uint32_t dst_flags)
{ {
msg_t msg, reply; msg_t msg, reply;
rrp_address_msg_t content; rp_address_msg_t content;
content.address = dst; content.address = dst;
content.address_size = dst_size; content.address_size = dst_size;
content.address_flags = dst_flags; content.address_flags = dst_flags;
int ret = -ENOENT; int ret = -ENOENT;
msg.type = FIB_MSG_RRP_SIGNAL; msg.type = FIB_MSG_RP_SIGNAL;
msg.content.ptr = (void *)&content; msg.content.ptr = (void *)&content;
for (size_t i = 0; i < FIB_MAX_RRP; ++i) { for (size_t i = 0; i < FIB_MAX_REGISTERED_RP; ++i) {
if (notify_rrp[i] != KERNEL_PID_UNDEF) { if (notify_rp[i] != KERNEL_PID_UNDEF) {
DEBUG("[fib_signal_rrp] send msg@: %p to pid[%d]: %d\n", \ DEBUG("[fib_signal_rp] send msg@: %p to pid[%d]: %d\n", \
msg.content.ptr, (int)i, (int)notify_rrp[i]); msg.content.ptr, (int)i, (int)notify_rp[i]);
/* the receiver, i.e. the RRP, MUST copy the content value. /* do only signal a RP if its registered prefix matches */
if (universal_address_compare(prefix_rp[i], dst, &dst_size) == 0) {
/* the receiver, i.e. the RP, MUST copy the content value.
* using the provided pointer after replying this message * using the provided pointer after replying this message
* will lead to errors * will lead to errors
*/ */
msg_send_receive(&msg, &reply, notify_rrp[i]); msg_send_receive(&msg, &reply, notify_rp[i]);
DEBUG("[fib_signal_rrp] got reply."); DEBUG("[fib_signal_rp] got reply.");
}
} }
} }
@ -395,8 +405,8 @@ int fib_get_next_hop(kernel_pid_t *iface_id,
int ret = fib_find_entry(dst, dst_size, &(entry[0]), &count); int ret = fib_find_entry(dst, dst_size, &(entry[0]), &count);
if (!(ret == 0 || ret == 1)) { if (!(ret == 0 || ret == 1)) {
/* notify all RRPs for route discovery if available */ /* notify all responsible RPs for unknown next-hop for the destination address */
if (fib_signal_rrp(dst, dst_size, dst_flags) == 0) { if (fib_signal_rp(dst, dst_size, dst_flags) == 0) {
count = 1; count = 1;
/* now lets see if the RRPs have found a valid next-hop */ /* now lets see if the RRPs have found a valid next-hop */
ret = fib_find_entry(dst, dst_size, &(entry[0]), &count); ret = fib_find_entry(dst, dst_size, &(entry[0]), &count);
@ -429,8 +439,9 @@ void fib_init(void)
DEBUG("[fib_init] hello. Initializing some stuff."); DEBUG("[fib_init] hello. Initializing some stuff.");
mutex_lock(&mtx_access); mutex_lock(&mtx_access);
for (size_t i = 0; i < FIB_MAX_RRP; ++i) { for (size_t i = 0; i < FIB_MAX_REGISTERED_RP; ++i) {
notify_rrp[i] = KERNEL_PID_UNDEF; notify_rp[i] = KERNEL_PID_UNDEF;
prefix_rp[i] = NULL;
} }
for (size_t i = 0; i < FIB_MAX_FIB_TABLE_ENTRIES; ++i) { for (size_t i = 0; i < FIB_MAX_FIB_TABLE_ENTRIES; ++i) {
@ -452,11 +463,12 @@ void fib_deinit(void)
DEBUG("[fib_deinit] hello. De-Initializing stuff."); DEBUG("[fib_deinit] hello. De-Initializing stuff.");
mutex_lock(&mtx_access); mutex_lock(&mtx_access);
for (size_t i = 0; i < FIB_MAX_RRP; ++i) { for (size_t i = 0; i < FIB_MAX_REGISTERED_RP; ++i) {
notify_rrp[i] = KERNEL_PID_UNDEF; notify_rp[i] = KERNEL_PID_UNDEF;
prefix_rp[i] = NULL;
} }
notify_rrp_pos = 0; notify_rp_pos = 0;
for (size_t i = 0; i < FIB_MAX_FIB_TABLE_ENTRIES; ++i) { for (size_t i = 0; i < FIB_MAX_FIB_TABLE_ENTRIES; ++i) {
fib_table[i].iface_id = 0; fib_table[i].iface_id = 0;
@ -472,16 +484,29 @@ void fib_deinit(void)
mutex_unlock(&mtx_access); mutex_unlock(&mtx_access);
} }
void fib_register_rrp(void) int fib_register_rrp(uint8_t *prefix, size_t prefix_size)
{ {
mutex_lock(&mtx_access); mutex_lock(&mtx_access);
if (notify_rrp_pos < FIB_MAX_RRP) { if (notify_rp_pos >= FIB_MAX_REGISTERED_RP) {
notify_rrp[notify_rrp_pos] = sched_active_pid; mutex_unlock(&mtx_access);
notify_rrp_pos++; return -ENOMEM;
}
if ((prefix == NULL) || (prefix_size == 0)) {
mutex_unlock(&mtx_access);
return -EINVAL;
}
if (notify_rp_pos < FIB_MAX_REGISTERED_RP) {
notify_rp[notify_rp_pos] = sched_active_pid;
universal_address_container_t *container = universal_address_add(prefix, prefix_size);
prefix_rp[notify_rp_pos] = container;
notify_rp_pos++;
} }
mutex_unlock(&mtx_access); mutex_unlock(&mtx_access);
return 0;
} }
int fib_get_num_used_entries(void) int fib_get_num_used_entries(void)
@ -499,12 +524,12 @@ int fib_get_num_used_entries(void)
/* print functions */ /* print functions */
void fib_print_notify_rrp(void) void fib_print_notify_rp(void)
{ {
mutex_lock(&mtx_access); mutex_lock(&mtx_access);
for (size_t i = 0; i < FIB_MAX_RRP; ++i) { for (size_t i = 0; i < FIB_MAX_REGISTERED_RP; ++i) {
printf("[fib_print_notify_rrp] pid[%d]: %d\n", (int)i, (int)notify_rrp[i]); printf("[fib_print_notify_rp] pid[%d]: %d\n", (int)i, (int)notify_rp[i]);
} }
mutex_unlock(&mtx_access); mutex_unlock(&mtx_access);