summaryrefslogtreecommitdiffstats
path: root/examples/ip_pipeline/pipeline/pipeline_firewall.h
blob: 27304b007b73208d9f45e234f0c72e9f2c3d7eab (plain)
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: BSD-3-Clause
 * Copyright(c) 2010-2015 Intel Corporation
 */

#ifndef __INCLUDE_PIPELINE_FIREWALL_H__
#define __INCLUDE_PIPELINE_FIREWALL_H__

#include "pipeline.h"
#include "pipeline_firewall_be.h"

int
app_pipeline_firewall_add_rule(struct app_params *app,
	uint32_t pipeline_id,
	struct pipeline_firewall_key *key,
	uint32_t priority,
	uint32_t port_id);

int
app_pipeline_firewall_delete_rule(struct app_params *app,
	uint32_t pipeline_id,
	struct pipeline_firewall_key *key);

int
app_pipeline_firewall_add_bulk(struct app_params *app,
		uint32_t pipeline_id,
		struct pipeline_firewall_key *keys,
		uint32_t n_keys,
		uint32_t *priorities,
		uint32_t *port_ids);

int
app_pipeline_firewall_delete_bulk(struct app_params *app,
	uint32_t pipeline_id,
	struct pipeline_firewall_key *keys,
	uint32_t n_keys);

int
app_pipeline_firewall_add_default_rule(struct app_params *app,
	uint32_t pipeline_id,
	uint32_t port_id);

int
app_pipeline_firewall_delete_default_rule(struct app_params *app,
	uint32_t pipeline_id);

#ifndef APP_PIPELINE_FIREWALL_MAX_RULES_IN_FILE
#define APP_PIPELINE_FIREWALL_MAX_RULES_IN_FILE		65536
#endif

int
app_pipeline_firewall_load_file(char *filename,
	struct pipeline_firewall_key *keys,
	uint32_t *priorities,
	uint32_t *port_ids,
	uint32_t *n_keys,
	uint32_t *line);

extern struct pipeline_type pipeline_firewall;

#endif