hc
2023-11-07 f45e756958099c35d6afb746df1d40a1c6302cfc
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
/* SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) */
/*
 * Copyright (c) 2018 Mellanox Technologies. All rights reserved.
 */
 
#ifndef _MLX5_ESWITCH_
#define _MLX5_ESWITCH_
 
#include <linux/mlx5/driver.h>
 
#define MLX5_ESWITCH_MANAGER(mdev) MLX5_CAP_GEN(mdev, eswitch_manager)
 
enum {
   SRIOV_NONE,
   SRIOV_LEGACY,
   SRIOV_OFFLOADS
};
 
enum {
   REP_ETH,
   REP_IB,
   NUM_REP_TYPES,
};
 
struct mlx5_eswitch_rep;
struct mlx5_eswitch_rep_if {
   int               (*load)(struct mlx5_core_dev *dev,
                      struct mlx5_eswitch_rep *rep);
   void               (*unload)(struct mlx5_eswitch_rep *rep);
   void               *(*get_proto_dev)(struct mlx5_eswitch_rep *rep);
   void            *priv;
   bool               valid;
};
 
struct mlx5_eswitch_rep {
   struct mlx5_eswitch_rep_if rep_if[NUM_REP_TYPES];
   u16               vport;
   u8               hw_id[ETH_ALEN];
   u16               vlan;
   u32               vlan_refcount;
};
 
void mlx5_eswitch_register_vport_rep(struct mlx5_eswitch *esw,
                    int vport_index,
                    struct mlx5_eswitch_rep_if *rep_if,
                    u8 rep_type);
void mlx5_eswitch_unregister_vport_rep(struct mlx5_eswitch *esw,
                      int vport_index,
                      u8 rep_type);
void *mlx5_eswitch_get_proto_dev(struct mlx5_eswitch *esw,
                int vport,
                u8 rep_type);
struct mlx5_eswitch_rep *mlx5_eswitch_vport_rep(struct mlx5_eswitch *esw,
                       int vport);
void *mlx5_eswitch_uplink_get_proto_dev(struct mlx5_eswitch *esw, u8 rep_type);
u8 mlx5_eswitch_mode(struct mlx5_eswitch *esw);
struct mlx5_flow_handle *
mlx5_eswitch_add_send_to_vport_rule(struct mlx5_eswitch *esw,
                   int vport, u32 sqn);
#endif