porting routing code from stable to master (and change many arm-nowarn-alignments)
[olsrd.git] / src / olsr_cfg_gen.c
1
2 /*
3  * The olsr.org Optimized Link-State Routing daemon(olsrd)
4  * Copyright (c) 2004-2009, the olsr.org team - see HISTORY file
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 "olsr_cfg_gen.h"
43 #include "olsr_protocol.h"
44 #include "ipcalc.h"
45 #include "olsr_ip_prefix_list.h"
46 #include "olsr_time.h"
47
48 #include <errno.h>
49
50 static INLINE void
51 append_reltime(struct autobuf *abuf, const char *name, uint32_t val, uint32_t deflt, bool first)
52 {
53   struct millitxt_buf buf;
54
55   if (val != deflt) {
56     abuf_appendf(abuf, "    %s\t%s\n", name, olsr_milli_to_txt(&buf, val));
57   } else if (first) {
58     abuf_appendf(abuf, "    #%s\t%s\n", name, olsr_milli_to_txt(&buf, val));
59   }
60 }
61
62 void
63 olsr_write_cnf_buf(struct autobuf *abuf, struct olsr_config *cnf, bool write_more_comments)
64 {
65   char ipv6_buf[INET6_ADDRSTRLEN];     /* buffer for IPv6 inet_ntop */
66   struct millitxt_buf tbuf;
67   const char *s;
68
69   abuf_appendf(abuf, "#\n" "# Generated config file for %s\n" "#\n\n", olsrd_version);
70
71   /* IP version */
72   abuf_appendf(abuf, "# IP version to use (4 or 6)\n" "IpVersion\t%d\n\n", cnf->ip_version == AF_INET ? 4 : 6);
73
74   /* FIB Metric */
75   abuf_appendf(abuf, "# FIBMetric (\"%s\", \"%s\", or \"%s\")\n"
76                "FIBMetric\t\"%s\"\n\n",
77                CFG_FIBM_FLAT, CFG_FIBM_CORRECT, CFG_FIBM_APPROX,
78                FIBM_FLAT == cnf->fib_metric ? CFG_FIBM_FLAT : FIBM_CORRECT == cnf->fib_metric ? CFG_FIBM_CORRECT : CFG_FIBM_APPROX);
79
80   /* HNA IPv4/IPv6 */
81   abuf_appendf(abuf, "# HNA IPv%d routes\n"
82                "# syntax: netaddr/prefix\n" "Hna%d {\n", cnf->ip_version == AF_INET ? 4 : 6, cnf->ip_version == AF_INET ? 4 : 6);
83   if (!list_is_empty(&cnf->hna_entries)) {
84     struct ip_prefix_entry *h;
85     struct list_iterator iterator;
86
87     OLSR_FOR_ALL_IPPREFIX_ENTRIES(&cnf->hna_entries, h, iterator) {
88       struct ipprefix_str strbuf;
89       abuf_appendf(abuf, "    %s\n", ip_prefix_to_string(cnf->ip_version, &strbuf, &h->net));
90     }
91   }
92   abuf_appendf(abuf, "}\n\n");
93
94   /* No interfaces */
95   abuf_appendf(abuf, "# Should olsrd keep on running even if there are\n"
96                "# no interfaces available? This is a good idea\n"
97                "# for a PCMCIA/USB hotswap environment.\n"
98                "# \"yes\" OR \"no\"\n" "AllowNoInt\t%s\n\n", cnf->allow_no_interfaces ? "yes" : "no");
99
100   /* TOS */
101   abuf_appendf(abuf, "# TOS(type of service) to use. Default is 16\n" "TosValue\t%d\n\n", cnf->tos);
102
103   /* RtProto */
104   abuf_appendf(abuf, "# Routing proto flag to use. Operating system default is 0\n" "RtProto\t\t%d\n\n", cnf->rt_proto);
105
106   /* RtTable */
107   abuf_appendf(abuf, "# Policy Routing Table to use. Default is 254\n" "RtTable\t\t%d\n\n", cnf->rt_table);
108
109   /* RtTableDefault */
110   abuf_appendf(abuf,
111                "# Policy Routing Table to use for the default Route. Default is 0 (Take the same table as specified by RtTable)\n"
112                "RtTableDefault\t\t%d\n\n", cnf->rt_table_default);
113
114   /* Willingness */
115   abuf_appendf(abuf, "# The fixed willingness to use(0-7)\n"
116                "# If not set willingness will be calculated\n"
117                "# dynammically based on battery/power status\n"
118                "%sWillingness\t%d\n\n", cnf->willingness_auto ? "#" : "", cnf->willingness_auto ? 4 : cnf->willingness);
119
120   /* Pollrate */
121   abuf_appendf(abuf, "# Polling rate in seconds(float).\n"
122                "# Auto uses default value 0.05 sec\n" "Pollrate\t%s\n",
123                olsr_milli_to_txt(&tbuf, cnf->pollrate));
124
125   /* NIC Changes Pollrate */
126   abuf_appendf(abuf, "# Interval to poll network interfaces for configuration\n"
127                "# changes. Defaults to 2.5 seconds\n" "NicChgsPollInt\t%s\n",
128                olsr_milli_to_txt(&tbuf, cnf->nic_chgs_pollrate));
129
130   /* TC redundancy */
131   abuf_appendf(abuf, "# TC redundancy\n"
132                "# Specifies how much neighbor info should\n"
133                "# be sent in TC messages\n"
134                "# Possible values are:\n"
135                "# 0 - only send MPR selectors\n"
136                "# 1 - send MPR selectors and MPRs\n"
137                "# 2 - send all neighbors\n" "# defaults to 0\n" "TcRedundancy\t%d\n\n", cnf->tc_redundancy);
138
139   /* MPR coverage */
140   abuf_appendf(abuf, "# MPR coverage\n"
141                "# Specifies how many MPRs a node should\n"
142                "# try select to reach every 2 hop neighbor\n"
143                "# Can be set to any integer >0\n" "# defaults to 1\n" "MprCoverage\t%d\n\n", cnf->mpr_coverage);
144
145   abuf_appendf(abuf, "# Fish Eye algorithm\n"
146                "# 0 = do not use fish eye\n" "# 1 = use fish eye\n" "LinkQualityFishEye\t%d\n\n", cnf->lq_fish);
147
148   abuf_appendf(abuf, "# NAT threshold\n" "NatThreshold\t%s\n\n", olsr_milli_to_txt(&tbuf, cnf->lq_nat_thresh));
149
150   abuf_appendf(abuf, "# Clear screen when printing debug output?\n" "ClearScreen\t%s\n\n", cnf->clear_screen ? "yes" : "no");
151
152   /* Plugins */
153   abuf_appendf(abuf, "# Olsrd plugins to load\n"
154                "# This must be the absolute path to the file\n"
155                "# or the loader will use the following scheme:\n"
156                "# - Try the paths in the LD_LIBRARY_PATH \n"
157                "#   environment variable.\n"
158                "# - The list of libraries cached in /etc/ld.so.cache\n" "# - /lib, followed by /usr/lib\n\n");
159   if (cnf->plugins) {
160     struct plugin_entry *pe;
161     for (pe = cnf->plugins; pe != NULL; pe = pe->next) {
162       struct plugin_param *pp;
163       abuf_appendf(abuf, "LoadPlugin \"%s\" {\n", pe->name);
164       for (pp = pe->params; pp != NULL; pp = pp->next) {
165         abuf_appendf(abuf, "    PlParam \"%s\"\t\"%s\"\n", pp->key, pp->value);
166       }
167       abuf_appendf(abuf, "}\n");
168     }
169   }
170   abuf_appendf(abuf, "\n");
171
172   append_reltime(abuf, "TcInterval", cnf->tc_params.emission_interval, TC_INTERVAL, true);
173   append_reltime(abuf, "TcValidityTime", cnf->tc_params.validity_time, TOP_HOLD_TIME, true);
174   append_reltime(abuf, "MidInterval", cnf->mid_params.emission_interval, MID_INTERVAL, true);
175   append_reltime(abuf, "MidValidityTime", cnf->mid_params.validity_time, MID_HOLD_TIME, true);
176   append_reltime(abuf, "HnaInterval", cnf->hna_params.emission_interval, HNA_INTERVAL, true);
177   append_reltime(abuf, "HnaValidityTime", cnf->hna_params.validity_time, HNA_HOLD_TIME, true);
178
179   abuf_puts(abuf, "\n");
180
181   /* Interfaces */
182   abuf_appendf(abuf, "# Interfaces\n"
183                "# Multiple interfaces with the same configuration\n"
184                "# can shar the same config block. Just list the\n" "# interfaces(e.g. Interface \"eth0\" \"eth2\"\n");
185   /* Interfaces */
186   if (cnf->if_configs) {
187     struct olsr_if_config *in;
188     bool first;
189     for (in = cnf->if_configs, first = write_more_comments; in != NULL; in = in->next, first = false) {
190       abuf_appendf(abuf, "Interface \"%s\" {\n", in->name);
191
192       if (first) {
193         abuf_appendf(abuf, "    # IPv4 broadcast address to use. The\n"
194                      "    # one usefull example would be 255.255.255.255\n"
195                      "    # If not defined the broadcastaddress\n" "    # every card is configured with is used\n\n");
196       }
197
198       if (in->cnf->ipv4_broadcast.v4.s_addr) {
199         abuf_appendf(abuf, "    Ip4Broadcast\t%s\n", inet_ntoa(in->cnf->ipv4_broadcast.v4));
200       } else if (first) {
201         abuf_appendf(abuf, "    #Ip4Broadcast\t255.255.255.255\n");
202       }
203
204       if (first) {
205         abuf_appendf(abuf, "\n    # IPv6 address type to use.\n"
206                      "    # Must be 'auto', 'site-local', 'unique-local' or 'global'\n\n");
207       }
208       if (in->cnf->ipv6_addrtype == OLSR_IP6T_SITELOCAL)
209         s = CFG_IP6T_SITELOCAL;
210       else if (in->cnf->ipv6_addrtype == OLSR_IP6T_UNIQUELOCAL)
211         s = CFG_IP6T_UNIQUELOCAL;
212       else if (in->cnf->ipv6_addrtype == OLSR_IP6T_GLOBAL)
213         s = CFG_IP6T_GLOBAL;
214       else
215         s = CFG_IP6T_AUTO;
216       abuf_appendf(abuf, "    Ip6AddrType\t%s\n\n", s);
217
218       if (first) {
219         abuf_appendf(abuf, "\n"
220                      "    # IPv6 multicast address to use when\n"
221                      "    # using site-local addresses.\n" "    # If not defined, ff05::15 is used\n");
222       }
223       abuf_appendf(abuf, "    Ip6MulticastSite\t%s\n",
224                    inet_ntop(AF_INET6, &in->cnf->ipv6_multi_site.v6, ipv6_buf, sizeof(ipv6_buf)));
225       if (first) {
226         abuf_appendf(abuf, "\n    # IPv6 multicast address to use when\n"
227                      "    # using global addresses\n" "    # If not defined, ff0e::1 is used\n");
228       }
229       abuf_appendf(abuf, "    Ip6MulticastGlobal\t%s\n",
230                    inet_ntop(AF_INET6, &in->cnf->ipv6_multi_glbl.v6, ipv6_buf, sizeof(ipv6_buf)));
231       if (first) {
232         abuf_appendf(abuf, "\n");
233       }
234       abuf_appendf(abuf, "    # Olsrd can autodetect changes in\n"
235                    "    # interface configurations. Enabled by default\n"
236                    "    # turn off to save CPU.\n" "    AutoDetectChanges: %s\n\n", in->cnf->autodetect_chg ? "yes" : "no");
237
238       if (first) {
239         abuf_appendf(abuf, "    # Emission and validity intervals.\n"
240                      "    # If not defined, RFC proposed values will\n" "    # in most cases be used.\n");
241       }
242       append_reltime(abuf, "HelloInterval", in->cnf->hello_params.emission_interval, HELLO_INTERVAL, first);
243       append_reltime(abuf, "HelloValidityTime", in->cnf->hello_params.validity_time, NEIGHB_HOLD_TIME, first);
244       if (in->cnf->lq_mult == NULL) {
245         if (first) {
246           abuf_appendf(abuf, "    #LinkQualityMult\tdefault 1.0\n");
247         }
248       } else {
249         struct olsr_lq_mult *mult;
250         for (mult = in->cnf->lq_mult; mult != NULL; mult = mult->next) {
251           abuf_appendf(abuf, "    LinkQualityMult\t%s %0.2f\n",
252                        inet_ntop(cnf->ip_version, &mult->addr, ipv6_buf, sizeof(ipv6_buf)), (float)mult->value / 65536.0);
253         }
254       }
255
256       if (first) {
257         abuf_appendf(abuf, "    # When multiple links exist between hosts\n"
258                      "    # the weight of interface is used to determine\n"
259                      "    # the link to use. Normally the weight is\n"
260                      "    # automatically calculated by olsrd based\n"
261                      "    # on the characteristics of the interface,\n"
262                      "    # but here you can specify a fixed value.\n"
263                      "    # Olsrd will choose links with the lowest value.\n"
264                      "    # Note:\n"
265                      "    # Interface weight is used only when LinkQualityLevel is 0.\n"
266                      "    # For any other value of LinkQualityLevel, the interface ETX\n" "    # value is used instead.\n\n");
267       }
268       if (in->cnf->weight.fixed) {
269         abuf_appendf(abuf, "    Weight\t %d\n", in->cnf->weight.value);
270       } else if (first) {
271         abuf_appendf(abuf, "    #Weight\t 0\n");
272       }
273
274       abuf_appendf(abuf, "}\n\n");
275     }
276   }
277 }
278
279 /*
280  * Local Variables:
281  * c-basic-offset: 2
282  * indent-tabs-mode: nil
283  * End:
284  */