summaryrefslogtreecommitdiff
path: root/src/network/networkd-route.c
diff options
context:
space:
mode:
authorTom Gundersen <teg@jklm.no>2015-10-05 22:42:44 +0200
committerTom Gundersen <teg@jklm.no>2015-10-05 22:42:44 +0200
commit2b22ffaf600df7f775ce6a7fdf4a470f04f8e75d (patch)
tree710af2c3e562ac0782c24c30fcf8b3751a7cb2a4 /src/network/networkd-route.c
parentf4e5a03ed7d62e21b5533a7e1124d610bd0a81a4 (diff)
parent0d07e595cc22379ec7388406c2f4f2a74eea9083 (diff)
Merge pull request #1372 from jemk/prefsrc
networkd: add support to configure preferred source of static routes
Diffstat (limited to 'src/network/networkd-route.c')
-rw-r--r--src/network/networkd-route.c40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/network/networkd-route.c b/src/network/networkd-route.c
index 1f09d95674..ee1ddd81fe 100644
--- a/src/network/networkd-route.c
+++ b/src/network/networkd-route.c
@@ -305,6 +305,46 @@ int config_parse_gateway(const char *unit,
return 0;
}
+int config_parse_preferred_src(const char *unit,
+ const char *filename,
+ unsigned line,
+ const char *section,
+ unsigned section_line,
+ const char *lvalue,
+ int ltype,
+ const char *rvalue,
+ void *data,
+ void *userdata) {
+
+ Network *network = userdata;
+ _cleanup_route_free_ Route *n = NULL;
+ union in_addr_union buffer;
+ int r, f;
+
+ assert(filename);
+ assert(section);
+ assert(lvalue);
+ assert(rvalue);
+ assert(data);
+
+ r = route_new_static(network, section_line, &n);
+ if (r < 0)
+ return r;
+
+ r = in_addr_from_string_auto(rvalue, &f, &buffer);
+ if (r < 0) {
+ log_syntax(unit, LOG_ERR, filename, line, EINVAL,
+ "Preferred source is invalid, ignoring assignment: %s", rvalue);
+ return 0;
+ }
+
+ n->family = f;
+ n->prefsrc_addr = buffer;
+ n = NULL;
+
+ return 0;
+}
+
int config_parse_destination(const char *unit,
const char *filename,
unsigned line,