aboutsummaryrefslogtreecommitdiff
path: root/src/net
diff options
context:
space:
mode:
authorStefan Hajnoczi <stefanha@redhat.com>2013-03-01 16:32:15 +0100
committerMichael Brown <mcb30@ipxe.org>2013-03-01 16:11:40 +0000
commit7426177d631c0fd8b2ef3ffae4449637d5bca32a (patch)
tree5d1fd4375b0b51ebcf4278be7974ad2268ba6748 /src/net
parent09c5109b8585178172c7608de8d52e9d9af0b680 (diff)
downloadipxe-7426177d631c0fd8b2ef3ffae4449637d5bca32a.zip
ipxe-7426177d631c0fd8b2ef3ffae4449637d5bca32a.tar.gz
ipxe-7426177d631c0fd8b2ef3ffae4449637d5bca32a.tar.bz2
[netdevice] Add vlan_tag() to get the VLAN tag of a network device
The iBFT has a VLAN field that should be filled in. Add the vlan_tag() function to extract the VLAN tag of a network device. Since VLAN support is optional, define a weak function that returns 0 when iPXE is built without VLAN support. Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Modified-by: Michael Brown <mcb30@ipxe.org> Signed-off-by: Michael Brown <mcb30@ipxe.org>
Diffstat (limited to 'src/net')
-rw-r--r--src/net/netdevice.c11
-rw-r--r--src/net/vlan.c17
2 files changed, 28 insertions, 0 deletions
diff --git a/src/net/netdevice.c b/src/net/netdevice.c
index ec3456a..a716663 100644
--- a/src/net/netdevice.c
+++ b/src/net/netdevice.c
@@ -33,6 +33,7 @@ FILE_LICENCE ( GPL2_OR_LATER );
#include <ipxe/init.h>
#include <ipxe/device.h>
#include <ipxe/errortab.h>
+#include <ipxe/vlan.h>
#include <ipxe/netdevice.h>
/** @file
@@ -783,5 +784,15 @@ static void net_step ( struct process *process __unused ) {
net_poll();
}
+/**
+ * Get the VLAN tag (when VLAN support is not present)
+ *
+ * @v netdev Network device
+ * @ret tag 0, indicating that device is not a VLAN device
+ */
+__weak unsigned int vlan_tag ( struct net_device *netdev __unused ) {
+ return 0;
+}
+
/** Networking stack process */
PERMANENT_PROCESS ( net_process, net_step );
diff --git a/src/net/vlan.c b/src/net/vlan.c
index f7281f5..1a2a086 100644
--- a/src/net/vlan.c
+++ b/src/net/vlan.c
@@ -283,6 +283,23 @@ struct net_protocol vlan_protocol __net_protocol = {
};
/**
+ * Get the VLAN tag
+ *
+ * @v netdev Network device
+ * @ret tag VLAN tag, or 0 if device is not a VLAN device
+ */
+unsigned int vlan_tag ( struct net_device *netdev ) {
+ struct vlan_device *vlan;
+
+ if ( netdev->op == &vlan_operations ) {
+ vlan = netdev->priv;
+ return vlan->tag;
+ } else {
+ return 0;
+ }
+}
+
+/**
* Check if network device can be used as a VLAN trunk device
*
* @v trunk Trunk network device