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__ */