From 907f27f8b21919ba41be6b8ef212d8669dafccc9 Mon Sep 17 00:00:00 2001 From: Jo-Philipp Wich Date: Sun, 15 Mar 2009 18:52:11 +0000 Subject: [PATCH] Merge r4331, r4332 --- contrib/package/olsrd-luci/Makefile | 26 +- .../package/olsrd-luci/files/etc/config/olsrd | 1 - .../package/olsrd-luci/files/etc/init.d/olsrd | 2 +- .../olsrd-luci/patches/100-olsrd-hg-r3.patch | 500 ------------ .../patches/140-olsrd-optimize-size.patch | 717 ++++++++++-------- 5 files changed, 419 insertions(+), 827 deletions(-) delete mode 100644 contrib/package/olsrd-luci/patches/100-olsrd-hg-r3.patch diff --git a/contrib/package/olsrd-luci/Makefile b/contrib/package/olsrd-luci/Makefile index bcc50d729..c0ccf46d2 100644 --- a/contrib/package/olsrd-luci/Makefile +++ b/contrib/package/olsrd-luci/Makefile @@ -12,21 +12,21 @@ include $(TOPDIR)/rules.mk PKG_BASENAME:=olsrd PKG_NAME:=$(PKG_BASENAME)-luci PKG_BASEVER:=0.5.6-r3 -PKG_VERSION:=$(PKG_BASEVER)+freifunk +PKG_VERSION:=$(PKG_BASEVER)+hg1765 PKG_RELEASE:=1 -#PKG_HGREV:=a7316f987848 -#PKG_SOURCE:=$(PKG_HGREV).tar.gz -#PKG_SOURCE_URL:=http://gredler.at/hg/olsrd/archive -#PKG_MD5SUM:=b228b5452af158cd4313f9ed416d9c84 -#PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_HGREV) -#PKG_UNPACK=$(HOST_TAR) -C $(PKG_BUILD_DIR) --strip-components=1 -xzf $(DL_DIR)/$(PKG_SOURCE) +PKG_HGREV:=fc691af9a18d +PKG_SOURCE:=$(PKG_HGREV).tar.gz +PKG_SOURCE_URL:=http://gredler.at/hg/olsrd-0.5.6/archive +PKG_MD5SUM:=17fe345abf208ea1411d0a2041cf3c4e +PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_HGREV) +PKG_UNPACK=$(HOST_TAR) -C $(PKG_BUILD_DIR) --strip-components=1 -xzf $(DL_DIR)/$(PKG_SOURCE) -PKG_SOURCE:=$(PKG_BASENAME)-$(PKG_BASEVER).tar.bz2 -PKG_SOURCE_URL:=http://www.olsr.org/releases/0.5 -PKG_MD5SUM:=0935688fa0fb5b0e073fe53ec654c5b2 -PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_BASEVER) -PKG_UNPACK=$(HOST_TAR) -C $(PKG_BUILD_DIR) --strip-components=1 -xjf $(DL_DIR)/$(PKG_SOURCE) +#PKG_SOURCE:=$(PKG_BASENAME)-$(PKG_BASEVER).tar.bz2 +#PKG_SOURCE_URL:=http://www.olsr.org/releases/0.5 +#PKG_MD5SUM:=0935688fa0fb5b0e073fe53ec654c5b2 +#PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_BASEVER) +#PKG_UNPACK=$(HOST_TAR) -C $(PKG_BUILD_DIR) --strip-components=1 -xjf $(DL_DIR)/$(PKG_SOURCE) include $(INCLUDE_DIR)/package.mk @@ -125,7 +125,7 @@ define Build/Compile $(MAKE) -C "$(PKG_BUILD_DIR)" olsrd libs \ $(TARGET_CONFIGURE_OPTS) \ NODEBUG=1 \ - CFLAGS="$(TARGET_CFLAGS)" \ + CFLAGS="$(TARGET_CFLAGS) -DSVEN_OLA_UNBLOAT" \ OS="linux" \ INSTALL_PREFIX="$(PKG_INSTALL_DIR)" \ LIBDIR="$(PKG_INSTALL_DIR)/usr/lib" \ diff --git a/contrib/package/olsrd-luci/files/etc/config/olsrd b/contrib/package/olsrd-luci/files/etc/config/olsrd index 415859022..c3c93039d 100644 --- a/contrib/package/olsrd-luci/files/etc/config/olsrd +++ b/contrib/package/olsrd-luci/files/etc/config/olsrd @@ -6,7 +6,6 @@ config 'olsrd' config 'Interface' option 'ignore' '1' option 'interface' 'ff' - option 'Ip4Broadcast' '255.255.255.255' config 'LoadPlugin' option 'library' 'olsrd_dyn_gw_plain.so.0.4' diff --git a/contrib/package/olsrd-luci/files/etc/init.d/olsrd b/contrib/package/olsrd-luci/files/etc/init.d/olsrd index b90c3b993..d9e5a8d8c 100755 --- a/contrib/package/olsrd-luci/files/etc/init.d/olsrd +++ b/contrib/package/olsrd-luci/files/etc/init.d/olsrd @@ -10,7 +10,7 @@ PID=/var/run/olsrd.pid OLSRD_OLSRD_SCHEMA='ignore:internal config_file:internal DebugLevel=0 IpVersion=4 AllowNoInt:bool=1 Pollrate=0.025 TcRedundancy=2 MprCoverage=3 LinkQualityFishEye=1 LinkQualityDijkstraLimit=0+9.0 FIBMetric=flat ClearScreen:bool=1 Willingness=3 LinkQualityAging=0.1 LinkQualityAlgorithm=etx_fpm' OLSRD_IPCCONNECT_SCHEMA='ignore:internal Host:list Net:list2' OLSRD_LOADPLUGIN_SCHEMA='ignore:internal library:internal Host:list Net:list2 Ping:list redistribute:list NonOlsrIf:list name:list lat lon latlon_infile HNA:list2 hosts:list2' -OLSRD_INTERFACE_SCHEMA='ignore:internal interface:internal AutoDetectChanges:bool Ip4Broadcast HelloInterval=2.0 HelloValidityTime=40.0 TcInterval=5.0 TcValidityTime=100.0 MidInterval=18.0 MidValidityTime=324.0 HnaInterval=18.0 HnaValidityTime=108.0' +OLSRD_INTERFACE_SCHEMA='ignore:internal interface:internal AutoDetectChanges:bool Ip4Broadcast HelloInterval=5.0 HelloValidityTime=40.0 TcInterval=2.0 TcValidityTime=100.0 MidInterval=18.0 MidValidityTime=324.0 HnaInterval=18.0 HnaValidityTime=108.0' T=' ' N=' diff --git a/contrib/package/olsrd-luci/patches/100-olsrd-hg-r3.patch b/contrib/package/olsrd-luci/patches/100-olsrd-hg-r3.patch deleted file mode 100644 index a4890049b..000000000 --- a/contrib/package/olsrd-luci/patches/100-olsrd-hg-r3.patch +++ /dev/null @@ -1,500 +0,0 @@ -diff --exclude='.hg*' -Nur olsrd-0.5.6-r3/lib/nameservice/README_NAMESERVICE /home/sven-ola/olsrd-0.5.6/lib/nameservice/README_NAMESERVICE ---- olsrd-0.5.6-r3/lib/nameservice/README_NAMESERVICE 2008-12-02 11:42:54.000000000 +0100 -+++ /home/sven-ola/olsrd-0.5.6/lib/nameservice/README_NAMESERVICE 2008-12-03 09:11:11.000000000 +0100 -@@ -112,12 +112,32 @@ - table. Useful for executing a script that uses the hosts file - to keep a website or a database updated. - -+PlParam "service" "http://me.olsr:80|tcp|my little homepage" -+ Add a new service announcement to be spreaded in the mesh. -+ -+PlParam "services-file" "/path/to/services_file" -+ File to write (default: /var/run/services_olsr) -+ - PlParam "services-change-script" "/path/to/script" - Similar to the previous parameter. Script to execute when there - is a change in the services list propagated by the nameserver - plugin. Useful for executing a script that uses the services file - to keep a website or a database updated. - -+PlParam "mac" "xx:xx:xx:xx:xx:xx[,0-255]" -+ Add a new MAC addr to be spreaded in the mesh. This MAC addr -+ may be used to fine control nerve-wreck-page solutions based -+ on MAC adresses. The optional dec. number designates a class. -+ -+PlParam "macs-file" "/path/to/macs_file" -+ File to write (default: /var/run/macs_olsr) -+ -+PlParam "macs-change-script" "/path/to/script" -+ Similar to the previous parameter. Script to execute when there -+ is a change in the macs list propagated by the nameserver -+ plugin. Useful for executing a script that uses the services file -+ to keep a website or a database updated. -+ - --------------------------------------------------------------------- - SAMPLE CONFIG - --------------------------------------------------------------------- -diff --exclude='.hg*' -Nur olsrd-0.5.6-r3/lib/nameservice/src/nameservice.c /home/sven-ola/olsrd-0.5.6/lib/nameservice/src/nameservice.c ---- olsrd-0.5.6-r3/lib/nameservice/src/nameservice.c 2008-12-02 11:50:01.000000000 +0100 -+++ /home/sven-ola/olsrd-0.5.6/lib/nameservice/src/nameservice.c 2008-12-03 09:20:01.000000000 +0100 -@@ -75,8 +75,10 @@ - static double my_timeout = NAME_VALID_TIME; - static char my_resolv_file[MAX_FILE + 1]; - static char my_services_file[MAX_FILE + 1]; -+static char my_macs_file[MAX_FILE + 1]; - static char my_name_change_script[MAX_FILE + 1]; - static char my_services_change_script[MAX_FILE + 1]; -+static char my_macs_change_script[MAX_FILE + 1]; - static char latlon_in_file[MAX_FILE + 1]; - static char my_latlon_file[MAX_FILE + 1]; - float my_lat = 0.0, my_lon = 0.0; -@@ -96,6 +98,10 @@ - static struct name_entry *my_services = NULL; - static olsr_bool service_table_changed = OLSR_TRUE; - -+static struct list_node mac_list[HASHSIZE]; -+static struct name_entry *my_macs = NULL; -+static olsr_bool mac_table_changed = OLSR_TRUE; -+ - static struct list_node forwarder_list[HASHSIZE]; - static struct name_entry *my_forwarders = NULL; - static olsr_bool forwarder_table_changed = OLSR_TRUE; -@@ -131,6 +137,7 @@ - - GetWindowsDirectory(my_hosts_file, MAX_FILE - 12); - GetWindowsDirectory(my_services_file, MAX_FILE - 12); -+ GetWindowsDirectory(my_macs_file, MAX_FILE - 12); - GetWindowsDirectory(my_resolv_file, MAX_FILE - 12); - - len = strlen(my_hosts_file); -@@ -143,6 +150,11 @@ - strscat(my_services_file, "\\", sizeof(my_services_file)); - strscat(my_services_file, "services_olsr", sizeof(my_services_file)); - -+ len = strlen(my_macs_file); -+ if (my_macs_file[len - 1] != '\\') -+ strscat(my_macs_file, "\\", sizeof(my_macs_file)); -+ strscat(my_macs_file, "macs_olsr", sizeof(my_macs_file)); -+ - len = strlen(my_resolv_file); - if (my_resolv_file[len - 1] != '\\') - strscat(my_resolv_file, "\\", sizeof(my_resolv_file)); -@@ -150,6 +162,7 @@ - #else - strscpy(my_hosts_file, "/var/run/hosts_olsr", sizeof(my_hosts_file)); - strscpy(my_services_file, "/var/run/services_olsr", sizeof(my_services_file)); -+ strscpy(my_macs_file, "/var/run/macs_olsr", sizeof(my_macs_file)); - strscpy(my_resolv_file, "/var/run/resolvconf_olsr", sizeof(my_resolv_file)); - *my_sighup_pid_file = 0; - #endif -@@ -160,12 +173,14 @@ - latlon_in_file[0] = '\0'; - my_name_change_script[0] = '\0'; - my_services_change_script[0] = '\0'; -+ my_macs_change_script[0] = '\0'; - - /* init the lists heads */ - for (i = 0; i < HASHSIZE; i++) { - list_head_init(&name_list[i]); - list_head_init(&forwarder_list[i]); - list_head_init(&service_list[i]); -+ list_head_init(&mac_list[i]); - list_head_init(&latlon_list[i]); - } - -@@ -232,58 +247,31 @@ - return 0; - } - -+/* *INDENT-OFF* */ - static const struct olsrd_plugin_parameters plugin_parameters[] = { -- {.name = "interval",.set_plugin_parameter = &set_plugin_int,.data = &my_interval}, -- {.name = "timeout",.set_plugin_parameter = &set_nameservice_float,.data = &my_timeout}, -- {.name = "sighup-pid-file",.set_plugin_parameter = &set_plugin_string,.data = &my_sighup_pid_file,.addon = -- {sizeof(my_sighup_pid_file)} -- } -- , -- {.name = "hosts-file",.set_plugin_parameter = &set_plugin_string,.data = &my_hosts_file,.addon = {sizeof(my_hosts_file)} -- } -- , -- {.name = "name-change-script",.set_plugin_parameter = &set_plugin_string,.data = &my_name_change_script,.addon = -- {sizeof(my_name_change_script)} -- } -- , -- {.name = "services-change-script",.set_plugin_parameter = &set_plugin_string,.data = &my_services_change_script,.addon = -- {sizeof(my_services_change_script)} -- } -- , -- {.name = "resolv-file",.set_plugin_parameter = &set_plugin_string,.data = &my_resolv_file,.addon = {sizeof(my_resolv_file)} -- } -- , -- {.name = "suffix",.set_plugin_parameter = &set_plugin_string,.data = &my_suffix,.addon = {sizeof(my_suffix)} -- } -- , -- {.name = "add-hosts",.set_plugin_parameter = &set_plugin_string,.data = &my_add_hosts,.addon = {sizeof(my_add_hosts)} -- } -- , -- {.name = "services-file",.set_plugin_parameter = &set_plugin_string,.data = &my_services_file,.addon = {sizeof(my_services_file)} -- } -- , -- {.name = "lat",.set_plugin_parameter = &set_nameservice_float,.data = &my_lat} -- , -- {.name = "lon",.set_plugin_parameter = &set_nameservice_float,.data = &my_lon} -- , -- {.name = "latlon-file",.set_plugin_parameter = &set_plugin_string,.data = &my_latlon_file,.addon = {sizeof(my_latlon_file)} -- } -- , -- {.name = "latlon-infile",.set_plugin_parameter = &set_plugin_string,.data = &latlon_in_file,.addon = {sizeof(latlon_in_file)} -- } -- , -- {.name = "dns-server",.set_plugin_parameter = &set_nameservice_server,.data = &my_forwarders,.addon = {NAME_FORWARDER} -- } -- , -- {.name = "name",.set_plugin_parameter = &set_nameservice_name,.data = &my_names,.addon = {NAME_HOST} -- } -- , -- {.name = "service",.set_plugin_parameter = &set_nameservice_name,.data = &my_services,.addon = {NAME_SERVICE} -- } -- , -- {.name = "",.set_plugin_parameter = &set_nameservice_host,.data = &my_names} -- , -+ { .name = "interval", .set_plugin_parameter = &set_plugin_int, .data = &my_interval }, -+ { .name = "timeout", .set_plugin_parameter = &set_nameservice_float, .data = &my_timeout }, -+ { .name = "sighup-pid-file", .set_plugin_parameter = &set_plugin_string, .data = &my_sighup_pid_file, .addon = {sizeof(my_sighup_pid_file)} }, -+ { .name = "hosts-file", .set_plugin_parameter = &set_plugin_string, .data = &my_hosts_file, .addon = {sizeof(my_hosts_file)} }, -+ { .name = "name-change-script", .set_plugin_parameter = &set_plugin_string, .data = &my_name_change_script, .addon = {sizeof(my_name_change_script)} }, -+ { .name = "services-change-script", .set_plugin_parameter = &set_plugin_string, .data = &my_services_change_script, .addon = {sizeof(my_services_change_script)} }, -+ { .name = "macs-change-script", .set_plugin_parameter = &set_plugin_string, .data = &my_macs_change_script, .addon = {sizeof(my_macs_change_script)} }, -+ { .name = "resolv-file", .set_plugin_parameter = &set_plugin_string, .data = &my_resolv_file, .addon = {sizeof(my_resolv_file)} }, -+ { .name = "suffix", .set_plugin_parameter = &set_plugin_string, .data = &my_suffix, .addon = {sizeof(my_suffix)} }, -+ { .name = "add-hosts", .set_plugin_parameter = &set_plugin_string, .data = &my_add_hosts, .addon = {sizeof(my_add_hosts)} }, -+ { .name = "services-file", .set_plugin_parameter = &set_plugin_string, .data = &my_services_file, .addon = {sizeof(my_services_file)} }, -+ { .name = "macs-file", .set_plugin_parameter = &set_plugin_string, .data = &my_macs_file, .addon = {sizeof(my_macs_file)} }, -+ { .name = "lat", .set_plugin_parameter = &set_nameservice_float, .data = &my_lat }, -+ { .name = "lon", .set_plugin_parameter = &set_nameservice_float, .data = &my_lon }, -+ { .name = "latlon-file", .set_plugin_parameter = &set_plugin_string, .data = &my_latlon_file, .addon = {sizeof(my_latlon_file)} }, -+ { .name = "latlon-infile", .set_plugin_parameter = &set_plugin_string, .data = &latlon_in_file, .addon = {sizeof(latlon_in_file)} }, -+ { .name = "dns-server", .set_plugin_parameter = &set_nameservice_server, .data = &my_forwarders, .addon = {NAME_FORWARDER} }, -+ { .name = "name", .set_plugin_parameter = &set_nameservice_name, .data = &my_names, .addon = {NAME_HOST} }, -+ { .name = "service", .set_plugin_parameter = &set_nameservice_name, .data = &my_services, .addon = {NAME_SERVICE} }, -+ { .name = "mac", .set_plugin_parameter = &set_nameservice_name, .data = &my_macs, .addon = {NAME_MACADDR} }, -+ { .name = "", .set_plugin_parameter = &set_nameservice_host, .data = &my_names }, - }; -+/* *INDENT-OFF* */ - - void - olsrd_get_plugin_parameters(const struct olsrd_plugin_parameters **params, int *size) -@@ -404,6 +392,7 @@ - my_names = remove_nonvalid_names_from_list(my_names, NAME_HOST); - my_forwarders = remove_nonvalid_names_from_list(my_forwarders, NAME_FORWARDER); - my_services = remove_nonvalid_names_from_list(my_services, NAME_SERVICE); -+ my_macs = remove_nonvalid_names_from_list(my_macs, NAME_MACADDR); - - /* register functions with olsrd */ - olsr_parser_add_function(&olsr_parser, PARSER_TYPE); -@@ -435,6 +424,9 @@ - case NAME_SERVICE: - valid = allowed_service(my_list->name); - break; -+ case NAME_MACADDR: -+ valid = is_mac_wellformed(my_list->name); -+ break; - case NAME_LATLON: - valid = is_latlon_wellformed(my_list->name); - break; -@@ -470,10 +462,12 @@ - - free_name_entry_list(&my_names); - free_name_entry_list(&my_services); -+ free_name_entry_list(&my_macs); - free_name_entry_list(&my_forwarders); - - free_all_list_entries(name_list); - free_all_list_entries(service_list); -+ free_all_list_entries(mac_list); - free_all_list_entries(forwarder_list); - free_all_list_entries(latlon_list); - -@@ -517,11 +511,12 @@ - { - write_file_timer = NULL; - -- write_resolv_file(); /* if forwarder_table_changed */ -- write_hosts_file(); /* if name_table_changed */ -- write_services_file(); /* if service_table_changed */ -+ write_resolv_file(); /* if forwarder_table_changed */ -+ write_hosts_file(); /* if name_table_changed */ -+ write_services_file(OLSR_FALSE); /* if service_table_changed */ -+ write_services_file(OLSR_TRUE); /* if mac_table_changed */ - #ifdef WIN32 -- write_latlon_file(); /* if latlon_table_changed */ -+ write_latlon_file(); /* if latlon_table_changed */ - #endif - } - -@@ -688,7 +683,6 @@ - encap_namemsg(struct namemsg *msg) - { - struct name_entry *my_name; -- struct name_entry *my_service; - - // add the hostname, service and forwarder entries after the namemsg header - char *pos = (char *)msg + sizeof(struct namemsg); -@@ -705,8 +699,13 @@ - i++; - } - // services -- for (my_service = my_services; my_service != NULL; my_service = my_service->next) { -- pos = create_packet((struct name *)pos, my_service); -+ for (my_name = my_services; my_name != NULL; my_name = my_name->next) { -+ pos = create_packet((struct name *)pos, my_name); -+ i++; -+ } -+ // macs -+ for (my_name = my_macs; my_name != NULL; my_name = my_name->next) { -+ pos = create_packet((struct name *)pos, my_name); - i++; - } - // latlon -@@ -779,6 +778,7 @@ - //XXX: should I check the from_packet->ip here? If so, why not also check the ip from HOST and SERVICE? - if ((type_of_from_packet == NAME_HOST && !is_name_wellformed(name)) - || (type_of_from_packet == NAME_SERVICE && !is_service_wellformed(name)) -+ || (type_of_from_packet == NAME_MACADDR && !is_mac_wellformed(name)) - || (type_of_from_packet == NAME_LATLON && !is_latlon_wellformed(name))) { - OLSR_PRINTF(4, "NAME PLUGIN: invalid name [%s] received, skipping.\n", name); - return; -@@ -886,6 +886,9 @@ - case NAME_SERVICE: - insert_new_name_in_list(originator, service_list, from_packet, &service_table_changed, vtime); - break; -+ case NAME_MACADDR: -+ insert_new_name_in_list(originator, mac_list, from_packet, &mac_table_changed, vtime); -+ break; - case NAME_LATLON: - insert_new_name_in_list(originator, latlon_list, from_packet, &latlon_table_changed, vtime); - break; -@@ -1128,45 +1131,47 @@ - } - - /** -- * write services to a file in the format: -- * service #originator ip -+ * write services or macs to a file in the format: -+ * service-or-mac #originator ip - * - * since service has a special format - * each line will look similar to e.g. - * http://me.olsr:80|tcp|my little homepage -+ * while a mac line will look similar to -+ * 02:ca:ff:ee:ba:be,1 - */ - void --write_services_file(void) -+write_services_file(olsr_bool writemacs) - { - int hash; - struct name_entry *name; - struct db_entry *entry; - struct list_node *list_head, *list_node; -- FILE *services_file; -+ FILE *file; - time_t currtime; - -- if (!service_table_changed) -+ if ((writemacs && !mac_table_changed) || (!writemacs && !service_table_changed)) - return; - -- OLSR_PRINTF(2, "NAME PLUGIN: writing services file\n"); -+ OLSR_PRINTF(2, "NAME PLUGIN: writing %s file\n", writemacs ? "macs" : "services"); - -- services_file = fopen(my_services_file, "w"); -- if (services_file == NULL) { -- OLSR_PRINTF(2, "NAME PLUGIN: cant write services_file file\n"); -+ file = fopen(writemacs ? my_macs_file : my_services_file, "w"); -+ if (file == NULL) { -+ OLSR_PRINTF(2, "NAME PLUGIN: cant write %s\n", writemacs ? my_macs_file : my_services_file); - return; - } - -- fprintf(services_file, "### this file is overwritten regularly by olsrd\n"); -- fprintf(services_file, "### do not edit\n\n"); -+ fprintf(file, "### this file is overwritten regularly by olsrd\n"); -+ fprintf(file, "### do not edit\n\n"); - -- // write own services -- for (name = my_services; name != NULL; name = name->next) { -- fprintf(services_file, "%s\t# my own service\n", name->name); -+ // write own services or macs -+ for (name = writemacs ? my_macs : my_services; name != NULL; name = name->next) { -+ fprintf(file, "%s\t# my own %s\n", name->name, writemacs ? "mac" : "service"); - } - -- // write received services -+ // write received services or macs - for (hash = 0; hash < HASHSIZE; hash++) { -- list_head = &service_list[hash]; -+ list_head = writemacs ? &mac_list[hash] : &service_list[hash]; - for (list_node = list_head->next; list_node != list_head; list_node = list_node->next) { - - entry = list2db(list_node); -@@ -1176,26 +1181,38 @@ - OLSR_PRINTF(6, "%s\t", name->name); - OLSR_PRINTF(6, "\t#%s\n", olsr_ip_to_string(&strbuf, &entry->originator)); - -- fprintf(services_file, "%s\t", name->name); -- fprintf(services_file, "\t#%s\n", olsr_ip_to_string(&strbuf, &entry->originator)); -+ fprintf(file, "%s\t", name->name); -+ fprintf(file, "\t#%s\n", olsr_ip_to_string(&strbuf, &entry->originator)); - } - } - } - - if (time(&currtime)) { -- fprintf(services_file, "\n### written by olsrd at %s", ctime(&currtime)); -+ fprintf(file, "\n### written by olsrd at %s", ctime(&currtime)); - } - -- fclose(services_file); -- service_table_changed = OLSR_FALSE; -- -- // Executes my_services_change_script after writing the services file -- if (my_services_change_script[0] != '\0') { -- if (system(my_services_change_script) != -1) { -- OLSR_PRINTF(2, "NAME PLUGIN: Service changed, %s executed\n", my_services_change_script); -- } else { -- OLSR_PRINTF(2, "NAME PLUGIN: WARNING! Failed to execute %s on service change\n", my_services_change_script); -+ fclose(file); -+ if (writemacs) { -+ // Executes my_macs_change_script after writing the macs file -+ if (my_macs_change_script[0] != '\0') { -+ if (system(my_macs_change_script) != -1) { -+ OLSR_PRINTF(2, "NAME PLUGIN: Service changed, %s executed\n", my_macs_change_script); -+ } else { -+ OLSR_PRINTF(2, "NAME PLUGIN: WARNING! Failed to execute %s on mac change\n", my_macs_change_script); -+ } - } -+ mac_table_changed = OLSR_FALSE; -+ } -+ else { -+ // Executes my_services_change_script after writing the services file -+ if (my_services_change_script[0] != '\0') { -+ if (system(my_services_change_script) != -1) { -+ OLSR_PRINTF(2, "NAME PLUGIN: Service changed, %s executed\n", my_services_change_script); -+ } else { -+ OLSR_PRINTF(2, "NAME PLUGIN: WARNING! Failed to execute %s on service change\n", my_services_change_script); -+ } -+ } -+ service_table_changed = OLSR_FALSE; - } - } - -@@ -1348,6 +1365,9 @@ - case NAME_SERVICE: - service_table_changed = OLSR_TRUE; - break; -+ case NAME_MACADDR: -+ mac_table_changed = OLSR_TRUE; -+ break; - case NAME_LATLON: - latlon_table_changed = OLSR_TRUE; - break; -@@ -1498,6 +1518,22 @@ - return regexec(®ex_t_service, service_line, pmatch_service, regmatch_t_service, 0) == 0; - } - -+/* -+ * check if the mac matches the syntax -+ */ -+olsr_bool -+is_mac_wellformed(const char *mac_line) -+{ -+ size_t i; -+ olsr_bool ret; -+ int x[6], d = -1; -+ for(i = 0; i < ARRAYSIZE(x); i++) x[i] = -1; -+ sscanf(mac_line, "%02x:%02x:%02x:%02x:%02x:%02x,%d\n", &x[0], &x[1], &x[2], &x[3], &x[4], &x[5], &d); -+ ret = 0 <= d && d <= 0xffff; -+ for(i = 0; i < ARRAYSIZE(x); i++) ret = ret && 0 <= x[i]; -+ return ret; -+} -+ - /** - * check if the latlot matches the syntax - */ -diff --exclude='.hg*' -Nur olsrd-0.5.6-r3/lib/nameservice/src/nameservice.h /home/sven-ola/olsrd-0.5.6/lib/nameservice/src/nameservice.h ---- olsrd-0.5.6-r3/lib/nameservice/src/nameservice.h 2008-12-02 11:50:01.000000000 +0100 -+++ /home/sven-ola/olsrd-0.5.6/lib/nameservice/src/nameservice.h 2008-12-03 09:20:01.000000000 +0100 -@@ -145,7 +145,7 @@ - - void write_hosts_file(void); - --void write_services_file(void); -+void write_services_file(olsr_bool writemacs); - - void write_resolv_file(void); - -@@ -161,7 +161,7 @@ - - olsr_bool is_service_wellformed(const char *service_line); - --olsr_bool is_service_wellformed(const char *service_line); -+olsr_bool is_mac_wellformed(const char *service_line); - - olsr_bool is_latlon_wellformed(const char *latlon_line); - -diff --exclude='.hg*' -Nur olsrd-0.5.6-r3/lib/nameservice/src/nameservice_msg.h /home/sven-ola/olsrd-0.5.6/lib/nameservice/src/nameservice_msg.h ---- olsrd-0.5.6-r3/lib/nameservice/src/nameservice_msg.h 2008-12-02 11:50:01.000000000 +0100 -+++ /home/sven-ola/olsrd-0.5.6/lib/nameservice/src/nameservice_msg.h 2008-12-03 09:11:13.000000000 +0100 -@@ -43,6 +43,7 @@ - NAME_FORWARDER = 1, - NAME_SERVICE = 2, - NAME_LATLON = 3, -+ NAME_MACADDR = 4, - } NAME_TYPE; - - /** -diff --exclude='.hg*' -Nur olsrd-0.5.6-r3/lib/tas/src/lua/lobject.c /home/sven-ola/olsrd-0.5.6/lib/tas/src/lua/lobject.c ---- olsrd-0.5.6-r3/lib/tas/src/lua/lobject.c 2008-12-02 11:50:01.000000000 +0100 -+++ /home/sven-ola/olsrd-0.5.6/lib/tas/src/lua/lobject.c 2008-12-03 09:19:32.000000000 +0100 -@@ -42,11 +42,11 @@ - return (m << 3) | cast(int, x); - } - -+/* *INDENT-OFF* */ - int - luaO_log2(unsigned int x) - { - static const lu_byte log_8[255] = { --/* *INDENT-OFF* */ - 0, - 1,1, - 2,2,2,2, -@@ -59,7 +59,6 @@ - 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7, - 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7, - 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7 --/* *INDENT-ON* */ - }; - if (x >= 0x00010000) { - if (x >= 0x01000000) -@@ -74,6 +73,7 @@ - return -1; /* special `log' for 0 */ - } - } -+/* *INDENT-ON* */ - - int - luaO_rawequalObj(const TObject * t1, const TObject * t2) -diff --exclude='.hg*' -Nur olsrd-0.5.6-r3/Makefile /home/sven-ola/olsrd-0.5.6/Makefile ---- olsrd-0.5.6-r3/Makefile 2008-12-02 11:50:01.000000000 +0100 -+++ /home/sven-ola/olsrd-0.5.6/Makefile 2008-12-03 09:11:10.000000000 +0100 -@@ -39,7 +39,7 @@ - # Please also write a new version to: - # gui/win32/Main/Frontend.rc (line 71, around "CAPTION [...]") - # gui/win32/Inst/installer.nsi (line 57, around "MessageBox MB_YESNO [...]") --VERS = 0.5.6-r3 -+VERS = pre-0.5.6-r4 - - TOPDIR = . - include Makefile.inc diff --git a/contrib/package/olsrd-luci/patches/140-olsrd-optimize-size.patch b/contrib/package/olsrd-luci/patches/140-olsrd-optimize-size.patch index 7aed872e9..debc3415d 100644 --- a/contrib/package/olsrd-luci/patches/140-olsrd-optimize-size.patch +++ b/contrib/package/olsrd-luci/patches/140-olsrd-optimize-size.patch @@ -1,6 +1,20 @@ -diff -Nur olsrd-0.5.6-r3.orig/lib/bmf/src/NetworkInterfaces.c olsrd-0.5.6-r3/lib/bmf/src/NetworkInterfaces.c ---- olsrd-0.5.6-r3.orig/lib/bmf/src/NetworkInterfaces.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/lib/bmf/src/NetworkInterfaces.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/Makefile.inc olsrd-0-5-6-fc691af9a18d/Makefile.inc +--- olsrd-0-5-6-fc691af9a18d.orig/Makefile.inc 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/Makefile.inc 2009-03-15 18:10:12.000000000 +0000 +@@ -205,6 +205,10 @@ + $(warning Use CPPFLAGS instead of DEFINES for -D) + endif + ++ifeq ($(SVEN_OLA_UNBLOAT),1) ++CPPFLAGS += -DSVEN_OLA_UNBLOAT -DNODEBUG ++endif ++ + TAGFILE ?= src/TAGS + + help: +diff -ur olsrd-0-5-6-fc691af9a18d.orig/lib/bmf/src/NetworkInterfaces.c olsrd-0-5-6-fc691af9a18d/lib/bmf/src/NetworkInterfaces.c +--- olsrd-0-5-6-fc691af9a18d.orig/lib/bmf/src/NetworkInterfaces.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/lib/bmf/src/NetworkInterfaces.c 2009-03-15 18:10:12.000000000 +0000 @@ -544,7 +544,9 @@ OLSR_PRINTF(9, "%s: ----> Not forwarding to %s: no link found\n", PLUGIN_NAME_SHORT, olsr_ip_to_string(&buf, &walker->neighbor_iface_addr)); @@ -11,9 +25,9 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/bmf/src/NetworkInterfaces.c olsrd-0.5.6-r3/lib OLSR_PRINTF(9, "%s: ----> Not forwarding to %s: \"%s\" gives a better link to this neighbor, costing %5.2f\n", PLUGIN_NAME_SHORT, olsr_ip_to_string(&buf, &walker->neighbor_iface_addr), bestIntf->int_name, -diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/Makefile olsrd-0.5.6-r3/lib/httpinfo/Makefile ---- olsrd-0.5.6-r3.orig/lib/httpinfo/Makefile 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/lib/httpinfo/Makefile 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/lib/httpinfo/Makefile olsrd-0-5-6-fc691af9a18d/lib/httpinfo/Makefile +--- olsrd-0-5-6-fc691af9a18d.orig/lib/httpinfo/Makefile 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/lib/httpinfo/Makefile 2009-03-15 18:10:12.000000000 +0000 @@ -47,7 +47,11 @@ CPPFLAGS += -DADMIN_INTERFACE endif @@ -26,9 +40,9 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/Makefile olsrd-0.5.6-r3/lib/httpinfo/ default_target: $(PLUGIN_FULLNAME) ifdef ADMIN_INTERFACE -diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/lib/httpinfo/src/olsrd_httpinfo.c ---- olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/lib/httpinfo/src/olsrd_httpinfo.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0-5-6-fc691af9a18d/lib/httpinfo/src/olsrd_httpinfo.c +--- olsrd-0-5-6-fc691af9a18d.orig/lib/httpinfo/src/olsrd_httpinfo.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/lib/httpinfo/src/olsrd_httpinfo.c 2009-03-15 18:10:12.000000000 +0000 @@ -67,7 +67,9 @@ #include "olsrd_httpinfo.h" @@ -41,29 +55,29 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/l #undef OS @@ -181,7 +183,9 @@ - static int build_about_body(char *, olsr_u32_t); + static int build_about_body(char *, uint32_t); +#ifndef SVEN_OLA_UNBLOAT - static int build_cfgfile_body(char *, olsr_u32_t); + static int build_cfgfile_body(char *, uint32_t); +#endif /* SVEN_OLA_UNBLOAT */ static int check_allowed_ip(const struct allowed_net *const allowed_nets, const union olsr_ip_addr *const addr); -@@ -217,10 +221,13 @@ - {"Admin", "admin", build_admin_body, OLSR_TRUE}, +@@ -216,10 +220,13 @@ + {"Admin", "admin", build_admin_body, true}, #endif - {"About", "about", build_about_body, OLSR_TRUE}, + {"About", "about", build_about_body, true}, +#ifndef SVEN_OLA_UNBLOAT - {"FOO", "cfgfile", build_cfgfile_body, OLSR_FALSE}, + {"FOO", "cfgfile", build_cfgfile_body, false}, +#endif /* SVEN_OLA_UNBLOAT */ - {NULL, NULL, NULL, OLSR_FALSE} + {NULL, NULL, NULL, false} }; +#ifndef SVEN_OLA_UNBLOAT static const struct static_bin_file_entry static_bin_files[] = { {"favicon.ico", favicon_ico, sizeof(favicon_ico)} , -@@ -230,6 +237,7 @@ +@@ -229,6 +236,7 @@ , {NULL, NULL, 0} }; @@ -71,7 +85,7 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/l static const struct static_txt_file_entry static_txt_files[] = { {"httpinfo.css", httpinfo_css}, -@@ -408,6 +416,7 @@ +@@ -407,6 +415,7 @@ } else if (!strcmp(req_type, "GET")) { int i = 0; @@ -79,7 +93,7 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/l for (i = 0; static_bin_files[i].filename; i++) { if (FILENREQ_MATCH(filename, static_bin_files[i].filename)) { break; -@@ -423,6 +432,7 @@ +@@ -422,6 +431,7 @@ } i = 0; @@ -87,7 +101,7 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/l while (static_txt_files[i].filename) { if (FILENREQ_MATCH(filename, static_txt_files[i].filename)) { break; -@@ -462,16 +472,22 @@ +@@ -461,16 +471,22 @@ snprintf(&body[size], sizeof(body) - size, "\n" "\n" "\n" @@ -100,10 +114,10 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/l "\n" "\n" "\n" +#ifndef SVEN_OLA_UNBLOAT - "\n" + "
\n" "\n" "\n" - "\n" "\n" - "\n" "
\n" "   olsr.org OLSR daemon\n" + "\n" "\"olsrd
\n", FRAMEWIDTH); + "\n" "\n", FRAMEWIDTH @@ -112,7 +126,7 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/l size += build_tabs(&body[size], sizeof(body) - size, i); size += build_frame(&body[size], sizeof(body) - size, "Current Routes", "routes", FRAMEWIDTH, tab_entries[i].build_body_cb); -@@ -855,7 +871,7 @@ +@@ -854,7 +870,7 @@ size += snprintf(&buf[size], bufsize - size, "Status: DOWN\n"); continue; } @@ -121,7 +135,7 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/l if (olsr_cnf->ip_version == AF_INET) { struct ipaddr_str addrbuf, maskbuf, bcastbuf; size += -@@ -868,6 +884,7 @@ +@@ -867,6 +883,7 @@ snprintf(&buf[size], bufsize - size, "\n" "IP: %s\n" "MCAST: %s\n" "\n" "\n", ip6_to_string(&addrbuf, &rifs->int6_addr.sin6_addr), ip6_to_string(&maskbuf, &rifs->int6_multaddr.sin6_addr)); } @@ -129,15 +143,15 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/l size += snprintf(&buf[size], bufsize - size, "\n" "MTU: %d\n" "WLAN: %s\n" "STATUS: UP\n" "\n", rifs->int_mtu, rifs->is_wireless ? "Yes" : "No"); -@@ -1116,6 +1133,7 @@ +@@ -1115,6 +1132,7 @@ build_host); } +#ifndef SVEN_OLA_UNBLOAT static int - build_cfgfile_body(char *buf, olsr_u32_t bufsize) + build_cfgfile_body(char *buf, uint32_t bufsize) { -@@ -1150,6 +1168,7 @@ +@@ -1149,6 +1167,7 @@ #endif return size; } @@ -145,9 +159,9 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/httpinfo/src/olsrd_httpinfo.c olsrd-0.5.6-r3/l static int check_allowed_ip(const struct allowed_net *const allowed_nets, const union olsr_ip_addr *const addr) -diff -Nur olsrd-0.5.6-r3.orig/lib/nameservice/src/nameservice.c olsrd-0.5.6-r3/lib/nameservice/src/nameservice.c ---- olsrd-0.5.6-r3.orig/lib/nameservice/src/nameservice.c 2008-12-03 10:01:07.000000000 +0100 -+++ olsrd-0.5.6-r3/lib/nameservice/src/nameservice.c 2008-12-03 10:10:52.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/lib/nameservice/src/nameservice.c olsrd-0-5-6-fc691af9a18d/lib/nameservice/src/nameservice.c +--- olsrd-0-5-6-fc691af9a18d.orig/lib/nameservice/src/nameservice.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/lib/nameservice/src/nameservice.c 2009-03-15 18:10:12.000000000 +0000 @@ -65,6 +65,11 @@ #include "mapwrite.h" #include "compat.h" @@ -179,16 +193,16 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/nameservice/src/nameservice.c olsrd-0.5.6-r3/l float my_lat = 0.0, my_lon = 0.0; @@ -102,9 +111,11 @@ static struct name_entry *my_macs = NULL; - static olsr_bool mac_table_changed = OLSR_TRUE; + static bool mac_table_changed = true; +#ifndef SVEN_OLA_UNBLOAT static struct list_node forwarder_list[HASHSIZE]; static struct name_entry *my_forwarders = NULL; - static olsr_bool forwarder_table_changed = OLSR_TRUE; + static bool forwarder_table_changed = true; +#endif /* SVEN_OLA_UNBLOAT */ struct list_node latlon_list[HASHSIZE]; - static olsr_bool latlon_table_changed = OLSR_TRUE; + static bool latlon_table_changed = true; @@ -138,7 +149,9 @@ GetWindowsDirectory(my_hosts_file, MAX_FILE - 12); GetWindowsDirectory(my_services_file, MAX_FILE - 12); @@ -323,8 +337,8 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/nameservice/src/nameservice.c olsrd-0.5.6-r3/l write_resolv_file(); /* if forwarder_table_changed */ +#endif /* SVEN_OLA_UNBLOAT */ write_hosts_file(); /* if name_table_changed */ - write_services_file(OLSR_FALSE); /* if service_table_changed */ - write_services_file(OLSR_TRUE); /* if mac_table_changed */ + write_services_file(false); /* if service_table_changed */ + write_services_file(true); /* if mac_table_changed */ @@ -693,11 +730,13 @@ pos = create_packet((struct name *)pos, my_name); i++; @@ -365,7 +379,7 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/nameservice/src/nameservice.c olsrd-0.5.6-r3/l /** @@ -1120,6 +1163,7 @@ #endif - name_table_changed = OLSR_FALSE; + name_table_changed = false; +#ifndef SVEN_OLA_UNBLOAT // Executes my_name_change_script after writing the hosts file @@ -392,7 +406,7 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/nameservice/src/nameservice.c olsrd-0.5.6-r3/l } } +#endif /* SVEN_OLA_UNBLOAT */ - mac_table_changed = OLSR_FALSE; + mac_table_changed = false; } else { +#ifndef SVEN_OLA_UNBLOAT @@ -404,7 +418,7 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/nameservice/src/nameservice.c olsrd-0.5.6-r3/l } } +#endif /* SVEN_OLA_UNBLOAT */ - service_table_changed = OLSR_FALSE; + service_table_changed = false; } } @@ -1222,6 +1271,7 @@ @@ -431,7 +445,7 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/nameservice/src/nameservice.c olsrd-0.5.6-r3/l { @@ -1341,6 +1393,7 @@ fclose(resolv); - forwarder_table_changed = OLSR_FALSE; + forwarder_table_changed = false; } +#endif /* SVEN_OLA_UNBLOAT */ @@ -439,48 +453,19 @@ diff -Nur olsrd-0.5.6-r3.orig/lib/nameservice/src/nameservice.c olsrd-0.5.6-r3/l * completely free a list of name_entries @@ -1359,9 +1412,11 @@ case NAME_HOST: - name_table_changed = OLSR_TRUE; + name_table_changed = true; break; +#ifndef SVEN_OLA_UNBLOAT case NAME_FORWARDER: - forwarder_table_changed = OLSR_TRUE; + forwarder_table_changed = true; break; +#endif /* SVEN_OLA_UNBLOAT */ case NAME_SERVICE: - service_table_changed = OLSR_TRUE; + service_table_changed = true; break; -@@ -1459,8 +1514,14 @@ - * these are then used by allowed_hostname_or_ip_in_service - * see regexec(3) for more infos */ - if (!is_service_wellformed(service_line)) { -+#ifdef SVEN_OLA_UNBLOAT -+ olsr_printf(1, "NAME PLUGIN: %s: Not 'x://y:z/|tcp|Text'\n", service_line); -+#endif /* SVEN_OLA_UNBLOAT */ - return OLSR_FALSE; - } else if (!allowed_hostname_or_ip_in_service(service_line, &(regmatch_t_service[1]))) { -+#ifdef SVEN_OLA_UNBLOAT -+ olsr_printf(1, "NAME PLUGIN: %s: IP/Addr not yours and not HNA\n", service_line); -+#endif /* SVEN_OLA_UNBLOAT */ - return OLSR_FALSE; - } - -diff -Nur olsrd-0.5.6-r3.orig/Makefile.inc olsrd-0.5.6-r3/Makefile.inc ---- olsrd-0.5.6-r3.orig/Makefile.inc 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/Makefile.inc 2008-12-03 10:01:07.000000000 +0100 -@@ -204,6 +204,10 @@ - $(warning Use CPPFLAGS instead of DEFINES for -D) - endif - -+ifeq ($(SVEN_OLA_UNBLOAT),1) -+CPPFLAGS += -DSVEN_OLA_UNBLOAT -DNODEBUG -+endif -+ - TAGFILE ?= src/TAGS - - help: -diff -Nur olsrd-0.5.6-r3.orig/src/apm.h olsrd-0.5.6-r3/src/apm.h ---- olsrd-0.5.6-r3.orig/src/apm.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/apm.h 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/apm.h olsrd-0-5-6-fc691af9a18d/src/apm.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/apm.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/apm.h 2009-03-15 18:10:12.000000000 +0000 @@ -41,6 +41,7 @@ #ifndef _OLSR_APM @@ -497,9 +482,64 @@ diff -Nur olsrd-0.5.6-r3.orig/src/apm.h olsrd-0.5.6-r3/src/apm.h /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/local.mk olsrd-0.5.6-r3/src/cfgparser/local.mk ---- olsrd-0.5.6-r3.orig/src/cfgparser/local.mk 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/cfgparser/local.mk 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/cfgfile_gen.c olsrd-0-5-6-fc691af9a18d/src/cfgparser/cfgfile_gen.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/cfgfile_gen.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/cfgparser/cfgfile_gen.c 2009-03-15 18:19:20.000000000 +0000 +@@ -57,7 +57,9 @@ + struct olsr_if *in = cnf->interfaces; + struct plugin_entry *pe = cnf->plugins; + struct plugin_param *pp; ++#ifndef SVEN_OLA_UNBLOAT + struct ip_prefix_list *ie = cnf->ipc_nets; ++#endif /* SVEN_OLA_UNBLOAT */ + struct olsr_lq_mult *mult; + + char ipv6_buf[100]; /* buffer for IPv6 inet_htop */ +@@ -125,6 +127,7 @@ + else + fprintf(fd, "Willingness\t%d\n\n", cnf->willingness); + ++#ifndef SVEN_OLA_UNBLOAT + /* IPC */ + fprintf(fd, "# Allow processes like the GUI front-end\n# to connect to the daemon.\n\n"); + fprintf(fd, "IpcConnect {\n"); +@@ -141,6 +144,7 @@ + } + + fprintf(fd, "}\n\n"); ++#endif /* SVEN_OLA_UNBLOAT */ + + /* Hysteresis */ + fprintf(fd, "# Hysteresis adds more robustness to the\n# link sensing.\n# Used by default. 'yes' or 'no'\n\n"); +@@ -350,7 +354,9 @@ + struct olsr_if *in = cnf->interfaces; + struct plugin_entry *pe = cnf->plugins; + struct plugin_param *pp; ++#ifndef SVEN_OLA_UNBLOAT + struct ip_prefix_list *ie = cnf->ipc_nets; ++#endif /* SVEN_OLA_UNBLOAT */ + struct olsr_lq_mult *mult; + + int size = 0; +@@ -409,6 +415,7 @@ + else + WRITE_TO_BUF("Willingness\t%d\n\n", cnf->willingness); + ++#ifndef SVEN_OLA_UNBLOAT + /* IPC */ + WRITE_TO_BUF("# Allow processes like the GUI front-end\n# to connect to the daemon.\n\n"); + WRITE_TO_BUF("IpcConnect {\n"); +@@ -424,6 +431,7 @@ + } + + WRITE_TO_BUF("}\n\n"); ++#endif /* SVEN_OLA_UNBLOAT */ + + /* Hysteresis */ + WRITE_TO_BUF("# Hysteresis adds more robustness to the\n# link sensing.\n# Used by default. 'yes' or 'no'\n\n"); +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/local.mk olsrd-0-5-6-fc691af9a18d/src/cfgparser/local.mk +--- olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/local.mk 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/cfgparser/local.mk 2009-03-15 18:10:12.000000000 +0000 @@ -41,8 +41,13 @@ C=$(if $(CFGDIR),$(CFGDIR)/) @@ -514,9 +554,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/local.mk olsrd-0.5.6-r3/src/cfgparse HDRS += $(foreach file,olsrd_conf oparse,$(C)$(file).h) $(C)oscan.c: $(C)oscan.lex $(C)Makefile -diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/olsrd_conf.c olsrd-0.5.6-r3/src/cfgparser/olsrd_conf.c ---- olsrd-0.5.6-r3.orig/src/cfgparser/olsrd_conf.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/cfgparser/olsrd_conf.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/olsrd_conf.c olsrd-0-5-6-fc691af9a18d/src/cfgparser/olsrd_conf.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/olsrd_conf.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/cfgparser/olsrd_conf.c 2009-03-15 18:10:12.000000000 +0000 @@ -81,11 +81,13 @@ } @@ -533,10 +573,10 @@ diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/olsrd_conf.c olsrd-0.5.6-r3/src/cfgp printf("Failed parsing \"%s\"\n", argv[1]); @@ -152,7 +154,9 @@ /* set various stuff */ - in->configured = OLSR_FALSE; + in->configured = false; in->interf = NULL; +#ifndef SVEN_OLA_UNBLOAT - in->host_emul = OLSR_FALSE; + in->host_emul = false; +#endif /* SVEN_OLA_UNBLOAT */ } return olsr_cnf; @@ -544,9 +584,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/olsrd_conf.c olsrd-0.5.6-r3/src/cfgp @@ -389,7 +393,9 @@ cnf->debug_level = DEF_DEBUGLVL; - cnf->no_fork = OLSR_FALSE; + cnf->no_fork = false; +#ifndef SVEN_OLA_UNBLOAT - cnf->host_emul = OLSR_FALSE; + cnf->host_emul = false; +#endif /* SVEN_OLA_UNBLOAT */ cnf->ip_version = AF_INET; cnf->ipsize = sizeof(struct in_addr); @@ -577,9 +617,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/olsrd_conf.c olsrd-0.5.6-r3/src/cfgp #if defined WIN32 struct ioinfo { -diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/oparse.y olsrd-0.5.6-r3/src/cfgparser/oparse.y ---- olsrd-0.5.6-r3.orig/src/cfgparser/oparse.y 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/cfgparser/oparse.y 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/oparse.y olsrd-0-5-6-fc691af9a18d/src/cfgparser/oparse.y +--- olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/oparse.y 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/cfgparser/oparse.y 2009-03-15 18:10:12.000000000 +0000 @@ -176,7 +176,6 @@ %token TOK_RTTABLE %token TOK_RTTABLE_DEFAULT @@ -701,9 +741,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/oparse.y olsrd-0.5.6-r3/src/cfgparse iifweight: TOK_IFWEIGHT TOK_INTEGER { int ifcnt = ifs_in_curr_cfg; -diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/oscan.lex olsrd-0.5.6-r3/src/cfgparser/oscan.lex ---- olsrd-0.5.6-r3.orig/src/cfgparser/oscan.lex 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/cfgparser/oscan.lex 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/oscan.lex olsrd-0-5-6-fc691af9a18d/src/cfgparser/oscan.lex +--- olsrd-0-5-6-fc691af9a18d.orig/src/cfgparser/oscan.lex 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/cfgparser/oscan.lex 2009-03-15 18:10:12.000000000 +0000 @@ -253,11 +253,6 @@ return TOK_NETLABEL; } @@ -728,12 +768,12 @@ diff -Nur olsrd-0.5.6-r3.orig/src/cfgparser/oscan.lex olsrd-0.5.6-r3/src/cfgpars "FIBMetric" { yylval = NULL; return TOK_FIBMETRIC; -diff -Nur olsrd-0.5.6-r3.orig/src/defs.h olsrd-0.5.6-r3/src/defs.h ---- olsrd-0.5.6-r3.orig/src/defs.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/defs.h 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/defs.h olsrd-0-5-6-fc691af9a18d/src/defs.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/defs.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/defs.h 2009-03-15 18:10:12.000000000 +0000 @@ -190,6 +190,8 @@ */ - unsigned long olsr_times(void); + clock_t olsr_times(void); +#ifndef SVEN_OLA_UNBLOAT + @@ -748,11 +788,11 @@ diff -Nur olsrd-0.5.6-r3.orig/src/defs.h olsrd-0.5.6-r3/src/defs.h /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/duplicate_set.c olsrd-0.5.6-r3/src/duplicate_set.c ---- olsrd-0.5.6-r3.orig/src/duplicate_set.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/duplicate_set.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/duplicate_set.c olsrd-0-5-6-fc691af9a18d/src/duplicate_set.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/duplicate_set.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/duplicate_set.c 2009-03-15 18:10:12.000000000 +0000 @@ -174,6 +174,7 @@ - return OLSR_FALSE; /* no duplicate */ + return false; /* no duplicate */ } +#ifndef SVEN_OLA_UNBLOAT @@ -767,9 +807,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/duplicate_set.c olsrd-0.5.6-r3/src/duplicate_s /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/hna_set.c olsrd-0.5.6-r3/src/hna_set.c ---- olsrd-0.5.6-r3.orig/src/hna_set.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/hna_set.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/hna_set.c olsrd-0-5-6-fc691af9a18d/src/hna_set.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/hna_set.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/hna_set.c 2009-03-15 18:10:12.000000000 +0000 @@ -279,6 +279,7 @@ * *@return nada @@ -786,9 +826,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/hna_set.c olsrd-0.5.6-r3/src/hna_set.c /** *Process incoming HNA message. -diff -Nur olsrd-0.5.6-r3.orig/src/interfaces.c olsrd-0.5.6-r3/src/interfaces.c ---- olsrd-0.5.6-r3.orig/src/interfaces.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/interfaces.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/interfaces.c olsrd-0-5-6-fc691af9a18d/src/interfaces.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/interfaces.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/interfaces.c 2009-03-15 18:10:12.000000000 +0000 @@ -93,12 +93,16 @@ OLSR_PRINTF(1, "\n ---- Interface configuration ---- \n\n"); /* Run trough all interfaces immedeatly */ @@ -823,14 +863,14 @@ diff -Nur olsrd-0.5.6-r3.orig/src/interfaces.c olsrd-0.5.6-r3/src/interfaces.c interf_n->configured = 0; +#ifndef SVEN_OLA_UNBLOAT - interf_n->host_emul = hemu ? OLSR_TRUE : OLSR_FALSE; + interf_n->host_emul = hemu ? true : false; +#endif /* SVEN_OLA_UNBLOAT */ strscpy(interf_n->name, name, name_size); interf_n->next = olsr_cnf->interfaces; -diff -Nur olsrd-0.5.6-r3.orig/src/interfaces.h olsrd-0.5.6-r3/src/interfaces.h ---- olsrd-0.5.6-r3.orig/src/interfaces.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/interfaces.h 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/interfaces.h olsrd-0-5-6-fc691af9a18d/src/interfaces.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/interfaces.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/interfaces.h 2009-03-15 18:10:12.000000000 +0000 @@ -196,7 +196,12 @@ struct interface *if_ifwithindex(const int if_index); @@ -845,41 +885,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/interfaces.h olsrd-0.5.6-r3/src/interfaces.h int add_ifchgf(int (*f) (struct interface *, int)); -diff -Nur olsrd-0.5.6-r3.orig/src/ipcalc.c olsrd-0.5.6-r3/src/ipcalc.c ---- olsrd-0.5.6-r3.orig/src/ipcalc.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/ipcalc.c 2008-12-03 10:01:07.000000000 +0100 -@@ -122,6 +122,7 @@ - return prefix; - } - -+#ifndef SVEN_OLA_UNBLOAT - const char * - olsr_ip_prefix_to_string(const struct olsr_ip_prefix *prefix) - { -@@ -148,6 +149,7 @@ - } - return rv; - } -+#endif /* SVEN_OLA_UNBLOAT */ - - /* see if the ipaddr is in the net. That is equivalent to the fact that the net part - * of both are equal. So we must compare the first bits. -diff -Nur olsrd-0.5.6-r3.orig/src/ipcalc.h olsrd-0.5.6-r3/src/ipcalc.h ---- olsrd-0.5.6-r3.orig/src/ipcalc.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/ipcalc.h 2008-12-03 10:01:07.000000000 +0100 -@@ -146,7 +146,9 @@ - return inet_ntop(olsr_cnf->ip_version, addr, buf->buf, sizeof(buf->buf)); - } - -+#ifndef SVEN_OLA_UNBLOAT - const char *olsr_ip_prefix_to_string(const struct olsr_ip_prefix *prefix); -+#endif /* SVEN_OLA_UNBLOAT */ - - static INLINE const char * - sockaddr4_to_string(struct ipaddr_str *const buf, const struct sockaddr *const addr) -diff -Nur olsrd-0.5.6-r3.orig/src/ipc_frontend.c olsrd-0.5.6-r3/src/ipc_frontend.c ---- olsrd-0.5.6-r3.orig/src/ipc_frontend.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/ipc_frontend.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/ipc_frontend.c olsrd-0-5-6-fc691af9a18d/src/ipc_frontend.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/ipc_frontend.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/ipc_frontend.c 2009-03-15 18:10:12.000000000 +0000 @@ -46,6 +46,7 @@ * */ @@ -896,9 +904,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/ipc_frontend.c olsrd-0.5.6-r3/src/ipc_frontend /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/ipc_frontend.h olsrd-0.5.6-r3/src/ipc_frontend.h ---- olsrd-0.5.6-r3.orig/src/ipc_frontend.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/ipc_frontend.h 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/ipc_frontend.h olsrd-0-5-6-fc691af9a18d/src/ipc_frontend.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/ipc_frontend.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/ipc_frontend.h 2009-03-15 18:10:12.000000000 +0000 @@ -48,6 +48,7 @@ #ifndef _OLSR_IPC @@ -915,10 +923,42 @@ diff -Nur olsrd-0.5.6-r3.orig/src/ipc_frontend.h olsrd-0.5.6-r3/src/ipc_frontend /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/link_set.c olsrd-0.5.6-r3/src/link_set.c ---- olsrd-0.5.6-r3.orig/src/link_set.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/link_set.c 2008-12-03 10:01:07.000000000 +0100 -@@ -746,6 +746,7 @@ +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/ipcalc.c olsrd-0-5-6-fc691af9a18d/src/ipcalc.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/ipcalc.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/ipcalc.c 2009-03-15 18:10:12.000000000 +0000 +@@ -121,6 +121,7 @@ + return prefix; + } + ++#ifndef SVEN_OLA_UNBLOAT + const char * + olsr_ip_prefix_to_string(const struct olsr_ip_prefix *prefix) + { +@@ -147,6 +148,7 @@ + } + return rv; + } ++#endif /* SVEN_OLA_UNBLOAT */ + + /* see if the ipaddr is in the net. That is equivalent to the fact that the net part + * of both are equal. So we must compare the first bits. +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/ipcalc.h olsrd-0-5-6-fc691af9a18d/src/ipcalc.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/ipcalc.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/ipcalc.h 2009-03-15 18:10:12.000000000 +0000 +@@ -146,7 +146,9 @@ + return inet_ntop(olsr_cnf->ip_version, addr, buf->buf, sizeof(buf->buf)); + } + ++#ifndef SVEN_OLA_UNBLOAT + const char *olsr_ip_prefix_to_string(const struct olsr_ip_prefix *prefix); ++#endif /* SVEN_OLA_UNBLOAT */ + + static INLINE const char * + sockaddr4_to_string(struct ipaddr_str *const buf, const struct sockaddr *const addr) +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/link_set.c olsrd-0-5-6-fc691af9a18d/src/link_set.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/link_set.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/link_set.c 2009-03-15 18:10:12.000000000 +0000 +@@ -761,6 +761,7 @@ return ret; } @@ -926,7 +966,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/link_set.c olsrd-0.5.6-r3/src/link_set.c void olsr_print_link_set(void) { -@@ -767,6 +768,7 @@ +@@ -782,6 +783,7 @@ } OLSR_FOR_ALL_LINK_ENTRIES_END(walker); #endif } @@ -934,9 +974,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/link_set.c olsrd-0.5.6-r3/src/link_set.c /* * called for every LQ HELLO message. -diff -Nur olsrd-0.5.6-r3.orig/src/linux/apm.c olsrd-0.5.6-r3/src/linux/apm.c ---- olsrd-0.5.6-r3.orig/src/linux/apm.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/linux/apm.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/linux/apm.c olsrd-0-5-6-fc691af9a18d/src/linux/apm.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/linux/apm.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/linux/apm.c 2009-03-15 18:10:12.000000000 +0000 @@ -44,6 +44,7 @@ * Acpi-Power Enlightenment epplet */ @@ -953,25 +993,66 @@ diff -Nur olsrd-0.5.6-r3.orig/src/linux/apm.c olsrd-0.5.6-r3/src/linux/apm.c /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/linux/kernel_routes.c olsrd-0.5.6-r3/src/linux/kernel_routes.c ---- olsrd-0.5.6-r3.orig/src/linux/kernel_routes.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/linux/kernel_routes.c 2008-12-03 10:01:07.000000000 +0100 -@@ -144,10 +144,12 @@ - h = NLMSG_NEXT(h, ret); - } - } +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/linux/kernel_routes.c olsrd-0-5-6-fc691af9a18d/src/linux/kernel_routes.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/linux/kernel_routes.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/linux/kernel_routes.c 2009-03-15 18:22:31.000000000 +0000 +@@ -288,11 +288,13 @@ + if (rt_ret > 0) rt_ret = 0;//0 means successful recovery + else rt_ret = -1;//unrecoverable error + } +#ifndef SVEN_OLA_UNBLOAT - if (0 <= ret && olsr_cnf->ipc_connections > 0) { - ipc_route_send_rtentry(&rt->rt_dst.prefix, &nexthop->gateway, metric, RTM_NEWROUTE == cmd, + //send ipc update on success + if ( ( cmd != RTM_NEWRULE ) & ( cmd != RTM_DELRULE ) & (flag = RT_ORIG_REQUEST) & (0 <= rt_ret && olsr_cnf->ipc_connections > 0)) { + ipc_route_send_rtentry(&rt->rt_dst.prefix, &nexthop->gateway, metric, RTM_NEWROUTE == cmd, if_ifwithindex_name(nexthop->iif_index)); - } -+#endif /* SVEN_OLA_UNBLOAT */ } - return ret; ++#endif /* SVEN_OLA_UNBLOAT */ + if (rt_ret == -2) olsr_syslog(OLSR_LOG_ERR,"no rtnetlink response was received! (no more system ressources?, everything may happen now ...)"); + return rt_ret; } -diff -Nur olsrd-0.5.6-r3.orig/src/linux/net.c olsrd-0.5.6-r3/src/linux/net.c ---- olsrd-0.5.6-r3.orig/src/linux/net.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/linux/net.c 2008-12-03 10:01:07.000000000 +0100 +@@ -330,7 +332,9 @@ + int rslt; + #endif /* LINUX_POLICY_ROUTING */ + ++#ifndef SVEN_OLA_UNBLOAT + OLSR_PRINTF(2, "KERN: Adding %s\n", olsr_rtp_to_string(rt->rt_best)); ++#endif /* SVEN_OLA_UNBLOAT */ + + #if !LINUX_POLICY_ROUTING + memset(&kernel_route, 0, sizeof(struct rtentry)); +@@ -404,7 +408,9 @@ + struct in6_rtmsg kernel_route; + int rslt; + ++#ifndef SVEN_OLA_UNBLOAT + OLSR_PRINTF(2, "KERN: Adding %s\n", olsr_rtp_to_string(rt->rt_best)); ++#endif /* SVEN_OLA_UNBLOAT */ + + memset(&kernel_route, 0, sizeof(struct in6_rtmsg)); + +@@ -457,7 +463,9 @@ + int rslt; + #endif /* LINUX_POLICY_ROUTING */ + ++#ifndef SVEN_OLA_UNBLOAT + OLSR_PRINTF(2, "KERN: Deleting %s\n", olsr_rt_to_string(rt)); ++#endif /* SVEN_OLA_UNBLOAT */ + + #if !LINUX_POLICY_ROUTING + memset(&kernel_route, 0, sizeof(struct rtentry)); +@@ -524,7 +532,9 @@ + int rslt; + #endif /* LINUX_POLICY_ROUTING */ + ++#ifndef SVEN_OLA_UNBLOAT + OLSR_PRINTF(2, "KERN: Deleting %s\n", olsr_rt_to_string(rt)); ++#endif /* SVEN_OLA_UNBLOAT */ + + #if !LINUX_POLICY_ROUTING + memset(&kernel_route, 0, sizeof(struct in6_rtmsg)); +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/linux/net.c olsrd-0-5-6-fc691af9a18d/src/linux/net.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/linux/net.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/linux/net.c 2009-03-15 18:10:12.000000000 +0000 @@ -69,8 +69,10 @@ #define SIOCGIWRATE 0x8B21 /* get default bit rate (bps) */ @@ -1168,9 +1249,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/linux/net.c olsrd-0.5.6-r3/src/linux/net.c /** *Creates a nonblocking broadcast socket. *@param sa sockaddr struct. Used for bind(2). -diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin.c olsrd-0.5.6-r3/src/lq_plugin.c ---- olsrd-0.5.6-r3.orig/src/lq_plugin.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/lq_plugin.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin.c olsrd-0-5-6-fc691af9a18d/src/lq_plugin.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/lq_plugin.c 2009-03-15 18:10:12.000000000 +0000 @@ -67,12 +67,18 @@ init_lq_handler_tree(void) { @@ -1238,9 +1319,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin.c olsrd-0.5.6-r3/src/lq_plugin.c { struct link_entry *h; -diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin_default_float.c olsrd-0.5.6-r3/src/lq_plugin_default_float.c ---- olsrd-0.5.6-r3.orig/src/lq_plugin_default_float.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/lq_plugin_default_float.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin_default_float.c olsrd-0-5-6-fc691af9a18d/src/lq_plugin_default_float.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin_default_float.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/lq_plugin_default_float.c 2009-03-15 18:10:12.000000000 +0000 @@ -39,6 +39,7 @@ * */ @@ -1257,9 +1338,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin_default_float.c olsrd-0.5.6-r3/src/l /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin_default_float.h olsrd-0.5.6-r3/src/lq_plugin_default_float.h ---- olsrd-0.5.6-r3.orig/src/lq_plugin_default_float.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/lq_plugin_default_float.h 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin_default_float.h olsrd-0-5-6-fc691af9a18d/src/lq_plugin_default_float.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin_default_float.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/lq_plugin_default_float.h 2009-03-15 18:10:12.000000000 +0000 @@ -39,6 +39,7 @@ * */ @@ -1276,9 +1357,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin_default_float.h olsrd-0.5.6-r3/src/l /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin_default_fpm.c olsrd-0.5.6-r3/src/lq_plugin_default_fpm.c ---- olsrd-0.5.6-r3.orig/src/lq_plugin_default_fpm.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/lq_plugin_default_fpm.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin_default_fpm.c olsrd-0-5-6-fc691af9a18d/src/lq_plugin_default_fpm.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin_default_fpm.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/lq_plugin_default_fpm.c 2009-03-15 18:10:12.000000000 +0000 @@ -39,6 +39,7 @@ * */ @@ -1295,9 +1376,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin_default_fpm.c olsrd-0.5.6-r3/src/lq_ /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin_default_fpm.h olsrd-0.5.6-r3/src/lq_plugin_default_fpm.h ---- olsrd-0.5.6-r3.orig/src/lq_plugin_default_fpm.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/lq_plugin_default_fpm.h 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin_default_fpm.h olsrd-0-5-6-fc691af9a18d/src/lq_plugin_default_fpm.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/lq_plugin_default_fpm.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/lq_plugin_default_fpm.h 2009-03-15 18:10:12.000000000 +0000 @@ -39,6 +39,7 @@ * */ @@ -1314,10 +1395,10 @@ diff -Nur olsrd-0.5.6-r3.orig/src/lq_plugin_default_fpm.h olsrd-0.5.6-r3/src/lq_ /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c ---- olsrd-0.5.6-r3.orig/src/main.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/main.c 2008-12-03 10:01:07.000000000 +0100 -@@ -243,13 +243,17 @@ +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/main.c olsrd-0-5-6-fc691af9a18d/src/main.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/main.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/main.c 2009-03-15 18:10:12.000000000 +0000 +@@ -258,13 +258,17 @@ /* * Print configuration */ @@ -1335,7 +1416,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c /* * socket for ioctl calls -@@ -285,7 +289,9 @@ +@@ -300,7 +304,9 @@ /* *enable ip forwarding on host */ @@ -1345,7 +1426,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c /* Initialize parser */ olsr_init_parser(); -@@ -303,6 +309,7 @@ +@@ -318,6 +324,7 @@ *Set up willingness/APM */ if (olsr_cnf->willingness_auto) { @@ -1353,7 +1434,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c if (apm_init() < 0) { OLSR_PRINTF(1, "Could not read APM info - setting default willingness(%d)\n", WILL_DEFAULT); -@@ -311,10 +318,13 @@ +@@ -326,10 +333,13 @@ olsr_cnf->willingness_auto = 0; olsr_cnf->willingness = WILL_DEFAULT; } else { @@ -1367,7 +1448,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c } /* Initialize net */ -@@ -342,9 +352,11 @@ +@@ -364,9 +374,11 @@ /* Initialize the IPC socket */ @@ -1379,7 +1460,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c /* Initialisation of different tables to be used. */ olsr_init_tables(); -@@ -450,9 +462,11 @@ +@@ -489,9 +501,11 @@ OLSR_PRINTF(1, "Closing sockets...\n"); /* front-end IPC socket */ @@ -1391,7 +1472,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c /* OLSR sockets */ for (ifn = ifnet; ifn; ifn = ifn->int_next) -@@ -462,7 +476,9 @@ +@@ -501,7 +515,9 @@ olsr_close_plugins(); /* Reset network settings */ @@ -1401,7 +1482,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c /* ioctl socket */ close(olsr_cnf->ioctl_s); -@@ -498,7 +514,11 @@ +@@ -542,7 +558,11 @@ "usage: olsrd [-f ] [ -i interface1 interface2 ... ]\n" " [-d ] [-ipv6] [-multi ]\n" " [-lql ] [-lqw ] [-lqnt ]\n" @@ -1413,14 +1494,14 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c " [-hint ] [-tcint ]\n" " [-midint ] [-hnaint ]\n" " [-T ] [-nofork] [-hemu ]\n" " [-lql ] [-lqa ]\n"); -@@ -662,12 +682,20 @@ +@@ -706,12 +726,20 @@ olsr_exit(__func__, EXIT_FAILURE); } printf("Queuing if %s\n", *argv); +#ifdef SVEN_OLA_UNBLOAT + queue_if(*argv); +#else /* SVEN_OLA_UNBLOAT */ - queue_if(*argv, OLSR_FALSE); + queue_if(*argv, false); +#endif /* SVEN_OLA_UNBLOAT */ while ((argc - 1) && (argv[1][0] != '-')) { @@ -1429,12 +1510,12 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c +#ifdef SVEN_OLA_UNBLOAT + queue_if(*argv); +#else /* SVEN_OLA_UNBLOAT */ - queue_if(*argv, OLSR_FALSE); + queue_if(*argv, false); +#endif /* SVEN_OLA_UNBLOAT */ } continue; -@@ -729,7 +757,7 @@ +@@ -773,7 +801,7 @@ sscanf(*argv, "%f", &cnf->pollrate); continue; } @@ -1443,7 +1524,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c /* * Should we display the contents of packages beeing sent? */ -@@ -753,6 +781,7 @@ +@@ -797,6 +825,7 @@ cnf->ipc_connections = 1; continue; } @@ -1451,7 +1532,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c /* * IPv6 multicast addr -@@ -770,7 +799,7 @@ +@@ -814,7 +843,7 @@ continue; } @@ -1460,7 +1541,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c /* * Host emulation */ -@@ -798,6 +827,7 @@ +@@ -842,6 +871,7 @@ continue; } @@ -1468,9 +1549,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/main.c olsrd-0.5.6-r3/src/main.c /* * Delete possible default GWs -diff -Nur olsrd-0.5.6-r3.orig/src/neighbor_table.c olsrd-0.5.6-r3/src/neighbor_table.c ---- olsrd-0.5.6-r3.orig/src/neighbor_table.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/neighbor_table.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/neighbor_table.c olsrd-0-5-6-fc691af9a18d/src/neighbor_table.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/neighbor_table.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/neighbor_table.c 2009-03-15 18:10:12.000000000 +0000 @@ -362,6 +362,7 @@ * *@return nada @@ -1487,9 +1568,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/neighbor_table.c olsrd-0.5.6-r3/src/neighbor_t /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/net_olsr.c olsrd-0.5.6-r3/src/net_olsr.c ---- olsrd-0.5.6-r3.orig/src/net_olsr.c 2008-12-03 10:01:07.000000000 +0100 -+++ olsrd-0.5.6-r3/src/net_olsr.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/net_olsr.c olsrd-0-5-6-fc691af9a18d/src/net_olsr.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/net_olsr.c 2009-03-15 17:06:26.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/net_olsr.c 2009-03-15 18:10:12.000000000 +0000 @@ -44,7 +44,9 @@ #include "log.h" #include "olsr.h" @@ -1528,9 +1609,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/net_olsr.c olsrd-0.5.6-r3/src/net_olsr.c retval = -1; } } -diff -Nur olsrd-0.5.6-r3.orig/src/olsr.c olsrd-0.5.6-r3/src/olsr.c ---- olsrd-0.5.6-r3.orig/src/olsr.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/olsr.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/olsr.c olsrd-0-5-6-fc691af9a18d/src/olsr.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/olsr.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/olsr.c 2009-03-15 18:10:12.000000000 +0000 @@ -149,7 +149,9 @@ return; @@ -1559,7 +1640,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/olsr.c olsrd-0.5.6-r3/src/olsr.c for (tmp_pc_list = pcf_list; tmp_pc_list != NULL; tmp_pc_list = tmp_pc_list->next) { tmp_pc_list->function(changes_neighborhood, changes_topology, changes_hna); @@ -415,12 +418,15 @@ - olsr_u8_t + uint8_t olsr_calculate_willingness(void) { +#ifndef SVEN_OLA_UNBLOAT @@ -1585,7 +1666,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/olsr.c olsrd-0.5.6-r3/src/olsr.c +#ifndef SVEN_OLA_UNBLOAT const char * - olsr_msgtype_to_string(olsr_u8_t msgtype) + olsr_msgtype_to_string(uint8_t msgtype) { @@ -508,6 +518,7 @@ snprintf(type, sizeof(type), "UNKNOWN(%d)", status); @@ -1611,45 +1692,70 @@ diff -Nur olsrd-0.5.6-r3.orig/src/olsr.c olsrd-0.5.6-r3/src/olsr.c /** *Wrapper for printf that prints to a specific -diff -Nur olsrd-0.5.6-r3.orig/src/olsr_cfg.h olsrd-0.5.6-r3/src/olsr_cfg.h ---- olsrd-0.5.6-r3.orig/src/olsr_cfg.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/olsr_cfg.h 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/olsr.h olsrd-0-5-6-fc691af9a18d/src/olsr.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/olsr.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/olsr.h 2009-03-15 18:10:12.000000000 +0000 +@@ -72,15 +72,21 @@ + + uint8_t olsr_calculate_willingness(void); + ++#ifndef SVEN_OLA_UNBLOAT + const char *olsr_msgtype_to_string(uint8_t); + + const char *olsr_link_to_string(uint8_t); + + const char *olsr_status_to_string(uint8_t); ++#endif /* SVEN_OLA_UNBLOAT */ + + void olsr_exit(const char *, int); + ++#ifdef SVEN_OLA_UNBLOAT ++#define olsr_malloc(size, msg) calloc(1, size) ++#else /* SVEN_OLA_UNBLOAT */ + void *olsr_malloc(size_t, const char *); ++#endif /* SVEN_OLA_UNBLOAT */ + + int olsr_printf(int, const char *, ...) __attribute__ ((format(printf, 2, 3))); + +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/olsr_cfg.h olsrd-0-5-6-fc691af9a18d/src/olsr_cfg.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/olsr_cfg.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/olsr_cfg.h 2009-03-15 18:10:12.000000000 +0000 @@ -140,8 +140,10 @@ char *name; char *config; - olsr_bool configured; + bool configured; +#ifndef SVEN_OLA_UNBLOAT - olsr_bool host_emul; + bool host_emul; union olsr_ip_addr hemu_ip; -+#endif /* SVEN_OLA_UNBLOAT */ ++#endif /* SVEN_OLA_UNBLOAT */ struct interface *interf; struct if_config_options *cnf; struct olsr_if *next; @@ -183,7 +185,9 @@ struct olsrd_config { int debug_level; - olsr_bool no_fork; + bool no_fork; +#ifndef SVEN_OLA_UNBLOAT - olsr_bool host_emul; -+#endif /* SVEN_OLA_UNBLOAT */ + bool host_emul; ++#endif /* SVEN_OLA_UNBLOAT */ int ip_version; - olsr_bool allow_no_interfaces; - olsr_u16_t tos; + bool allow_no_interfaces; + uint16_t tos; @@ -191,13 +195,17 @@ - olsr_u8_t rttable_default; - olsr_u8_t willingness; - olsr_bool willingness_auto; + uint8_t rttable_default; + uint8_t willingness; + bool willingness_auto; +#ifndef SVEN_OLA_UNBLOAT int ipc_connections; -+#endif /* SVEN_OLA_UNBLOAT */ - olsr_bool use_hysteresis; ++#endif /* SVEN_OLA_UNBLOAT */ + bool use_hysteresis; olsr_fib_metric_options fib_metric; struct hyst_param hysteresis_param; struct plugin_entry *plugins; struct ip_prefix_list *hna_entries; +#ifndef SVEN_OLA_UNBLOAT struct ip_prefix_list *ipc_nets; -+#endif /* SVEN_OLA_UNBLOAT */ ++#endif /* SVEN_OLA_UNBLOAT */ struct olsr_if *interfaces; float pollrate; float nic_chgs_pollrate; @@ -1663,34 +1769,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/olsr_cfg.h olsrd-0.5.6-r3/src/olsr_cfg.h int olsrd_write_cnf(struct olsrd_config *, const char *); -diff -Nur olsrd-0.5.6-r3.orig/src/olsr.h olsrd-0.5.6-r3/src/olsr.h ---- olsrd-0.5.6-r3.orig/src/olsr.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/olsr.h 2008-12-03 10:01:07.000000000 +0100 -@@ -72,15 +72,21 @@ - - olsr_u8_t olsr_calculate_willingness(void); - -+#ifndef SVEN_OLA_UNBLOAT - const char *olsr_msgtype_to_string(olsr_u8_t); - - const char *olsr_link_to_string(olsr_u8_t); - - const char *olsr_status_to_string(olsr_u8_t); -+#endif /* SVEN_OLA_UNBLOAT */ - - void olsr_exit(const char *, int); - -+#ifdef SVEN_OLA_UNBLOAT -+#define olsr_malloc(size, msg) calloc(1, size) -+#else /* SVEN_OLA_UNBLOAT */ - void *olsr_malloc(size_t, const char *); -+#endif /* SVEN_OLA_UNBLOAT */ - - int olsr_printf(int, const char *, ...) __attribute__ ((format(printf, 2, 3))); - -diff -Nur olsrd-0.5.6-r3.orig/src/parser.c olsrd-0.5.6-r3/src/parser.c ---- olsrd-0.5.6-r3.orig/src/parser.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/parser.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/parser.c olsrd-0-5-6-fc691af9a18d/src/parser.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/parser.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/parser.c 2009-03-15 18:10:12.000000000 +0000 @@ -51,7 +51,9 @@ #include "rebuild_packet.h" #include "net_os.h" @@ -1712,9 +1793,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/parser.c olsrd-0.5.6-r3/src/parser.c if (olsr_cnf->ip_version == AF_INET) msgsize = ntohs(m->v4.olsr_msgsize); -diff -Nur olsrd-0.5.6-r3.orig/src/print_packet.c olsrd-0.5.6-r3/src/print_packet.c ---- olsrd-0.5.6-r3.orig/src/print_packet.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/print_packet.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/print_packet.c olsrd-0-5-6-fc691af9a18d/src/print_packet.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/print_packet.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/print_packet.c 2009-03-15 18:10:12.000000000 +0000 @@ -39,6 +39,7 @@ * */ @@ -1731,23 +1812,23 @@ diff -Nur olsrd-0.5.6-r3.orig/src/print_packet.c olsrd-0.5.6-r3/src/print_packet /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/process_routes.c olsrd-0.5.6-r3/src/process_routes.c ---- olsrd-0.5.6-r3.orig/src/process_routes.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/process_routes.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/process_routes.c olsrd-0-5-6-fc691af9a18d/src/process_routes.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/process_routes.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/process_routes.c 2009-03-15 18:11:42.000000000 +0000 @@ -159,6 +159,7 @@ static void olsr_delete_kernel_route(struct rt_entry *rt) { +#ifndef SVEN_OLA_UNBLOAT if (!olsr_cnf->host_emul) { - olsr_16_t error = olsr_cnf->ip_version == AF_INET ? olsr_delroute_function(rt) : olsr_delroute6_function(rt); + int16_t error = olsr_cnf->ip_version == AF_INET ? olsr_delroute_function(rt) : olsr_delroute6_function(rt); @@ -170,6 +171,12 @@ olsr_syslog(OLSR_LOG_ERR, "Delete route %s: %s", routestr, err_msg); } } +#else /* SVEN_OLA_UNBLOAT */ -+ olsr_16_t error = olsr_cnf->ip_version == AF_INET ? olsr_delroute_function(rt) : olsr_delroute6_function(rt); ++ int16_t error = olsr_cnf->ip_version == AF_INET ? olsr_delroute_function(rt) : olsr_delroute6_function(rt); + if (0 > error) { + olsr_syslog(OLSR_LOG_ERR, "Delete route: %s", strerror(errno)); + } @@ -1761,14 +1842,14 @@ diff -Nur olsrd-0.5.6-r3.orig/src/process_routes.c olsrd-0.5.6-r3/src/process_ro +#ifndef SVEN_OLA_UNBLOAT if (!olsr_cnf->host_emul) { - olsr_16_t error = (olsr_cnf->ip_version == AF_INET) ? olsr_addroute_function(rt) : olsr_addroute6_function(rt); + int16_t error = (olsr_cnf->ip_version == AF_INET) ? olsr_addroute_function(rt) : olsr_addroute6_function(rt); @@ -199,6 +207,14 @@ rt->rt_metric = rt->rt_best->rtp_metric; } } +#else /* SVEN_OLA_UNBLOAT */ -+ olsr_16_t error = olsr_cnf->ip_version == AF_INET ? olsr_addroute_function(rt) : olsr_addroute6_function(rt); ++ int16_t error = olsr_cnf->ip_version == AF_INET ? olsr_addroute_function(rt) : olsr_addroute6_function(rt); + if (0 > error) { + olsr_syslog(OLSR_LOG_ERR, "Add route: %s", strerror(errno)); + } else { @@ -1787,9 +1868,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/process_routes.c olsrd-0.5.6-r3/src/process_ro olsr_print_routing_table(&routingtree); #endif } -diff -Nur olsrd-0.5.6-r3.orig/src/rebuild_packet.c olsrd-0.5.6-r3/src/rebuild_packet.c ---- olsrd-0.5.6-r3.orig/src/rebuild_packet.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/rebuild_packet.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/rebuild_packet.c olsrd-0-5-6-fc691af9a18d/src/rebuild_packet.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/rebuild_packet.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/rebuild_packet.c 2009-03-15 18:10:12.000000000 +0000 @@ -60,7 +60,11 @@ mid_chgestruct(struct mid_message *mmsg, const union olsr_message *m) { @@ -1834,9 +1915,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/rebuild_packet.c olsrd-0.5.6-r3/src/rebuild_pa } } -diff -Nur olsrd-0.5.6-r3.orig/src/routing_table.c olsrd-0.5.6-r3/src/routing_table.c ---- olsrd-0.5.6-r3.orig/src/routing_table.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/routing_table.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/routing_table.c olsrd-0-5-6-fc691af9a18d/src/routing_table.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/routing_table.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/routing_table.c 2009-03-15 18:10:12.000000000 +0000 @@ -623,6 +623,7 @@ /** * format a route entry into a buffer @@ -1867,12 +1948,12 @@ diff -Nur olsrd-0.5.6-r3.orig/src/routing_table.c olsrd-0.5.6-r3/src/routing_tab /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/routing_table.h olsrd-0.5.6-r3/src/routing_table.h ---- olsrd-0.5.6-r3.orig/src/routing_table.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/routing_table.h 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/routing_table.h olsrd-0-5-6-fc691af9a18d/src/routing_table.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/routing_table.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/routing_table.h 2009-03-15 18:10:12.000000000 +0000 @@ -210,9 +210,11 @@ - olsr_bool olsr_cmp_rt(const struct rt_entry *, const struct rt_entry *); - olsr_u8_t olsr_fib_metric(const struct rt_metric *); + bool olsr_cmp_rt(const struct rt_entry *, const struct rt_entry *); + uint8_t olsr_fib_metric(const struct rt_metric *); +#ifndef SVEN_OLA_UNBLOAT char *olsr_rt_to_string(const struct rt_entry *); @@ -1882,9 +1963,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/routing_table.h olsrd-0.5.6-r3/src/routing_tab const struct rt_nexthop *olsr_get_nh(const struct rt_entry *); -diff -Nur olsrd-0.5.6-r3.orig/src/tc_set.c olsrd-0.5.6-r3/src/tc_set.c ---- olsrd-0.5.6-r3.orig/src/tc_set.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/tc_set.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/tc_set.c olsrd-0-5-6-fc691af9a18d/src/tc_set.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/tc_set.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/tc_set.c 2009-03-15 18:10:12.000000000 +0000 @@ -336,6 +336,7 @@ /** * Format tc_edge contents into a buffer. @@ -1901,7 +1982,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/tc_set.c olsrd-0.5.6-r3/src/tc_set.c /** * Wrapper for the timer callback. -@@ -685,6 +687,7 @@ +@@ -686,6 +688,7 @@ /** * Print the topology table to stdout */ @@ -1909,7 +1990,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/tc_set.c olsrd-0.5.6-r3/src/tc_set.c void olsr_print_tc_table(void) { -@@ -710,6 +713,7 @@ +@@ -711,6 +714,7 @@ } OLSR_FOR_ALL_TC_ENTRIES_END(tc); #endif } @@ -1917,22 +1998,22 @@ diff -Nur olsrd-0.5.6-r3.orig/src/tc_set.c olsrd-0.5.6-r3/src/tc_set.c /* * calculate the border IPs of a tc edge set according to the border flags -diff -Nur olsrd-0.5.6-r3.orig/src/tc_set.h olsrd-0.5.6-r3/src/tc_set.h ---- olsrd-0.5.6-r3.orig/src/tc_set.h 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/tc_set.h 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/tc_set.h olsrd-0-5-6-fc691af9a18d/src/tc_set.h +--- olsrd-0-5-6-fc691af9a18d.orig/src/tc_set.h 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/tc_set.h 2009-03-15 18:10:12.000000000 +0000 @@ -157,7 +157,9 @@ /* tc_edge_entry manipulation */ - olsr_bool olsr_delete_outdated_tc_edges(struct tc_entry *); + bool olsr_delete_outdated_tc_edges(struct tc_entry *); +#ifndef SVEN_OLA_UNBLOAT char *olsr_tc_edge_to_string(struct tc_edge_entry *); +#endif /* SVEN_OLA_UNBLOAT */ struct tc_edge_entry *olsr_lookup_tc_edge(struct tc_entry *, union olsr_ip_addr *); - struct tc_edge_entry *olsr_add_tc_edge_entry(struct tc_entry *, union olsr_ip_addr *, olsr_u16_t); + struct tc_edge_entry *olsr_add_tc_edge_entry(struct tc_entry *, union olsr_ip_addr *, uint16_t); void olsr_delete_tc_entry(struct tc_entry *); -diff -Nur olsrd-0.5.6-r3.orig/src/two_hop_neighbor_table.c olsrd-0.5.6-r3/src/two_hop_neighbor_table.c ---- olsrd-0.5.6-r3.orig/src/two_hop_neighbor_table.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/two_hop_neighbor_table.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/two_hop_neighbor_table.c olsrd-0-5-6-fc691af9a18d/src/two_hop_neighbor_table.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/two_hop_neighbor_table.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/two_hop_neighbor_table.c 2009-03-15 18:10:12.000000000 +0000 @@ -203,6 +203,8 @@ return NULL; } @@ -1950,9 +2031,9 @@ diff -Nur olsrd-0.5.6-r3.orig/src/two_hop_neighbor_table.c olsrd-0.5.6-r3/src/tw /* * Local Variables: -diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c ---- olsrd-0.5.6-r3.orig/src/unix/ifnet.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/unix/ifnet.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/unix/ifnet.c olsrd-0-5-6-fc691af9a18d/src/unix/ifnet.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/unix/ifnet.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/unix/ifnet.c 2009-03-15 18:13:59.000000000 +0000 @@ -70,6 +70,8 @@ #define BUFSPACE (127*1024) /* max. input buffer size to request */ @@ -1996,7 +2077,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c ifp = iface->interf; -@@ -279,7 +287,9 @@ +@@ -281,7 +289,9 @@ } else /* IP version 4 */ { @@ -2006,8 +2087,20 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c /* Check interface address (IPv4) */ if (ioctl(olsr_cnf->ioctl_s, SIOCGIFADDR, &ifr) < 0) { OLSR_PRINTF(1, "\tCould not get address of interface - removing it\n"); -@@ -301,7 +311,9 @@ +@@ -294,17 +304,21 @@ + if (memcmp + (&((struct sockaddr_in *)&ifp->int_addr)->sin_addr.s_addr, &((struct sockaddr_in *)&ifr.ifr_addr)->sin_addr.s_addr, + olsr_cnf->ipsize) != 0) { ++#ifndef SVEN_OLA_UNBLOAT + /* New address */ + OLSR_PRINTF(1, "IPv4 address changed for %s\n", ifr.ifr_name); + OLSR_PRINTF(1, "\tOld:%s\n", ip4_to_string(&buf, ifp->int_addr.sin_addr)); + OLSR_PRINTF(1, "\tNew:%s\n", sockaddr4_to_string(&buf, &ifr.ifr_addr)); ++#endif /* SVEN_OLA_UNBLOAT */ + ifp->int_addr = *(struct sockaddr_in *)&ifr.ifr_addr; + /* deactivated to prevent change of originator IP */ + #if 0 if (memcmp(&olsr_cnf->main_addr, &ifp->ip_addr, olsr_cnf->ipsize) == 0) { OLSR_PRINTF(1, "New main address: %s\n", sockaddr4_to_string(&buf, &ifr.ifr_addr)); +#ifndef SVEN_OLA_UNBLOAT @@ -2015,8 +2108,8 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c +#endif /* SVEN_OLA_UNBLOAT */ memcpy(&olsr_cnf->main_addr, &((struct sockaddr_in *)&ifr.ifr_addr)->sin_addr.s_addr, olsr_cnf->ipsize); } - -@@ -363,7 +375,9 @@ + #endif +@@ -366,7 +380,9 @@ remove_interface: OLSR_PRINTF(1, "Removing interface %s\n", iface->name); @@ -2026,7 +2119,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c olsr_delete_link_entry_by_ip(&ifp->ip_addr); -@@ -393,10 +407,14 @@ +@@ -398,10 +414,14 @@ memset(&olsr_cnf->main_addr, 0, olsr_cnf->ipsize); OLSR_PRINTF(1, "No more interfaces...\n"); } else { @@ -2040,8 +2133,8 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c +#endif /* SVEN_OLA_UNBLOAT */ } } - -@@ -420,7 +438,9 @@ + #endif +@@ -425,7 +445,9 @@ if ((ifnet == NULL) && (!olsr_cnf->allow_no_interfaces)) { OLSR_PRINTF(1, "No more active interfaces - exiting.\n"); @@ -2051,7 +2144,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c olsr_cnf->exit_value = EXIT_FAILURE; kill(getpid(), SIGINT); } -@@ -429,6 +449,8 @@ +@@ -434,6 +456,8 @@ } @@ -2060,7 +2153,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c /** * Initializes the special interface used in * host-client emulation -@@ -578,6 +600,7 @@ +@@ -583,6 +607,7 @@ return 1; } @@ -2068,7 +2161,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c static char basenamestr[32]; static const char *if_basename(const char *name); -@@ -613,8 +636,10 @@ +@@ -618,8 +643,10 @@ int tos_bits = IPTOS_TOS(olsr_cnf->tos); #endif @@ -2079,7 +2172,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c memset(&ifr, 0, sizeof(struct ifreq)); memset(&ifs, 0, sizeof(struct interface)); -@@ -721,11 +746,13 @@ +@@ -726,11 +753,13 @@ ifs.int_broadaddr = *(struct sockaddr_in *)&ifr.ifr_broadaddr; } @@ -2093,7 +2186,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c } -@@ -755,7 +782,9 @@ +@@ -760,7 +789,9 @@ OLSR_PRINTF(1, "\tMTU - IPhdr: %d\n", ifs.int_mtu); @@ -2103,7 +2196,7 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c OLSR_PRINTF(1, "\tIndex %d\n", ifs.if_index); if (olsr_cnf->ip_version == AF_INET) { -@@ -860,10 +889,14 @@ +@@ -865,10 +896,14 @@ */ memset(&null_addr, 0, olsr_cnf->ipsize); if (ipequal(&null_addr, &olsr_cnf->main_addr)) { @@ -2111,16 +2204,16 @@ diff -Nur olsrd-0.5.6-r3.orig/src/unix/ifnet.c olsrd-0.5.6-r3/src/unix/ifnet.c struct ipaddr_str buf; +#endif olsr_cnf->main_addr = ifp->ip_addr; - OLSR_PRINTF(1, "New main address: %s\n", olsr_ip_to_string(&buf, &olsr_cnf->main_addr)); +#ifndef SVEN_OLA_UNBLOAT + OLSR_PRINTF(1, "New main address: %s\n", olsr_ip_to_string(&buf, &olsr_cnf->main_addr)); olsr_syslog(OLSR_LOG_INFO, "New main address: %s\n", olsr_ip_to_string(&buf, &olsr_cnf->main_addr)); +#endif /* SVEN_OLA_UNBLOAT */ } /* -diff -Nur olsrd-0.5.6-r3.orig/src/unix/misc.c olsrd-0.5.6-r3/src/unix/misc.c ---- olsrd-0.5.6-r3.orig/src/unix/misc.c 2008-12-02 11:50:01.000000000 +0100 -+++ olsrd-0.5.6-r3/src/unix/misc.c 2008-12-03 10:01:07.000000000 +0100 +diff -ur olsrd-0-5-6-fc691af9a18d.orig/src/unix/misc.c olsrd-0-5-6-fc691af9a18d/src/unix/misc.c +--- olsrd-0-5-6-fc691af9a18d.orig/src/unix/misc.c 2009-03-14 22:39:09.000000000 +0000 ++++ olsrd-0-5-6-fc691af9a18d/src/unix/misc.c 2009-03-15 18:10:12.000000000 +0000 @@ -44,6 +44,7 @@ #include "misc.h" #include "olsr_types.h" -- 2.25.1