Files
WheelTimer/WheelTimer/libtimer/Course/projects/rt.c
2020-10-27 07:08:05 -07:00

135 lines
3.4 KiB
C

/*
* =====================================================================================
*
* Filename: rt.h
*
* Description:
*
* Version: 1.0
* Created: 02/22/2020 06:14:33 AM
* Revision: none
* Compiler: gcc
*
* Author: Er. Abhishek Sagar, Juniper Networks (https://csepracticals.wixsite.com/csepracticals), sachinites@gmail.com
* Company: Juniper Networks
*
* This file is part of the Netlink Sockets distribution (https://github.com/sachinites)
* Copyright (c) 2019 Abhishek Sagar.
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General
* Public License as published by the Free Software Foundation, version 3.
*
* 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.
*
* visit website : https://csepracticals.wixsite.com/csepracticals for more courses and projects
*
* =====================================================================================
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <memory.h>
#include "rt.h"
void
rt_init_rt_table(rt_table_t *rt_table){
rt_table->head = NULL;
}
bool
rt_add_new_rt_entry(rt_table_t *rt_table,
char *dest,
char mask,
char *gw_ip,
char *oif){
rt_entry_t *head = NULL;
rt_entry_t *rt_entry = NULL;
rt_entry = calloc(1, sizeof(rt_entry_t));
if(!rt_entry)
return false;
strncpy(rt_entry->rt_entry_keys.dest, dest, sizeof(rt_entry->rt_entry_keys.dest));
rt_entry->rt_entry_keys.mask = mask;
if(gw_ip)
strncpy(rt_entry->gw_ip, gw_ip, sizeof(rt_entry->gw_ip));
if(oif)
strncpy(rt_entry->oif, oif, sizeof(rt_entry->oif));
rt_entry->time_to_expire = RT_TABLE_EXP_TIME;
head = rt_table->head;
rt_table->head = rt_entry;
rt_entry->prev = 0;
rt_entry->next = head;
if(head)
head->prev = rt_entry;
return true;
}
bool
rt_delete_rt_entry(rt_table_t *rt_table,
char *dest, char mask){
rt_entry_t *rt_entry = NULL;
ITERTAE_RT_TABLE_BEGIN(rt_table, rt_entry){
if(strncmp(rt_entry->rt_entry_keys.dest,
dest, sizeof(rt_entry->rt_entry_keys.dest)) == 0 &&
rt_entry->rt_entry_keys.mask == mask){
rt_entry_remove(rt_table, rt_entry);
free(rt_entry);
return true;
}
} ITERTAE_RT_TABLE_END(rt_table, curr);
return false;
}
bool
rt_update_rt_entry(rt_table_t *rt_table,
char *dest,
char mask,
char *new_gw_ip,
char *new_oif){
return true;
}
void
rt_clear_rt_table(rt_table_t *rt_table){
}
void
rt_free_rt_table(rt_table_t *rt_table){
}
void
rt_dump_rt_table(rt_table_t *rt_table){
rt_entry_t *rt_entry = NULL;
ITERTAE_RT_TABLE_BEGIN(rt_table, rt_entry){
printf("%-20s %-4d %-20s %-12s %usec\n",
rt_entry->rt_entry_keys.dest,
rt_entry->rt_entry_keys.mask,
rt_entry->gw_ip,
rt_entry->oif,
rt_entry->time_to_expire);
} ITERTAE_RT_TABLE_END(rt_tabl, rt_entry);
}