1 /*
2 * Copyright (C) 2017 Netronome Systems, Inc.
3 *
4 * This software is dual licensed under the GNU General License Version 2,
5 * June 1991 as shown in the file COPYING in the top-level directory of this
6 * source tree or the BSD 2-Clause License provided below. You have the
7 * option to license this software under the complete terms of either license.
8 *
9 * The BSD 2-Clause License:
10 *
11 * Redistribution and use in source and binary forms, with or
12 * without modification, are permitted provided that the following
13 * conditions are met:
14 *
15 * 1. Redistributions of source code must retain the above
16 * copyright notice, this list of conditions and the following
17 * disclaimer.
18 *
19 * 2. Redistributions in binary form must reproduce the above
20 * copyright notice, this list of conditions and the following
21 * disclaimer in the documentation and/or other materials
22 * provided with the distribution.
23 *
24 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
28 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
29 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
30 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
31 * SOFTWARE.
32 */
33
34 #ifndef NFP_NET_REPR_H
35 #define NFP_NET_REPR_H
36
37 struct metadata_dst;
38 struct nfp_app;
39 struct nfp_net;
40 struct nfp_port;
41
42 #include <net/dst_metadata.h>
43
44 /**
45 * struct nfp_reprs - container for representor netdevs
46 * @num_reprs: Number of elements in reprs array
47 * @reprs: Array of representor netdevs
48 */
49 struct nfp_reprs {
50 unsigned int num_reprs;
51 struct net_device __rcu *reprs[0];
52 };
53
54 /**
55 * struct nfp_repr_pcpu_stats
56 * @rx_packets: Received packets
57 * @rx_bytes: Received bytes
58 * @tx_packets: Transmitted packets
59 * @tx_bytes: Transmitted dropped
60 * @tx_drops: Packets dropped on transmit
61 * @syncp: Reference count
62 */
63 struct nfp_repr_pcpu_stats {
64 u64 rx_packets;
65 u64 rx_bytes;
66 u64 tx_packets;
67 u64 tx_bytes;
68 u64 tx_drops;
69 struct u64_stats_sync syncp;
70 };
71
72 /**
73 * struct nfp_repr - priv data for representor netdevs
74 * @netdev: Back pointer to netdev
75 * @dst: Destination for packet TX
76 * @port: Port of representor
77 * @app: APP handle
78 * @stats: Statistic of packets hitting CPU
79 * @app_priv: Pointer for APP data
80 */
81 struct nfp_repr {
82 struct net_device *netdev;
83 struct metadata_dst *dst;
84 struct nfp_port *port;
85 struct nfp_app *app;
86 struct nfp_repr_pcpu_stats __percpu *stats;
87 void *app_priv;
88 };
89
90 /**
91 * enum nfp_repr_type - type of representor
92 * @NFP_REPR_TYPE_PHYS_PORT: external NIC port
93 * @NFP_REPR_TYPE_PF: physical function
94 * @NFP_REPR_TYPE_VF: virtual function
95 * @__NFP_REPR_TYPE_MAX: number of representor types
96 */
97 enum nfp_repr_type {
98 NFP_REPR_TYPE_PHYS_PORT,
99 NFP_REPR_TYPE_PF,
100 NFP_REPR_TYPE_VF,
101
102 __NFP_REPR_TYPE_MAX,
103 };
104 #define NFP_REPR_TYPE_MAX (__NFP_REPR_TYPE_MAX - 1)
105
106 extern const struct net_device_ops nfp_repr_netdev_ops;
107
nfp_netdev_is_nfp_repr(struct net_device * netdev)108 static inline bool nfp_netdev_is_nfp_repr(struct net_device *netdev)
109 {
110 return netdev->netdev_ops == &nfp_repr_netdev_ops;
111 }
112
nfp_repr_get_port_id(struct net_device * netdev)113 static inline int nfp_repr_get_port_id(struct net_device *netdev)
114 {
115 struct nfp_repr *priv = netdev_priv(netdev);
116
117 return priv->dst->u.port_info.port_id;
118 }
119
120 struct net_device *
121 nfp_repr_get_locked(struct nfp_app *app, struct nfp_reprs *set,
122 unsigned int id);
123
124 void nfp_repr_inc_rx_stats(struct net_device *netdev, unsigned int len);
125 int nfp_repr_init(struct nfp_app *app, struct net_device *netdev,
126 u32 cmsg_port_id, struct nfp_port *port,
127 struct net_device *pf_netdev);
128 void nfp_repr_free(struct net_device *netdev);
129 struct net_device *
130 nfp_repr_alloc_mqs(struct nfp_app *app, unsigned int txqs, unsigned int rxqs);
131 void nfp_repr_clean_and_free(struct nfp_repr *repr);
132 void nfp_reprs_clean_and_free(struct nfp_app *app, struct nfp_reprs *reprs);
133 void nfp_reprs_clean_and_free_by_type(struct nfp_app *app,
134 enum nfp_repr_type type);
135 struct nfp_reprs *nfp_reprs_alloc(unsigned int num_reprs);
136 int nfp_reprs_resync_phys_ports(struct nfp_app *app);
137
nfp_repr_alloc(struct nfp_app * app)138 static inline struct net_device *nfp_repr_alloc(struct nfp_app *app)
139 {
140 return nfp_repr_alloc_mqs(app, 1, 1);
141 }
142 #endif /* NFP_NET_REPR_H */
143