File: smfs.c

package info (click to toggle)
linux 6.1.4-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 1,532,052 kB
  • sloc: ansic: 23,400,063; asm: 266,720; sh: 108,896; makefile: 49,712; python: 36,925; perl: 36,810; cpp: 6,044; yacc: 4,904; lex: 2,722; awk: 1,440; ruby: 25; sed: 5
file content (68 lines) | stat: -rw-r--r-- 1,650 bytes parent folder | download | duplicates (15)
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
// SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB
/* Copyright (c) 2021, NVIDIA CORPORATION & AFFILIATES. */

#include <linux/kernel.h>
#include <linux/mlx5/driver.h>

#include "smfs.h"

struct mlx5dr_matcher *
mlx5_smfs_matcher_create(struct mlx5dr_table *table, u32 priority, struct mlx5_flow_spec *spec)
{
	struct mlx5dr_match_parameters matcher_mask = {};

	matcher_mask.match_buf = (u64 *)&spec->match_criteria;
	matcher_mask.match_sz = DR_SZ_MATCH_PARAM;

	return mlx5dr_matcher_create(table, priority, spec->match_criteria_enable, &matcher_mask);
}

void
mlx5_smfs_matcher_destroy(struct mlx5dr_matcher *matcher)
{
	mlx5dr_matcher_destroy(matcher);
}

struct mlx5dr_table *
mlx5_smfs_table_get_from_fs_ft(struct mlx5_flow_table *ft)
{
	return mlx5dr_table_get_from_fs_ft(ft);
}

struct mlx5dr_action *
mlx5_smfs_action_create_dest_table(struct mlx5dr_table *table)
{
	return mlx5dr_action_create_dest_table(table);
}

struct mlx5dr_action *
mlx5_smfs_action_create_flow_counter(u32 counter_id)
{
	return mlx5dr_action_create_flow_counter(counter_id);
}

void
mlx5_smfs_action_destroy(struct mlx5dr_action *action)
{
	mlx5dr_action_destroy(action);
}

struct mlx5dr_rule *
mlx5_smfs_rule_create(struct mlx5dr_matcher *matcher, struct mlx5_flow_spec *spec,
		      size_t num_actions, struct mlx5dr_action *actions[],
		      u32 flow_source)
{
	struct mlx5dr_match_parameters value = {};

	value.match_buf = (u64 *)spec->match_value;
	value.match_sz = DR_SZ_MATCH_PARAM;

	return mlx5dr_rule_create(matcher, &value, num_actions, actions, flow_source);
}

void
mlx5_smfs_rule_destroy(struct mlx5dr_rule *rule)
{
	mlx5dr_rule_destroy(rule);
}