]> git.ipfire.org Git - people/ms/u-boot.git/blobdiff - include/ethsw.h
Merge git://git.denx.de/u-boot-sh
[people/ms/u-boot.git] / include / ethsw.h
index cc9708e9ac4c75e88d9d91b3b517215d7bc6a884..25f358d128e0c2a8074e82896a1a5d5f64442948 100644 (file)
@@ -12,6 +12,7 @@
 #define ETHSW_MAX_CMD_PARAMS 20
 #define ETHSW_CMD_PORT_ALL -1
 #define ETHSW_CMD_VLAN_ALL -1
+#define ETHSW_CMD_AGGR_GRP_NONE -1
 
 /* IDs used to track keywords in a command */
 enum ethsw_keyword_id {
@@ -37,6 +38,11 @@ enum ethsw_keyword_id {
        ethsw_id_egress,
        ethsw_id_tag,
        ethsw_id_classified,
+       ethsw_id_shared,
+       ethsw_id_private,
+       ethsw_id_ingress,
+       ethsw_id_filtering,
+       ethsw_id_aggr,
        ethsw_id_count, /* keep last */
 };
 
@@ -46,6 +52,7 @@ enum ethsw_keyword_opt_id {
        ethsw_id_pvid_no,
        ethsw_id_add_del_no,
        ethsw_id_add_del_mac,
+       ethsw_id_aggr_no,
        ethsw_id_count_all,     /* keep last */
 };
 
@@ -54,6 +61,7 @@ struct ethsw_command_def {
        int cmd_keywords_nr;
        int port;
        int vid;
+       int aggr_grp;
        uchar ethaddr[6];
        int (*cmd_function)(struct ethsw_command_def *parsed_cmd);
 };
@@ -80,6 +88,12 @@ struct ethsw_command_func {
        int (*port_untag_set)(struct ethsw_command_def *parsed_cmd);
        int (*port_egr_vlan_show)(struct ethsw_command_def *parsed_cmd);
        int (*port_egr_vlan_set)(struct ethsw_command_def *parsed_cmd);
+       int (*vlan_learn_show)(struct ethsw_command_def *parsed_cmd);
+       int (*vlan_learn_set)(struct ethsw_command_def *parsed_cmd);
+       int (*port_ingr_filt_show)(struct ethsw_command_def *parsed_cmd);
+       int (*port_ingr_filt_set)(struct ethsw_command_def *parsed_cmd);
+       int (*port_aggr_show)(struct ethsw_command_def *parsed_cmd);
+       int (*port_aggr_set)(struct ethsw_command_def *parsed_cmd);
 };
 
 int ethsw_define_functions(const struct ethsw_command_func *cmd_func);