Contributors: 17
| Author |
Tokens |
Token Proportion |
Commits |
Commit Proportion |
| Maxim Mikityanskiy |
186 |
70.19% |
5 |
18.52% |
| Andy Gospodarek |
14 |
5.28% |
1 |
3.70% |
| Tariq Toukan |
11 |
4.15% |
3 |
11.11% |
| Tal Gilboa |
9 |
3.40% |
1 |
3.70% |
| Aya Levin |
7 |
2.64% |
3 |
11.11% |
| Paul Blakey |
6 |
2.26% |
2 |
7.41% |
| Achiad Shochat |
6 |
2.26% |
1 |
3.70% |
| Amir Vadai |
5 |
1.89% |
1 |
3.70% |
| Khalid Manaa |
4 |
1.51% |
1 |
3.70% |
| Erez Shitrit |
3 |
1.13% |
1 |
3.70% |
| Saeed Mahameed |
3 |
1.13% |
2 |
7.41% |
| Gal Pressman |
3 |
1.13% |
1 |
3.70% |
| Matthew Finlay |
2 |
0.75% |
1 |
3.70% |
| Hadar Hen Zion |
2 |
0.75% |
1 |
3.70% |
| Eran Ben Elisha |
2 |
0.75% |
1 |
3.70% |
| Vlad Buslov |
1 |
0.38% |
1 |
3.70% |
| Or Gerlitz |
1 |
0.38% |
1 |
3.70% |
| Total |
265 |
|
27 |
|
/* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */
/* Copyright (c) 2021, Mellanox Technologies inc. All rights reserved. */
#ifndef __MLX5_EN_TIR_H__
#define __MLX5_EN_TIR_H__
#include <linux/kernel.h>
struct mlx5e_rss_params_hash {
u8 hfunc;
u8 toeplitz_hash_key[40];
bool symmetric;
};
struct mlx5e_rss_params_traffic_type {
u8 l3_prot_type;
u8 l4_prot_type;
u32 rx_hash_fields;
};
struct mlx5e_tir_builder;
struct mlx5e_packet_merge_param;
struct mlx5e_tir_builder *mlx5e_tir_builder_alloc(bool modify);
void mlx5e_tir_builder_free(struct mlx5e_tir_builder *builder);
void mlx5e_tir_builder_clear(struct mlx5e_tir_builder *builder);
void mlx5e_tir_builder_build_inline(struct mlx5e_tir_builder *builder, u32 tdn, u32 rqn);
void mlx5e_tir_builder_build_rqt(struct mlx5e_tir_builder *builder, u32 tdn,
u32 rqtn, bool inner_ft_support);
void mlx5e_tir_builder_build_packet_merge(struct mlx5e_tir_builder *builder,
const struct mlx5e_packet_merge_param *pkt_merge_param);
void mlx5e_tir_builder_build_rss(struct mlx5e_tir_builder *builder,
const struct mlx5e_rss_params_hash *rss_hash,
const struct mlx5e_rss_params_traffic_type *rss_tt,
bool inner);
void mlx5e_tir_builder_build_direct(struct mlx5e_tir_builder *builder);
void mlx5e_tir_builder_build_self_lb_block(struct mlx5e_tir_builder *builder,
bool enable_uc_lb,
bool enable_mc_lb);
void mlx5e_tir_builder_build_tls(struct mlx5e_tir_builder *builder);
struct mlx5_core_dev;
struct mlx5e_tir {
struct mlx5_core_dev *mdev;
u32 tirn;
struct list_head list;
};
int mlx5e_tir_init(struct mlx5e_tir *tir, struct mlx5e_tir_builder *builder,
struct mlx5_core_dev *mdev, bool reg);
void mlx5e_tir_destroy(struct mlx5e_tir *tir);
static inline u32 mlx5e_tir_get_tirn(struct mlx5e_tir *tir)
{
return tir->tirn;
}
int mlx5e_tir_modify(struct mlx5e_tir *tir, struct mlx5e_tir_builder *builder);
#endif /* __MLX5_EN_TIR_H__ */