mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-21 18:03:41 +03:00
network-generator: parse vlan ID from vlan interface name
Fixes #33954. (cherry picked from commit e31a55edf136e777aabdf19894ee886eac47c20e) (cherry picked from commit 4cd435ca49950c2bba86a95b500c6d239f18efe1)
This commit is contained in:
parent
be571ff648
commit
f9f74a067c
@ -14,6 +14,7 @@
|
|||||||
#include "string-table.h"
|
#include "string-table.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
|
#include "vlan-util.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
# .network
|
# .network
|
||||||
@ -951,6 +952,24 @@ static int parse_cmdline_rd_peerdns(Context *context, const char *key, const cha
|
|||||||
return network_set_dhcp_use_dns(context, "", r);
|
return network_set_dhcp_use_dns(context, "", r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int extract_vlan_id(const char *vlan_name, uint16_t *ret) {
|
||||||
|
assert(!isempty(vlan_name));
|
||||||
|
assert(ret);
|
||||||
|
|
||||||
|
/* From dracut.cmdline(7):
|
||||||
|
* We support the four styles of vlan names:
|
||||||
|
* VLAN_PLUS_VID (vlan0005),
|
||||||
|
* VLAN_PLUS_VID_NO_PAD (vlan5),
|
||||||
|
* DEV_PLUS_VID (eth0.0005), and
|
||||||
|
* DEV_PLUS_VID_NO_PAD (eth0.5). */
|
||||||
|
|
||||||
|
for (const char *p = vlan_name + strlen(vlan_name) - 1; p > vlan_name; p--)
|
||||||
|
if (!ascii_isdigit(*p))
|
||||||
|
return parse_vlanid(p+1, ret);
|
||||||
|
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
static int parse_cmdline_vlan(Context *context, const char *key, const char *value) {
|
static int parse_cmdline_vlan(Context *context, const char *key, const char *value) {
|
||||||
const char *name, *p;
|
const char *name, *p;
|
||||||
NetDev *netdev;
|
NetDev *netdev;
|
||||||
@ -975,6 +994,10 @@ static int parse_cmdline_vlan(Context *context, const char *key, const char *val
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
r = extract_vlan_id(name, &netdev->vlan_id);
|
||||||
|
if (r < 0)
|
||||||
|
return log_debug_errno(r, "Failed to parse VLAN ID from VLAN device name '%s': %m", name);
|
||||||
|
|
||||||
return network_set_vlan(context, p + 1, name);
|
return network_set_vlan(context, p + 1, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1352,6 +1375,13 @@ void netdev_dump(NetDev *netdev, FILE *f) {
|
|||||||
|
|
||||||
if (netdev->mtu > 0)
|
if (netdev->mtu > 0)
|
||||||
fprintf(f, "MTUBytes=%" PRIu32 "\n", netdev->mtu);
|
fprintf(f, "MTUBytes=%" PRIu32 "\n", netdev->mtu);
|
||||||
|
|
||||||
|
if (streq(netdev->kind, "vlan")) {
|
||||||
|
fprintf(f,
|
||||||
|
"\n[VLAN]\n"
|
||||||
|
"Id=%u\n",
|
||||||
|
netdev->vlan_id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void link_dump(Link *link, FILE *f) {
|
void link_dump(Link *link, FILE *f) {
|
||||||
|
@ -79,6 +79,9 @@ struct NetDev {
|
|||||||
char *ifname;
|
char *ifname;
|
||||||
char *kind;
|
char *kind;
|
||||||
uint32_t mtu;
|
uint32_t mtu;
|
||||||
|
|
||||||
|
/* [VLAN] */
|
||||||
|
uint16_t vlan_id;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Link {
|
struct Link {
|
||||||
|
@ -336,6 +336,38 @@ int main(int argc, char *argv[]) {
|
|||||||
"MTUBytes=1530\n"
|
"MTUBytes=1530\n"
|
||||||
);
|
);
|
||||||
|
|
||||||
|
test_netdev_one("vlan123", "vlan", "vlan123:eth0",
|
||||||
|
"[NetDev]\n"
|
||||||
|
"Kind=vlan\n"
|
||||||
|
"Name=vlan123\n"
|
||||||
|
"\n[VLAN]\n"
|
||||||
|
"Id=123\n"
|
||||||
|
);
|
||||||
|
|
||||||
|
test_netdev_one("vlan0013", "vlan", "vlan0013:eth0",
|
||||||
|
"[NetDev]\n"
|
||||||
|
"Kind=vlan\n"
|
||||||
|
"Name=vlan0013\n"
|
||||||
|
"\n[VLAN]\n"
|
||||||
|
"Id=11\n" /* 0013 (octal) -> 11 */
|
||||||
|
);
|
||||||
|
|
||||||
|
test_netdev_one("eth0.123", "vlan", "eth0.123:eth0",
|
||||||
|
"[NetDev]\n"
|
||||||
|
"Kind=vlan\n"
|
||||||
|
"Name=eth0.123\n"
|
||||||
|
"\n[VLAN]\n"
|
||||||
|
"Id=123\n"
|
||||||
|
);
|
||||||
|
|
||||||
|
test_netdev_one("eth0.0013", "vlan", "eth0.0013:eth0",
|
||||||
|
"[NetDev]\n"
|
||||||
|
"Kind=vlan\n"
|
||||||
|
"Name=eth0.0013\n"
|
||||||
|
"\n[VLAN]\n"
|
||||||
|
"Id=11\n" /* 0013 (octal) -> 11 */
|
||||||
|
);
|
||||||
|
|
||||||
test_link_one("hogehoge", "ifname", "hogehoge:00:11:22:33:44:55",
|
test_link_one("hogehoge", "ifname", "hogehoge:00:11:22:33:44:55",
|
||||||
"[Match]\n"
|
"[Match]\n"
|
||||||
"MACAddress=00:11:22:33:44:55\n"
|
"MACAddress=00:11:22:33:44:55\n"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user