blob: cc9708e9ac4c75e88d9d91b3b517215d7bc6a884 [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 Ciubotariubfafe5c2015-07-24 16:55:27 +030040 ethsw_id_count, /* keep last */
41};
42
43enum ethsw_keyword_opt_id {
44 ethsw_id_port_no = ethsw_id_count + 1,
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030045 ethsw_id_vlan_no,
Codrin Ciubotariu4718f952015-07-24 16:55:33 +030046 ethsw_id_pvid_no,
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030047 ethsw_id_add_del_no,
48 ethsw_id_add_del_mac,
Codrin Ciubotariubfafe5c2015-07-24 16:55:27 +030049 ethsw_id_count_all, /* keep last */
50};
51
52struct ethsw_command_def {
53 int cmd_to_keywords[ETHSW_MAX_CMD_PARAMS];
54 int cmd_keywords_nr;
55 int port;
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030056 int vid;
57 uchar ethaddr[6];
Codrin Ciubotariubfafe5c2015-07-24 16:55:27 +030058 int (*cmd_function)(struct ethsw_command_def *parsed_cmd);
59};
60
61/* Structure to be created and initialized by an Ethernet Switch driver */
62struct ethsw_command_func {
63 const char *ethsw_name;
64 int (*port_enable)(struct ethsw_command_def *parsed_cmd);
65 int (*port_disable)(struct ethsw_command_def *parsed_cmd);
66 int (*port_show)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariuc0034732015-07-24 16:55:29 +030067 int (*port_stats)(struct ethsw_command_def *parsed_cmd);
68 int (*port_stats_clear)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariu2d1607f2015-07-24 16:55:30 +030069 int (*port_learn)(struct ethsw_command_def *parsed_cmd);
70 int (*port_learn_show)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariu4732e352015-09-09 18:00:52 +030071 int (*fdb_show)(struct ethsw_command_def *parsed_cmd);
72 int (*fdb_flush)(struct ethsw_command_def *parsed_cmd);
73 int (*fdb_entry_add)(struct ethsw_command_def *parsed_cmd);
74 int (*fdb_entry_del)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariu4718f952015-07-24 16:55:33 +030075 int (*pvid_show)(struct ethsw_command_def *parsed_cmd);
76 int (*pvid_set)(struct ethsw_command_def *parsed_cmd);
77 int (*vlan_show)(struct ethsw_command_def *parsed_cmd);
78 int (*vlan_set)(struct ethsw_command_def *parsed_cmd);
79 int (*port_untag_show)(struct ethsw_command_def *parsed_cmd);
80 int (*port_untag_set)(struct ethsw_command_def *parsed_cmd);
81 int (*port_egr_vlan_show)(struct ethsw_command_def *parsed_cmd);
82 int (*port_egr_vlan_set)(struct ethsw_command_def *parsed_cmd);
Codrin Ciubotariubfafe5c2015-07-24 16:55:27 +030083};
84
85int ethsw_define_functions(const struct ethsw_command_func *cmd_func);
86
87#endif /* _CMD_ETHSW_H_ */