]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/blame - net/dsa/dsa_priv.h
net: fix __skb_try_recv_from_queue to return the old behavior
[mirror_ubuntu-jammy-kernel.git] / net / dsa / dsa_priv.h
CommitLineData
91da11f8
LB
1/*
2 * net/dsa/dsa_priv.h - Hardware switch handling
e84665c9 3 * Copyright (c) 2008-2009 Marvell Semiconductor
91da11f8
LB
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 */
10
11#ifndef __DSA_PRIV_H
12#define __DSA_PRIV_H
13
91da11f8 14#include <linux/phy.h>
5075314e 15#include <linux/netdevice.h>
04ff53f9 16#include <linux/netpoll.h>
5075314e
AD
17
18struct dsa_device_ops {
4ed70ce9 19 struct sk_buff *(*xmit)(struct sk_buff *skb, struct net_device *dev);
a86d8bec
FF
20 struct sk_buff *(*rcv)(struct sk_buff *skb, struct net_device *dev,
21 struct packet_type *pt,
22 struct net_device *orig_dev);
5075314e 23};
91da11f8 24
91da11f8 25struct dsa_slave_priv {
4ed70ce9 26 struct sk_buff * (*xmit)(struct sk_buff *skb,
5075314e 27 struct net_device *dev);
e84665c9 28
afdcf151
VD
29 /* DSA port data, such as switch, port index, etc. */
30 struct dsa_port *dp;
e84665c9
LB
31
32 /*
33 * The phylib phy_device pointer for the PHY connected
34 * to this port.
35 */
91da11f8 36 struct phy_device *phy;
0d8bcdd3
FF
37 phy_interface_t phy_interface;
38 int old_link;
39 int old_pause;
40 int old_duplex;
b73adef6 41
04ff53f9
FF
42#ifdef CONFIG_NET_POLL_CONTROLLER
43 struct netpoll *netpoll;
44#endif
f50f2127
FF
45
46 /* TC context */
47 struct list_head mall_tc_list;
91da11f8
LB
48};
49
91da11f8 50/* dsa.c */
9b8e895c 51int dsa_cpu_dsa_setup(struct dsa_switch *ds, struct device *dev,
293784a8
FF
52 struct dsa_port *dport, int port);
53void dsa_cpu_dsa_destroy(struct dsa_port *dport);
39a7f2a4 54const struct dsa_device_ops *dsa_resolve_tag_protocol(int tag_protocol);
0c73c523
FF
55int dsa_cpu_port_ethtool_setup(struct dsa_switch *ds);
56void dsa_cpu_port_ethtool_restore(struct dsa_switch *ds);
91da11f8 57
a6a71f19
VD
58/* legacy.c */
59int dsa_legacy_register(void);
60void dsa_legacy_unregister(void);
61
91da11f8 62/* slave.c */
5075314e 63extern const struct dsa_device_ops notag_netdev_ops;
91da11f8 64void dsa_slave_mii_bus_init(struct dsa_switch *ds);
af42192c 65void dsa_cpu_port_ethtool_init(struct ethtool_ops *ops);
d87d6f44 66int dsa_slave_create(struct dsa_switch *ds, struct device *parent,
83c0afae 67 int port, const char *name);
cda5c15b 68void dsa_slave_destroy(struct net_device *slave_dev);
24462549
FF
69int dsa_slave_suspend(struct net_device *slave_dev);
70int dsa_slave_resume(struct net_device *slave_dev);
88e4f0ca
VD
71int dsa_slave_register_notifier(void);
72void dsa_slave_unregister_notifier(void);
91da11f8 73
f515f192
VD
74/* switch.c */
75int dsa_switch_register_notifier(struct dsa_switch *ds);
76void dsa_switch_unregister_notifier(struct dsa_switch *ds);
77
eb7b7211
AL
78/* tag_brcm.c */
79extern const struct dsa_device_ops brcm_netdev_ops;
80
cf85d08f 81/* tag_dsa.c */
3e8a72d1 82extern const struct dsa_device_ops dsa_netdev_ops;
cf85d08f 83
91da11f8 84/* tag_edsa.c */
3e8a72d1 85extern const struct dsa_device_ops edsa_netdev_ops;
91da11f8 86
eb7b7211
AL
87/* tag_lan9303.c */
88extern const struct dsa_device_ops lan9303_netdev_ops;
396138f0 89
eb7b7211
AL
90/* tag_mtk.c */
91extern const struct dsa_device_ops mtk_netdev_ops;
5037d532 92
cafdc45c
JC
93/* tag_qca.c */
94extern const struct dsa_device_ops qca_netdev_ops;
91da11f8 95
eb7b7211
AL
96/* tag_trailer.c */
97extern const struct dsa_device_ops trailer_netdev_ops;
e8fe177a 98
91da11f8 99#endif