blob: 5361deb175c13cf5aeb60c043c7f280c147b73e6 [file] [log] [blame]
akmhoque29c1db52012-09-07 14:47:43 -05001#ifndef _NLSR_ROUTE_H_
2#define _NLSR_ROUTE_H_
3
4#define EMPTY_PARENT -12345
5#define INF_DISTANCE 2147483647
6
akmhoque810a5b52012-09-09 16:53:14 -05007#define NO_NEXT_HOP -12345
8#define NO_MAPPING_NUM -1
akmhoque3560cb62012-09-09 10:52:30 -05009
akmhoque29c1db52012-09-07 14:47:43 -050010struct map_entry
11{
12 char *router;
13 int mapping;
14};
15
akmhoque3560cb62012-09-09 10:52:30 -050016
17struct routing_table_entry
18{
19 char *dest_router;
20 int next_hop_face;
21}
22;
23
akmhoque29c1db52012-09-07 14:47:43 -050024int route_calculate(struct ccn_schedule *sched, void *clienth, struct ccn_scheduled_event *ev, int flags);
25void make_map(void);
26void add_map_entry(char *router);
27void add_adj_data_to_map(char *orig_router, char *body, int no_link);
28void print_map(void);
29void assign_mapping_number(void);
30void make_adj_matrix(int **adj_matrix,int map_element);
31void init_adj_matrix(int **adj_matrix,int map_element);
32void print_adj_matrix(int **adj_matrix, int map_element);
33int get_mapping_no(char *router);
34void calculate_path(int **adj_matrix, long int *parent, long int V, long int S);
35void sort_queue_by_distance(long int *Q,long int *dist,long int start,long int element);
36int is_not_explored(long int *Q, long int u,long int start, long int element);
37void print_path(long int *parent, long int dest);
38void print_all_path_from_source(long int *parent,long int source);
akmhoquefbfd0982012-09-09 20:59:03 -050039void add_rev_map_entry(long int mapping_number, char *router);
40void print_rev_map(void);
41char * get_router_from_rev_map(long int mapping_number);
akmhoque29c1db52012-09-07 14:47:43 -050042
akmhoque3560cb62012-09-09 10:52:30 -050043/* Routing Table Relates function */
44
45int get_next_hop(char *dest_router);
46void add_next_hop_router(char *dest_router);
47void add_next_hop_from_lsa_adj_body(char *body, int no_link);
48void print_routing_table(void);
49void do_old_routing_table_updates();
akmhoquefbfd0982012-09-09 20:59:03 -050050void update_routing_table_with_new_route(long int *parent, long int source);
51
52long int get_next_hop_from_calculation(long int *parent, long int dest,long int source);
53void print_all_next_hop(long int *parent,long int source);
akmhoque3560cb62012-09-09 10:52:30 -050054
akmhoque29c1db52012-09-07 14:47:43 -050055#endif