summaryrefslogtreecommitdiffstats
path: root/lib/route
diff options
context:
space:
mode:
authorSusant Sahani <susant@redhat.com>2014-05-07 10:35:53 (GMT)
committerThomas Haller <thaller@redhat.com>2014-05-12 12:23:32 (GMT)
commit430eb4004ab7f93fd840e9836d4bc9220d3c406d (patch)
tree338d908eed42aa5e29a83928f30f6fb54053f644 /lib/route
parentc79754297adcd933b275aeabbb94d9bd34f3bb33 (diff)
downloadlibnl-430eb4004ab7f93fd840e9836d4bc9220d3c406d.zip
libnl-430eb4004ab7f93fd840e9836d4bc9220d3c406d.tar.gz
libnl-430eb4004ab7f93fd840e9836d4bc9220d3c406d.tar.bz2
vlan: add support for IFLA_VLAN_PROTOCOL
This patch adds support for IFLA_VLAN_PROTOCOL Signed-off-by: Susant Sahani <susant@redhat.com> Acked-by: Thomas Graf <tgraf@suug.ch> [thaller@redhat.com: minor fixes (whitespace, documentation, and a typo)] Signed-off-by: Thomas Haller <thaller@redhat.com>
Diffstat (limited to 'lib/route')
-rw-r--r--lib/route/link/vlan.c52
1 files changed, 51 insertions, 1 deletions
diff --git a/lib/route/link/vlan.c b/lib/route/link/vlan.c
index 9bbe7d5..1a0d916 100644
--- a/lib/route/link/vlan.c
+++ b/lib/route/link/vlan.c
@@ -38,10 +38,12 @@
#define VLAN_HAS_FLAGS (1<<1)
#define VLAN_HAS_INGRESS_QOS (1<<2)
#define VLAN_HAS_EGRESS_QOS (1<<3)
+#define VLAN_HAS_PROTOCOL (1<<4)
struct vlan_info
{
uint16_t vi_vlan_id;
+ uint16_t vi_protocol;
uint32_t vi_flags;
uint32_t vi_flags_mask;
uint32_t vi_ingress_qos[VLAN_PRIO_MAX+1];
@@ -58,6 +60,7 @@ static struct nla_policy vlan_policy[IFLA_VLAN_MAX+1] = {
[IFLA_VLAN_FLAGS] = { .minlen = sizeof(struct ifla_vlan_flags) },
[IFLA_VLAN_INGRESS_QOS] = { .type = NLA_NESTED },
[IFLA_VLAN_EGRESS_QOS] = { .type = NLA_NESTED },
+ [IFLA_VLAN_PROTOCOL] = { .type = NLA_U16 },
};
static int vlan_alloc(struct rtnl_link *link)
@@ -94,6 +97,11 @@ static int vlan_parse(struct rtnl_link *link, struct nlattr *data,
vi->vi_mask |= VLAN_HAS_ID;
}
+ if (tb[IFLA_VLAN_PROTOCOL]) {
+ vi->vi_protocol = nla_get_u16(tb[IFLA_VLAN_PROTOCOL]);
+ vi->vi_mask |= VLAN_HAS_PROTOCOL;
+ }
+
if (tb[IFLA_VLAN_FLAGS]) {
struct ifla_vlan_flags flags;
nla_memcpy(&flags, tb[IFLA_VLAN_FLAGS], sizeof(flags));
@@ -186,7 +194,12 @@ static void vlan_dump_details(struct rtnl_link *link, struct nl_dump_params *p)
char buf[64];
rtnl_link_vlan_flags2str(vi->vi_flags, buf, sizeof(buf));
- nl_dump_line(p, " vlan-info id %d <%s>\n", vi->vi_vlan_id, buf);
+ nl_dump_line(p, " vlan-info id %d <%s>", vi->vi_vlan_id, buf);
+
+ if (vi->vi_mask & VLAN_HAS_PROTOCOL)
+ nl_dump_line(p, " vlan protocol <%d>", vi->vi_protocol);
+
+ nl_dump(p, "\n");
if (vi->vi_mask & VLAN_HAS_INGRESS_QOS) {
nl_dump_line(p,
@@ -410,6 +423,43 @@ int rtnl_link_vlan_get_id(struct rtnl_link *link)
}
/**
+ * Set VLAN protocol
+ * @arg link Link object
+ * @arg protocol VLAN protocol
+ *
+ * @return 0 on success or a negative error code
+ */
+int rtnl_link_vlan_set_protocol(struct rtnl_link *link, uint16_t protocol)
+{
+ struct vlan_info *vi = link->l_info;
+
+ IS_VLAN_LINK_ASSERT(link);
+
+ vi->vi_protocol = protocol;
+ vi->vi_mask |= VLAN_HAS_PROTOCOL;
+
+ return 0;
+}
+
+/**
+ * Get VLAN protocol
+ * @arg link Link object
+ *
+ * @return VLAN protocol, 0 if not set or a negative error code.
+ */
+int rtnl_link_vlan_get_protocol(struct rtnl_link *link)
+{
+ struct vlan_info *vi = link->l_info;
+
+ IS_VLAN_LINK_ASSERT(link);
+
+ if (vi->vi_mask & VLAN_HAS_PROTOCOL)
+ return vi->vi_protocol;
+ else
+ return 0;
+}
+
+/**
* Set VLAN flags
* @arg link Link object
* @arg flags VLAN flags