aboutsummaryrefslogtreecommitdiff
path: root/networking/vconfig.c
diff options
context:
space:
mode:
authorEric Andersen <andersen@codepoet.org>2003-12-19 10:40:56 +0000
committerEric Andersen <andersen@codepoet.org>2003-12-19 10:40:56 +0000
commitb8d2cd44a602b54814df034ac357c203d2781fb4 (patch)
tree1aa31b3a9c94fde7c5b01bad14ec9f597f9ac4bc /networking/vconfig.c
parentb51eb265681de8723a34c923032d0e8df143b19a (diff)
downloadbusybox-b8d2cd44a602b54814df034ac357c203d2781fb4.tar.gz
don't use kernel headers
Diffstat (limited to 'networking/vconfig.c')
-rw-r--r--networking/vconfig.c36
1 files changed, 35 insertions, 1 deletions
diff --git a/networking/vconfig.c b/networking/vconfig.c
index d58c375f7..0bb33084a 100644
--- a/networking/vconfig.c
+++ b/networking/vconfig.c
@@ -27,11 +27,45 @@
#include <fcntl.h>
#include <sys/ioctl.h>
#include <net/if.h>
-#include <linux/if_vlan.h>
#include <string.h>
#include <limits.h>
#include "busybox.h"
+/* Stuff from linux/if_vlan.h, kernel version 2.4.23 */
+enum vlan_ioctl_cmds {
+ ADD_VLAN_CMD,
+ DEL_VLAN_CMD,
+ SET_VLAN_INGRESS_PRIORITY_CMD,
+ SET_VLAN_EGRESS_PRIORITY_CMD,
+ GET_VLAN_INGRESS_PRIORITY_CMD,
+ GET_VLAN_EGRESS_PRIORITY_CMD,
+ SET_VLAN_NAME_TYPE_CMD,
+ SET_VLAN_FLAG_CMD
+};
+enum vlan_name_types {
+ VLAN_NAME_TYPE_PLUS_VID, /* Name will look like: vlan0005 */
+ VLAN_NAME_TYPE_RAW_PLUS_VID, /* name will look like: eth1.0005 */
+ VLAN_NAME_TYPE_PLUS_VID_NO_PAD, /* Name will look like: vlan5 */
+ VLAN_NAME_TYPE_RAW_PLUS_VID_NO_PAD, /* Name will look like: eth0.5 */
+ VLAN_NAME_TYPE_HIGHEST
+};
+
+struct vlan_ioctl_args {
+ int cmd; /* Should be one of the vlan_ioctl_cmds enum above. */
+ char device1[24];
+
+ union {
+ char device2[24];
+ int VID;
+ unsigned int skb_priority;
+ unsigned int name_type;
+ unsigned int bind_type;
+ unsigned int flag; /* Matches vlan_dev_info flags */
+ } u;
+
+ short vlan_qos;
+};
+
#define VLAN_GROUP_ARRAY_LEN 4096
#define SIOCSIFVLAN 0x8983 /* Set 802.1Q VLAN options */