hc
2023-12-09 b22da3d8526a935aa31e086e63f60ff3246cb61c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */
/* Copyright (C) 2017-2018 Netronome Systems, Inc. */
 
#ifndef NFP_NET_REPR_H
#define NFP_NET_REPR_H
 
struct metadata_dst;
struct nfp_app;
struct nfp_net;
struct nfp_port;
 
#include <net/dst_metadata.h>
 
/**
 * struct nfp_reprs - container for representor netdevs
 * @num_reprs:    Number of elements in reprs array
 * @reprs:    Array of representor netdevs
 */
struct nfp_reprs {
   unsigned int num_reprs;
   struct net_device __rcu *reprs[];
};
 
/**
 * struct nfp_repr_pcpu_stats
 * @rx_packets:    Received packets
 * @rx_bytes:    Received bytes
 * @tx_packets:    Transmitted packets
 * @tx_bytes:    Transmitted dropped
 * @tx_drops:    Packets dropped on transmit
 * @syncp:    Reference count
 */
struct nfp_repr_pcpu_stats {
   u64 rx_packets;
   u64 rx_bytes;
   u64 tx_packets;
   u64 tx_bytes;
   u64 tx_drops;
   struct u64_stats_sync syncp;
};
 
/**
 * struct nfp_repr - priv data for representor netdevs
 * @netdev:    Back pointer to netdev
 * @dst:    Destination for packet TX
 * @port:    Port of representor
 * @app:    APP handle
 * @stats:    Statistic of packets hitting CPU
 * @app_priv:    Pointer for APP data
 */
struct nfp_repr {
   struct net_device *netdev;
   struct metadata_dst *dst;
   struct nfp_port *port;
   struct nfp_app *app;
   struct nfp_repr_pcpu_stats __percpu *stats;
   void *app_priv;
};
 
/**
 * enum nfp_repr_type - type of representor
 * @NFP_REPR_TYPE_PHYS_PORT:    external NIC port
 * @NFP_REPR_TYPE_PF:        physical function
 * @NFP_REPR_TYPE_VF:        virtual function
 * @__NFP_REPR_TYPE_MAX:    number of representor types
 */
enum nfp_repr_type {
   NFP_REPR_TYPE_PHYS_PORT,
   NFP_REPR_TYPE_PF,
   NFP_REPR_TYPE_VF,
 
   __NFP_REPR_TYPE_MAX,
};
#define NFP_REPR_TYPE_MAX (__NFP_REPR_TYPE_MAX - 1)
 
extern const struct net_device_ops nfp_repr_netdev_ops;
 
static inline bool nfp_netdev_is_nfp_repr(struct net_device *netdev)
{
   return netdev->netdev_ops == &nfp_repr_netdev_ops;
}
 
static inline int nfp_repr_get_port_id(struct net_device *netdev)
{
   struct nfp_repr *priv = netdev_priv(netdev);
 
   return priv->dst->u.port_info.port_id;
}
 
struct net_device *
nfp_repr_get_locked(struct nfp_app *app, struct nfp_reprs *set,
           unsigned int id);
 
void nfp_repr_inc_rx_stats(struct net_device *netdev, unsigned int len);
void
nfp_repr_transfer_features(struct net_device *netdev, struct net_device *lower);
int nfp_repr_init(struct nfp_app *app, struct net_device *netdev,
         u32 cmsg_port_id, struct nfp_port *port,
         struct net_device *pf_netdev);
void nfp_repr_free(struct net_device *netdev);
struct net_device *
nfp_repr_alloc_mqs(struct nfp_app *app, unsigned int txqs, unsigned int rxqs);
void nfp_repr_clean_and_free(struct nfp_repr *repr);
void nfp_reprs_clean_and_free(struct nfp_app *app, struct nfp_reprs *reprs);
void nfp_reprs_clean_and_free_by_type(struct nfp_app *app,
                     enum nfp_repr_type type);
struct nfp_reprs *nfp_reprs_alloc(unsigned int num_reprs);
int nfp_reprs_resync_phys_ports(struct nfp_app *app);
 
static inline struct net_device *nfp_repr_alloc(struct nfp_app *app)
{
   return nfp_repr_alloc_mqs(app, 1, 1);
}
#endif /* NFP_NET_REPR_H */