olsr_switch: replace random() by our own function
[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 #include "olsr_random.h"
46
47 #include <string.h>
48 #include <stdlib.h>
49 #include <stdio.h>
50
51 int
52 ohs_check_link(struct ohs_connection *oc, union olsr_ip_addr *dst)
53 {
54   struct ohs_ip_link *links;
55   for (links = oc->links; links != NULL; links = links->next) {
56     int r;
57     if (!ipequal(&links->dst, dst)) {
58       continue;
59     }
60     if (links->quality == 0) {
61       if (logbits & LOG_LINK) {
62         struct ipaddr_str addrstr, dststr;
63         printf("%s -> %s Q: %d\n", olsr_ip_to_string(&addrstr, &oc->ip_addr), olsr_ip_to_string(&dststr, dst), links->quality);
64       }
65       return 0;
66     }
67
68     r = 1 + (int)(100.0 / (RAND_MAX + 1.0) * olsr_random());
69
70     if (logbits & LOG_LINK) {
71       struct ipaddr_str addrstr, dststr;
72       printf("%s -> %s Q: %d R: %d\n", olsr_ip_to_string(&addrstr, &oc->ip_addr), olsr_ip_to_string(&dststr, dst), links->quality,
73              r);
74     }
75     /* Random - based on quality */
76     return links->quality > r ? 0 : 1;
77   }
78   return 1;
79 }
80
81 int
82 ohs_delete_all_related_links(struct ohs_connection *oc)
83 {
84   struct ohs_ip_link *links = oc->links;
85   int cnt = 0;
86
87   /* Delete links from this node */
88   while (links) {
89     struct ohs_ip_link *tmp_link = links;
90     links = links->next;
91     free(tmp_link);
92     cnt++;
93   }
94
95   /* Delete links to this node */
96
97   // XXX - ToDo
98
99   return cnt;
100 }
101
102 struct ohs_ip_link *
103 add_link(struct ohs_connection *src, struct ohs_connection *dst)
104 {
105   struct ohs_ip_link *link;
106
107   /* Create new link */
108   link = malloc(sizeof(struct ohs_ip_link));
109   if (!link)
110     OHS_OUT_OF_MEMORY("New link");
111   /* Queue */
112   link->next = src->links;
113   src->links = link;
114   link->dst = dst->ip_addr;
115   src->linkcnt++;
116
117   return link;
118 }
119
120 int
121 remove_link(struct ohs_connection *oc, struct ohs_ip_link *lnk)
122 {
123   struct ohs_ip_link *links = oc->links;
124   struct ohs_ip_link *prev_link = NULL;
125
126   while (links) {
127     if (links == lnk) {
128       /* Remove */
129       if (prev_link)
130         prev_link->next = links->next;
131       else
132         oc->links = links->next;
133
134       free(lnk);
135       oc->linkcnt--;
136       return 1;
137     }
138     prev_link = links;
139     links = links->next;
140   }
141   return 0;
142 }
143
144 struct ohs_ip_link *
145 get_link(struct ohs_connection *oc, union olsr_ip_addr *dst)
146 {
147   struct ohs_ip_link *links;
148   for (links = oc->links; links != NULL; links = links->next) {
149     if (ipequal(&links->dst, dst)) {
150       return links;
151     }
152   }
153   return NULL;
154 }
155
156 /*
157  * Local Variables:
158  * c-basic-offset: 2
159  * indent-tabs-mode: nil
160  * End:
161  */