networking.networkd: adjust autmatic mapping of bonds

Since the bonds interface changed to a lot more possible values we create a
mapping of kernel bond attribute names and values to networkd attributes.
Those match for the most part, but have to transformed slightly.

There is also an assert that unknown options won’t slip through silently.
This commit is contained in:
Profpatsch 2017-02-03 02:20:47 +01:00
parent 9debdaf512
commit bb797c1390
2 changed files with 59 additions and 11 deletions

View File

@ -79,7 +79,7 @@ let
checkBond = checkUnitConfig "Bond" [ checkBond = checkUnitConfig "Bond" [
(assertOnlyFields [ (assertOnlyFields [
"Mode" "TransmitHashPolicy" "LACPTransmitRate" "MIIMonitorSec" "Mode" "TransmitHashPolicy" "LACPTransmitRate" "MIIMonitorSec"
"UpDelaySec" "DownDelaySec" "UpDelaySec" "DownDelaySec" "GratuitousARP"
]) ])
(assertValueOneOf "Mode" [ (assertValueOneOf "Mode" [
"balance-rr" "active-backup" "balance-xor" "balance-rr" "active-backup" "balance-xor"

View File

@ -115,17 +115,65 @@ in
Name = name; Name = name;
Kind = "bond"; Kind = "bond";
}; };
bondConfig = bondConfig = let
(optionalAttrs (bond.lacp_rate != null) { # manual mapping as of 2017-02-03
LACPTransmitRate = bond.lacp_rate; # man 5 systemd.netdev [BOND]
}) // (optionalAttrs (bond.miimon != null) { # to https://www.kernel.org/doc/Documentation/networking/bonding.txt
MIIMonitorSec = bond.miimon; # driver options.
}) // (optionalAttrs (bond.mode != null) { driverOptionMapping = let
Mode = bond.mode; trans = f: optName: { valTransform = f; optNames = [optName]; };
}) // (optionalAttrs (bond.xmit_hash_policy != null) { simp = trans id;
TransmitHashPolicy = bond.xmit_hash_policy; ms = trans (v: v + "ms");
}); in {
Mode = simp "mode";
TransmitHashPolixy = simp "xmit_hash_policy";
LACPTransmitRate = simp "lacp_rate";
MIIMonitorSec = ms "miimon";
UpDelaySec = ms "updelay";
DownDelaySec = ms "downdelay";
LearnPacketIntervalSec = simp "lp_interval";
AdSelect = simp "ad_select";
FailOverMACPolicy = simp "fail_over_mac";
ARPValidate = simp "arp_validate";
# apparently in ms for this value?! Upstream bug?
ARPIntervalSec = simp "arp_interval";
ARPIPTargets = simp "arp_ip_target";
ARPAllTargets = simp "arp_all_targets";
PrimaryReselectPolicy = simp "primary_reselect";
ResendIGMP = simp "resend_igmp";
PacketsPerSlave = simp "packets_per_slave";
GratuitousARP = { valTransform = id;
optNames = [ "num_grat_arp" "num_unsol_na" ]; };
AllSlavesActive = simp "all_slaves_active";
MinLinks = simp "min_links";
};
do = bond.driverOptions;
assertNoUnknownOption = let
knownOptions = flatten (mapAttrsToList (_: kOpts: kOpts.optNames)
driverOptionMapping);
# options that apparently dont exist in the networkd config
unknownOptions = [ "primary" ];
assertTrace = bool: msg: if bool then true else builtins.trace msg false;
in assert all (driverOpt: assertTrace
(elem driverOpt (knownOptions ++ unknownOptions))
"The bond.driverOption `${driverOpt}` cannot be mapped to the list of known networkd bond options. Please add it to the mapping above the assert or to `unknownOptions` should it not exist in networkd.")
(mapAttrsToList (k: _: k) do); "";
# get those driverOptions that have been set
filterSystemdOptions = filterAttrs (sysDOpt: kOpts:
any (kOpt: do ? "${kOpt}") kOpts.optNames);
# build final set of systemd options to bond values
buildOptionSet = mapAttrs (_: kOpts: with kOpts;
# we simply take the first set kernel bond option
# (one option has multiple names, which is silly)
head (map (optN: valTransform (do."${optN}"))
# only map those that exist
(filter (o: do ? "${o}") optNames)));
in seq assertNoUnknownOption
(buildOptionSet (filterSystemdOptions driverOptionMapping));
}; };
networks = listToAttrs (flip map bond.interfaces (bi: networks = listToAttrs (flip map bond.interfaces (bi:
nameValuePair "40-${bi}" (mkMerge [ (genericNetwork (mkOverride 999)) { nameValuePair "40-${bi}" (mkMerge [ (genericNetwork (mkOverride 999)) {
DHCP = mkOverride 0 (dhcpStr false); DHCP = mkOverride 0 (dhcpStr false);