mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-22 22:03:43 +03:00
udev,network: warn when .link or .network file has no [Match] section
Closes #12098. (cherry picked from commit 84ea567eb4326eb970a33188649fde6bea2a0d4e)
This commit is contained in:
parent
fbdf8536ab
commit
0f5caf88a6
@ -60,8 +60,13 @@
|
|||||||
<refsect1>
|
<refsect1>
|
||||||
<title>[Match] Section Options</title>
|
<title>[Match] Section Options</title>
|
||||||
|
|
||||||
<para>A link file is said to match a device if each of the entries in the [Match] section matches, or if
|
<para>A link file is said to match a device if all matches specified by the
|
||||||
the section is empty. The following keys are accepted:</para>
|
<literal>[Match]</literal> section are satisfied. When a link file does not contain valid settings
|
||||||
|
in <literal>[Match]</literal> section, then the file will match all devices and
|
||||||
|
<command>systemd-udevd</command> warns about that. Hint: to avoid the warning and to make it clear
|
||||||
|
that all interfaces shall be matched, add the following:
|
||||||
|
<programlisting>OriginalName=*</programlisting>
|
||||||
|
The following keys are accepted:</para>
|
||||||
|
|
||||||
<variablelist class='network-directives'>
|
<variablelist class='network-directives'>
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
|
@ -77,9 +77,13 @@
|
|||||||
is applied, all later files are ignored, even if they match as
|
is applied, all later files are ignored, even if they match as
|
||||||
well.</para>
|
well.</para>
|
||||||
|
|
||||||
<para>A network file is said to match a device if each of the
|
<para>A network file is said to match a network interface if all matches specified by the
|
||||||
entries in the <literal>[Match]</literal> section matches, or if
|
<literal>[Match]</literal> section are satisfied. When a network file does not contain valid
|
||||||
the section is empty. The following keys are accepted:</para>
|
settings in <literal>[Match]</literal> section, then the file will match all interfaces and
|
||||||
|
<command>systemd-networkd</command> warns about that. Hint: to avoid the warning and to make it
|
||||||
|
clear that all interfaces shall be matched, add the following:
|
||||||
|
<programlisting>Name=*</programlisting>
|
||||||
|
The following keys are accepted:</para>
|
||||||
|
|
||||||
<variablelist class='network-directives'>
|
<variablelist class='network-directives'>
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
|
@ -7,6 +7,9 @@
|
|||||||
# the Free Software Foundation; either version 2.1 of the License, or
|
# the Free Software Foundation; either version 2.1 of the License, or
|
||||||
# (at your option) any later version.
|
# (at your option) any later version.
|
||||||
|
|
||||||
|
[Match]
|
||||||
|
OriginalName=*
|
||||||
|
|
||||||
[Link]
|
[Link]
|
||||||
NamePolicy=keep kernel database onboard slot path
|
NamePolicy=keep kernel database onboard slot path
|
||||||
MACAddressPolicy=persistent
|
MACAddressPolicy=persistent
|
||||||
|
@ -174,6 +174,14 @@ int network_verify(Network *network) {
|
|||||||
assert(network);
|
assert(network);
|
||||||
assert(network->filename);
|
assert(network->filename);
|
||||||
|
|
||||||
|
if (set_isempty(network->match_mac) && strv_isempty(network->match_path) &&
|
||||||
|
strv_isempty(network->match_driver) && strv_isempty(network->match_type) &&
|
||||||
|
strv_isempty(network->match_name) && !network->conditions)
|
||||||
|
log_warning("%s: No valid settings found in the [Match] section. "
|
||||||
|
"The file will match all interfaces. "
|
||||||
|
"If that is intended, please add Name=* in the [Match] section.",
|
||||||
|
network->filename);
|
||||||
|
|
||||||
/* skip out early if configuration does not match the environment */
|
/* skip out early if configuration does not match the environment */
|
||||||
if (!condition_test_list(network->conditions, NULL, NULL, NULL))
|
if (!condition_test_list(network->conditions, NULL, NULL, NULL))
|
||||||
return log_debug_errno(SYNTHETIC_ERRNO(EINVAL),
|
return log_debug_errno(SYNTHETIC_ERRNO(EINVAL),
|
||||||
|
@ -173,6 +173,7 @@ static void test_config_parse_address_one(const char *rvalue, int family, unsign
|
|||||||
|
|
||||||
assert_se(network = new0(Network, 1));
|
assert_se(network = new0(Network, 1));
|
||||||
assert_se(network->filename = strdup("hogehoge.network"));
|
assert_se(network->filename = strdup("hogehoge.network"));
|
||||||
|
assert_se(config_parse_ifnames("network", "filename", 1, "section", 1, "Name", 0, "*", &network->match_name, network) == 0);
|
||||||
assert_se(config_parse_address("network", "filename", 1, "section", 1, "Address", 0, rvalue, network, network) == 0);
|
assert_se(config_parse_address("network", "filename", 1, "section", 1, "Address", 0, rvalue, network, network) == 0);
|
||||||
assert_se(network->n_static_addresses == 1);
|
assert_se(network->n_static_addresses == 1);
|
||||||
assert_se(network_verify(network) >= 0);
|
assert_se(network_verify(network) >= 0);
|
||||||
|
@ -159,6 +159,14 @@ int link_load_one(link_config_ctx *ctx, const char *filename) {
|
|||||||
if (link->speed > UINT_MAX)
|
if (link->speed > UINT_MAX)
|
||||||
return -ERANGE;
|
return -ERANGE;
|
||||||
|
|
||||||
|
if (set_isempty(link->match_mac) && strv_isempty(link->match_path) &&
|
||||||
|
strv_isempty(link->match_driver) && strv_isempty(link->match_type) &&
|
||||||
|
strv_isempty(link->match_name) && !link->conditions)
|
||||||
|
log_warning("%s: No valid settings found in the [Match] section. "
|
||||||
|
"The file will match all interfaces. "
|
||||||
|
"If that is intended, please add OriginalName=* in the [Match] section.",
|
||||||
|
filename);
|
||||||
|
|
||||||
if (!condition_test_list(link->conditions, NULL, NULL, NULL)) {
|
if (!condition_test_list(link->conditions, NULL, NULL, NULL)) {
|
||||||
log_debug("%s: Conditions do not match the system environment, skipping.", filename);
|
log_debug("%s: Conditions do not match the system environment, skipping.", filename);
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user