blob: 2d3c12a39e6d9f7909c47e4fcc95de0db06ad926 [file] [log] [blame]
Codrin Ciubotariubfafe5c2015-07-24 16:55:27 +03001/*
2 * Copyright 2015 Freescale Semiconductor, Inc.
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 *
6 * Ethernet Switch commands
7 */
8
9#ifndef _CMD_ETHSW_H_
10#define _CMD_ETHSW_H_
11
12#define ETHSW_MAX_CMD_PARAMS 20
13#define ETHSW_CMD_PORT_ALL -1
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030014#define ETHSW_CMD_VLAN_ALL -1
Codrin Ciubotariubfafe5c2015-07-24 16:55:27 +030015
16/* IDs used to track keywords in a command */
17enum ethsw_keyword_id {
18 ethsw_id_key_end = -1,
19 ethsw_id_help,
20 ethsw_id_show,
21 ethsw_id_port,
22 ethsw_id_enable,
23 ethsw_id_disable,
Codrin Ciubotariuc0034732015-07-24 16:55:29 +030024 ethsw_id_statistics,
25 ethsw_id_clear,
Codrin Ciubotariu2d1607f2015-07-24 16:55:30 +030026 ethsw_id_learning,
27 ethsw_id_auto,
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030028 ethsw_id_vlan,
29 ethsw_id_fdb,
30 ethsw_id_add,
31 ethsw_id_del,
32 ethsw_id_flush,
Codrin Ciubotariu4718f952015-07-24 16:55:33 +030033 ethsw_id_pvid,
34 ethsw_id_untagged,
35 ethsw_id_all,
36 ethsw_id_none,
37 ethsw_id_egress,
38 ethsw_id_tag,
39 ethsw_id_classified,
Codrin Ciubotariu3a74bbe2015-07-24 16:55:34 +030040 ethsw_id_shared,
41 ethsw_id_private,
Codrin Ciubotariud1c9fe52015-07-24 16:55:35 +030042 ethsw_id_ingress,
43 ethsw_id_filtering,
Codrin Ciubotariubfafe5c2015-07-24 16:55:27 +030044 ethsw_id_count, /* keep last */
45};
46
47enum ethsw_keyword_opt_id {
48 ethsw_id_port_no = ethsw_id_count + 1,
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030049 ethsw_id_vlan_no,
Codrin Ciubotariu4718f952015-07-24 16:55:33 +030050 ethsw_id_pvid_no,
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030051 ethsw_id_add_del_no,
52 ethsw_id_add_del_mac,
Codrin Ciubotariubfafe5c2015-07-24 16:55:27 +030053 ethsw_id_count_all, /* keep last */
54};
55
56struct ethsw_command_def {
57 int cmd_to_keywords[ETHSW_MAX_CMD_PARAMS];
58 int cmd_keywords_nr;
59 int port;
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030060 int vid;
61 uchar ethaddr[6];
Codrin Ciubotariubfafe5c2015-07-24 16:55:27 +030062 int (*cmd_function)(struct ethsw_command_def *parsed_cmd);
63};
64
65/* Structure to be created and initialized by an Ethernet Switch driver */
66struct ethsw_command_func {
67 const char *ethsw_name;
68 int (*port_enable)(struct ethsw_command_def *parsed_cmd);
69 int (*port_disable)(struct ethsw_command_def *parsed_cmd);
70 int (*port_show)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariuc0034732015-07-24 16:55:29 +030071 int (*port_stats)(struct ethsw_command_def *parsed_cmd);
72 int (*port_stats_clear)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariu2d1607f2015-07-24 16:55:30 +030073 int (*port_learn)(struct ethsw_command_def *parsed_cmd);
74 int (*port_learn_show)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030075 int (*fdb_show)(struct ethsw_command_def *parsed_cmd);
76 int (*fdb_flush)(struct ethsw_command_def *parsed_cmd);
77 int (*fdb_entry_add)(struct ethsw_command_def *parsed_cmd);
78 int (*fdb_entry_del)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariu4718f952015-07-24 16:55:33 +030079 int (*pvid_show)(struct ethsw_command_def *parsed_cmd);
80 int (*pvid_set)(struct ethsw_command_def *parsed_cmd);
81 int (*vlan_show)(struct ethsw_command_def *parsed_cmd);
82 int (*vlan_set)(struct ethsw_command_def *parsed_cmd);
83 int (*port_untag_show)(struct ethsw_command_def *parsed_cmd);
84 int (*port_untag_set)(struct ethsw_command_def *parsed_cmd);
85 int (*port_egr_vlan_show)(struct ethsw_command_def *parsed_cmd);
86 int (*port_egr_vlan_set)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariu3a74bbe2015-07-24 16:55:34 +030087 int (*vlan_learn_show)(struct ethsw_command_def *parsed_cmd);
88 int (*vlan_learn_set)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariud1c9fe52015-07-24 16:55:35 +030089 int (*port_ingr_filt_show)(struct ethsw_command_def *parsed_cmd);
90 int (*port_ingr_filt_set)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariubfafe5c2015-07-24 16:55:27 +030091};
92
93int ethsw_define_functions(const struct ethsw_command_func *cmd_func);
94
95#endif /* _CMD_ETHSW_H_ */