etherswitch.h revision 256281
1210006Srdivacky/*
2210006Srdivacky * $FreeBSD: stable/10/sys/dev/etherswitch/etherswitch.h 253569 2013-07-23 13:56:38Z loos $
3210006Srdivacky */
4210006Srdivacky
5210006Srdivacky#ifndef __SYS_DEV_ETHERSWITCH_ETHERSWITCH_H
6210006Srdivacky#define __SYS_DEV_ETHERSWITCH_ETHERSWITCH_H
7210006Srdivacky
8210006Srdivacky#include <sys/ioccom.h>
9210006Srdivacky
10210006Srdivacky#ifdef _KERNEL
11249423Sdimextern devclass_t       etherswitch_devclass;
12249423Sdimextern driver_t         etherswitch_driver;
13249423Sdim#endif /* _KERNEL */
14210006Srdivacky
15249423Sdimstruct etherswitch_reg {
16249423Sdim	uint16_t	reg;
17210006Srdivacky	uint16_t	val;
18210006Srdivacky};
19210006Srdivackytypedef struct etherswitch_reg etherswitch_reg_t;
20210006Srdivacky
21210006Srdivackystruct etherswitch_phyreg {
22210006Srdivacky	uint16_t	phy;
23210006Srdivacky	uint16_t	reg;
24210006Srdivacky	uint16_t	val;
25210006Srdivacky};
26210006Srdivackytypedef struct etherswitch_phyreg etherswitch_phyreg_t;
27210006Srdivacky
28210006Srdivacky#define	ETHERSWITCH_NAMEMAX		64
29249423Sdim#define	ETHERSWITCH_VID_MASK		0xfff
30249423Sdim#define	ETHERSWITCH_VID_VALID		(1 << 12)
31249423Sdim#define	ETHERSWITCH_VLAN_ISL		(1 << 0)	/* ISL */
32249423Sdim#define	ETHERSWITCH_VLAN_PORT		(1 << 1)	/* Port based vlan */
33249423Sdim#define	ETHERSWITCH_VLAN_DOT1Q		(1 << 2)	/* 802.1q */
34212904Sdim#define	ETHERSWITCH_VLAN_DOT1Q_4K	(1 << 3)	/* 4k support on 802.1q */
35212904Sdim#define	ETHERSWITCH_VLAN_DOUBLE_TAG	(1 << 4)	/* Q-in-Q */
36210006Srdivacky#define	ETHERSWITCH_VLAN_CAPS_BITS	\
37210006Srdivacky"\020\1ISL\2PORT\3DOT1Q\4DOT1Q4K\5QinQ"
38210006Srdivacky
39210006Srdivackystruct etherswitch_info {
40210006Srdivacky	int		es_nports;
41210006Srdivacky	int		es_nvlangroups;
42210006Srdivacky	char		es_name[ETHERSWITCH_NAMEMAX];
43210006Srdivacky	uint32_t	es_vlan_caps;
44210006Srdivacky};
45210006Srdivackytypedef struct etherswitch_info etherswitch_info_t;
46210006Srdivacky
47249423Sdim#define	ETHERSWITCH_CONF_FLAGS		(1 << 0)
48263508Sdim#define	ETHERSWITCH_CONF_MIRROR		(1 << 1)
49263508Sdim#define	ETHERSWITCH_CONF_VLAN_MODE	(1 << 2)
50249423Sdim
51249423Sdimstruct etherswitch_conf {
52212904Sdim	uint32_t	cmd;		/* What to configure */
53249423Sdim	uint32_t	vlan_mode;	/* Switch VLAN mode */
54249423Sdim};
55249423Sdimtypedef struct etherswitch_conf etherswitch_conf_t;
56249423Sdim
57249423Sdim#define	ETHERSWITCH_PORT_CPU		(1 << 0)
58249423Sdim#define	ETHERSWITCH_PORT_STRIPTAG	(1 << 1)
59249423Sdim#define	ETHERSWITCH_PORT_ADDTAG		(1 << 2)
60249423Sdim#define	ETHERSWITCH_PORT_FIRSTLOCK	(1 << 3)
61249423Sdim#define	ETHERSWITCH_PORT_DROPUNTAGGED	(1 << 4)
62212904Sdim#define	ETHERSWITCH_PORT_DOUBLE_TAG	(1 << 5)
63249423Sdim#define	ETHERSWITCH_PORT_INGRESS	(1 << 6)
64212904Sdim#define	ETHERSWITCH_PORT_FLAGS_BITS	\
65249423Sdim"\020\1CPUPORT\2STRIPTAG\3ADDTAG\4FIRSTLOCK\5DROPUNTAGGED\6QinQ\7INGRESS"
66249423Sdim
67210006Srdivackystruct etherswitch_port {
68249423Sdim	int		es_port;
69249423Sdim	int		es_pvid;
70249423Sdim	uint32_t	es_flags;
71249423Sdim	union {
72239462Sdim		struct ifreq		es_uifr;
73210006Srdivacky		struct ifmediareq	es_uifmr;
74263508Sdim	} es_ifu;
75249423Sdim#define es_ifr		es_ifu.es_uifr
76249423Sdim#define es_ifmr		es_ifu.es_uifmr
77249423Sdim};
78249423Sdimtypedef struct etherswitch_port etherswitch_port_t;
79249423Sdim
80249423Sdimstruct etherswitch_vlangroup {
81249423Sdim	int		es_vlangroup;
82249423Sdim	int		es_vid;
83249423Sdim	int		es_member_ports;
84249423Sdim	int		es_untagged_ports;
85249423Sdim	int		es_fid;
86249423Sdim};
87249423Sdimtypedef struct etherswitch_vlangroup etherswitch_vlangroup_t;
88249423Sdim
89249423Sdim#define ETHERSWITCH_PORTMASK(_port)	(1 << (_port))
90249423Sdim
91249423Sdim#define IOETHERSWITCHGETINFO		_IOR('i', 1, etherswitch_info_t)
92249423Sdim#define IOETHERSWITCHGETREG		_IOWR('i', 2, etherswitch_reg_t)
93249423Sdim#define IOETHERSWITCHSETREG		_IOW('i', 3, etherswitch_reg_t)
94249423Sdim#define IOETHERSWITCHGETPORT		_IOWR('i', 4, etherswitch_port_t)
95249423Sdim#define IOETHERSWITCHSETPORT		_IOW('i', 5, etherswitch_port_t)
96249423Sdim#define IOETHERSWITCHGETVLANGROUP	_IOWR('i', 6, etherswitch_vlangroup_t)
97249423Sdim#define IOETHERSWITCHSETVLANGROUP	_IOW('i', 7, etherswitch_vlangroup_t)
98249423Sdim#define IOETHERSWITCHGETPHYREG		_IOWR('i', 8, etherswitch_phyreg_t)
99249423Sdim#define IOETHERSWITCHSETPHYREG		_IOW('i', 9, etherswitch_phyreg_t)
100249423Sdim#define IOETHERSWITCHGETCONF		_IOR('i', 10, etherswitch_conf_t)
101249423Sdim#define IOETHERSWITCHSETCONF		_IOW('i', 11, etherswitch_conf_t)
102249423Sdim
103249423Sdim#endif
104249423Sdim