1d5c86e6a8c71e8d9b61cfe12e68c5683738a6b6
[olsrd.git] / src / olsr_switch / link_rules.c
1
2 /*
3  * The olsr.org Optimized Link-State Routing daemon(olsrd)
4  * Copyright (c) 2005, Andreas Tonnesen(andreto@olsr.org)
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * * Redistributions of source code must retain the above copyright
12  *   notice, this list of conditions and the following disclaimer.
13  * * Redistributions in binary form must reproduce the above copyright
14  *   notice, this list of conditions and the following disclaimer in
15  *   the documentation and/or other materials provided with the
16  *   distribution.
17  * * Neither the name of olsr.org, olsrd nor the names of its
18  *   contributors may be used to endorse or promote products derived
19  *   from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  *
34  * Visit http://www.olsr.org for more information.
35  *
36  * If you find this software useful feel free to make a donation
37  * to the project. For more information see the website or contact
38  * the copyright holders.
39  *
40  */
41
42 #include "link_rules.h"
43 #include "olsr_host_switch.h"
44 #include "ipcalc.h"
45
46 #include <string.h>
47 #include <stdlib.h>
48 #include <stdio.h>
49
50 int
51 ohs_check_link(struct ohs_connection *oc, union olsr_ip_addr *dst)
52 {
53   struct ohs_ip_link *links;
54   for (links = oc->links; links != NULL; links = links->next) {
55     int r;
56     if (!ipequal(&links->dst, dst)) {
57       continue;
58     }
59     if (links->quality == 0) {
60       if (logbits & LOG_LINK) {
61         struct ipaddr_str addrstr, dststr;
62         printf("%s -> %s Q: %d\n", olsr_ip_to_string(&addrstr, &oc->ip_addr), olsr_ip_to_string(&dststr, dst), links->quality);
63       }
64       return 0;
65     }
66
67     r = 1 + (int)(100.0 / (RAND_MAX + 1.0) * rand());
68
69     if (logbits & LOG_LINK) {
70       struct ipaddr_str addrstr, dststr;
71       printf("%s -> %s Q: %d R: %d\n", olsr_ip_to_string(&addrstr, &oc->ip_addr), olsr_ip_to_string(&dststr, dst), links->quality,
72              r);
73     }
74     /* Random - based on quality */
75     return links->quality > r ? 0 : 1;
76   }
77   return 1;
78 }
79
80 int
81 ohs_delete_all_related_links(struct ohs_connection *oc)
82 {
83   struct ohs_ip_link *links = oc->links;
84   int cnt = 0;
85
86   /* Delete links from this node */
87   while (links) {
88     struct ohs_ip_link *tmp_link = links;
89     links = links->next;
90     free(tmp_link);
91     cnt++;
92   }
93
94   /* Delete links to this node */
95
96   // XXX - ToDo
97
98   return cnt;
99 }
100
101 struct ohs_ip_link *
102 add_link(struct ohs_connection *src, struct ohs_connection *dst)
103 {
104   struct ohs_ip_link *link;
105
106   /* Create new link */
107   link = malloc(sizeof(struct ohs_ip_link));
108   if (!link)
109     OHS_OUT_OF_MEMORY("New link");
110   /* Queue */
111   link->next = src->links;
112   src->links = link;
113   link->dst = dst->ip_addr;
114   src->linkcnt++;
115
116   return link;
117 }
118
119 int
120 remove_link(struct ohs_connection *oc, struct ohs_ip_link *lnk)
121 {
122   struct ohs_ip_link *links = oc->links;
123   struct ohs_ip_link *prev_link = NULL;
124
125   while (links) {
126     if (links == lnk) {
127       /* Remove */
128       if (prev_link)
129         prev_link->next = links->next;
130       else
131         oc->links = links->next;
132
133       free(lnk);
134       oc->linkcnt--;
135       return 1;
136     }
137     prev_link = links;
138     links = links->next;
139   }
140   return 0;
141 }
142
143 struct ohs_ip_link *
144 get_link(struct ohs_connection *oc, union olsr_ip_addr *dst)
145 {
146   struct ohs_ip_link *links;
147   for (links = oc->links; links != NULL; links = links->next) {
148     if (ipequal(&links->dst, dst)) {
149       return links;
150     }
151   }
152   return NULL;
153 }
154
155 /*
156  * Local Variables:
157  * c-basic-offset: 2
158  * indent-tabs-mode: nil
159  * End:
160  */