net/hinic: remove optical module operation
[dpdk.git] / drivers / net / hinic / base / hinic_pmd_niccfg.h
index 94371bb..04cd374 100644 (file)
@@ -380,6 +380,29 @@ struct hinic_mtu {
        u32     mtu;
 };
 
+struct hinic_vlan_config {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u16     func_id;
+       u16     vlan_id;
+};
+
+struct hinic_vlan_filter {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u16     func_id;
+       u8      rsvd1[2];
+       u32     vlan_filter_ctrl;
+};
+
+struct hinic_vlan_offload {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u16     func_id;
+       u8      vlan_rx_offload;
+       u8      rsvd1[5];
+};
+
 struct hinic_get_link {
        struct hinic_mgmt_msg_head mgmt_msg_head;
 
@@ -448,6 +471,17 @@ struct hinic_rx_mode_config {
        u32     rx_mode;
 };
 
+#define HINIC_MGMT_VERSION_MAX_LEN     32
+#define HINIC_COMPILE_TIME_LEN         20
+#define HINIC_FW_VERSION_NAME          16
+
+struct hinic_version_info {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u8 ver[HINIC_FW_VERSION_NAME];
+       u8 time[HINIC_COMPILE_TIME_LEN];
+};
+
 /* rss */
 struct nic_rss_indirect_tbl {
        u32 group_index;
@@ -555,6 +589,13 @@ struct hinic_link_mode_cmd {
        u16     advertised;
 };
 
+struct hinic_set_xsfp_status {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u32 port_id;
+       u32 xsfp_tx_dis;        /* 0: tx enable; 1: tx disable */
+};
+
 struct hinic_clear_qp_resource {
        struct hinic_mgmt_msg_head mgmt_msg_head;
 
@@ -586,6 +627,209 @@ struct hinic_port_anti_attack_rate {
        u32     xbs;    /* eXtended Burst Size */
 };
 
+struct pa_u8_s {
+       u8   val8;
+       u8   mask8;
+};
+
+struct pa_u16_s {
+       u16  val16;
+       u16  mask16;
+};
+
+struct pa_u32_s {
+       u32  val32;
+       u32  mask32;
+};
+
+struct pa_u48_s {
+       u8   val8[6];
+       u8   mask8[6];
+};
+
+struct pa_u64_s {
+       u8   val8[8];
+       u8   mask8[8];
+};
+
+struct tag_pa_eth_ip_header {
+       struct pa_u8_s          ip_ver; /* 3bit */
+       struct pa_u8_s          ipv4_option_flag; /* 1bit */
+       /* 8bit ipv4 option or ipv6 next header */
+       struct pa_u8_s          protocol;
+       struct pa_u8_s          dscp;   /* 6bit DSCP */
+};
+
+struct tag_pa_common_l2_header {
+       struct pa_u48_s         dmac; /* dmac 48bit */
+       struct pa_u16_s         eth_type; /* ethernet type/length 16bit */
+       struct pa_u8_s          tag_flag; /* tag flag: 4bit */
+       struct pa_u8_s          np2np_hdr_qindex; /* NP2NP Header Qindex 4bit */
+       struct pa_u8_s          e_tag_pcp; /* 3bit */
+       struct pa_u8_s          vlan_layer; /* 2bit */
+       struct pa_u8_s          s_tag; /* 3bit */
+       struct pa_u8_s          c_tag; /* 3bit */
+       struct pa_u16_s         vlan_id; /* 12bit */
+};
+
+struct tag_pa_tcp {
+       struct pa_u16_s         sport; /* 16bit */
+       struct pa_u16_s         dport; /* 16bit */
+       struct pa_u16_s         tcp_flag; /* 6bit */
+};
+
+struct tag_pa_udp {
+       struct pa_u16_s         sport; /* 16bit */
+       struct pa_u16_s         dport; /* 16bit */
+       /* 8bit :
+        * 1.udp dport=67/68 && ipv4 protocol=0x11
+        * 2.udp dport=546/547 && ipv6 next header=0x11
+        * 3. do not care
+        */
+       struct pa_u8_s          dhcp_op_or_msg_type;
+};
+
+/* ICMP:
+ * ipv4 protocol = 0x1
+ * ipv6 next header = 0x3A
+ */
+struct tag_pa_icmp {
+       struct pa_u8_s          type; /* 8bit */
+       struct pa_u8_s          code; /* 8bit */
+};
+
+/* IGMP:
+ * ipv4 protocol = 0x2
+ */
+struct tag_pa_ipv4_igmp {
+       struct pa_u32_s         dip; /* 32bit */
+       struct pa_u8_s          type; /* 8bit */
+};
+
+struct tag_pa_rule {
+       struct pa_u8_s ncsi_flag; /* 1bit valid */
+       struct tag_pa_common_l2_header l2_header;
+
+       u8 eth_type;
+
+       struct pa_u64_s eth_other; /* eth_type=other 64bit */
+       struct pa_u8_s  eth_roce_opcode; /* eth_type=roce 8bit opcode */
+
+       struct tag_pa_eth_ip_header ip_header; /* eth_type=ip */
+
+       u8 ip_protocol_type;
+
+       struct tag_pa_tcp eth_ip_tcp; /* eth_type=ip && ip_protocol = tcp */
+       struct tag_pa_udp eth_ip_udp; /* eth_type=ip && ip_protocol = udp */
+       struct tag_pa_icmp eth_ip_icmp; /* eth_type=ip && ip_protocol = icmp */
+
+       /* eth_type=ip && ip_protocol = ipv4_igmp */
+       struct tag_pa_ipv4_igmp eth_ipv4_igmp;
+
+       /* eth_type=ip && ip_protocol = sctp;
+        * 16bit ipv4 protocol=0x84 or ipv6 nhr=0x84
+        */
+       struct pa_u16_s eth_ip_sctp;
+};
+
+struct tag_pa_action {
+       u16     pkt_type;
+       u8      err_type;
+       u8      pri;
+       u8      fwd_action;
+       u8      push_len;
+};
+
+struct hinic_fdir_tcam_info {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u16     tcam_index;
+       u8      flag; /* clear or set tcam table flag */
+       u8      rsvd1;
+       struct tag_pa_rule filter_rule;
+       struct tag_pa_action filter_action;
+};
+
+#define TCAM_SET       0x1
+#define TCAM_CLEAR     0x2
+
+struct hinic_port_qfilter_info {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u16 func_id;
+       u8 normal_type_enable;
+       u8 filter_type_enable;
+       u8 filter_enable;
+       u8 filter_type;
+       u8 qid;
+       u8 fdir_flag;
+       u32 key;
+};
+
+struct hinic_port_tcam_info {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u16 func_id;
+       u8 tcam_enable;
+       u8 rsvd1;
+       u32 rsvd2;
+};
+
+#define HINIC_MAX_TCAM_RULES_NUM   (10240)
+#define HINIC_TCAM_BLOCK_ENABLE      1
+#define HINIC_TCAM_BLOCK_DISABLE     0
+
+struct tag_tcam_result {
+       u32 qid;
+       u32 rsvd;
+};
+
+#define TCAM_FLOW_KEY_SIZE   24
+
+struct tag_tcam_key_x_y {
+       u8 x[TCAM_FLOW_KEY_SIZE];
+       u8 y[TCAM_FLOW_KEY_SIZE];
+};
+
+struct tag_tcam_cfg_rule {
+       u32 index;
+       struct tag_tcam_result data;
+       struct tag_tcam_key_x_y key;
+};
+
+struct tag_fdir_add_rule_cmd {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+       struct tag_tcam_cfg_rule rule;
+};
+
+struct tag_fdir_del_rule_cmd {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u32 index_start;
+       u32 index_num;
+};
+
+struct hinic_cmd_flush_tcam_rules {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u16 func_id;
+       u16 rsvd;
+};
+
+struct hinic_cmd_ctrl_tcam_block {
+       struct hinic_mgmt_msg_head mgmt_msg_head;
+
+       u16 func_id;
+       u8  alloc_en; /* 0: free tcam block, 1: alloc tcam block */
+       /*
+        * 0: alloc 1k size tcam block,
+        * 1: alloc 128 size tcam block, others rsvd
+        */
+       u8  tcam_type;
+       u16 tcam_block_index;
+       u16 rsvd;
+};
+
 int hinic_set_mac(void *hwdev, u8 *mac_addr, u16 vlan_id, u16 func_id);
 
 int hinic_del_mac(void *hwdev, u8 *mac_addr, u16 vlan_id, u16 func_id);
@@ -597,6 +841,12 @@ int hinic_get_default_mac(void *hwdev, u8 *mac_addr);
 
 int hinic_set_port_mtu(void *hwdev, u32 new_mtu);
 
+int hinic_add_remove_vlan(void *hwdev, u16 vlan_id, u16 func_id, bool add);
+
+int hinic_config_vlan_filter(void *hwdev, u32 vlan_filter_ctrl);
+
+int hinic_set_rx_vlan_offload(void *hwdev, u8 en);
+
 int hinic_set_vport_enable(void *hwdev, bool enable);
 
 int hinic_set_port_enable(void *hwdev, bool enable);
@@ -609,6 +859,8 @@ int hinic_set_rx_vhd_mode(void *hwdev, u16 vhd_mode, u16 rx_buf_sz);
 
 int hinic_set_pause_config(void *hwdev, struct nic_pause_config nic_pause);
 
+int hinic_get_pause_info(void *hwdev, struct nic_pause_config *nic_pause);
+
 int hinic_reset_port_link_cfg(void *hwdev);
 
 int hinic_dcb_set_ets(void *hwdev, u8 *up_tc, u8 *pg_bw, u8 *pgid, u8 *up_bw,
@@ -648,6 +900,8 @@ int hinic_rss_template_free(void *hwdev, u8 tmpl_idx);
 
 int hinic_set_rx_mode(void *hwdev, u32 enable);
 
+int hinic_get_mgmt_version(void *hwdev, char *fw);
+
 int hinic_set_rx_csum_offload(void *hwdev, u32 en);
 
 int hinic_set_link_status_follow(void *hwdev,
@@ -673,4 +927,27 @@ void hinic_vf_func_free(struct hinic_hwdev *hwdev);
 
 int hinic_vf_get_default_cos(struct hinic_hwdev *hwdev, u8 *cos_id);
 
+int hinic_set_fdir_filter(void *hwdev, u8 filter_type, u8 qid,
+               u8 type_enable, bool enable);
+
+int hinic_set_normal_filter(void *hwdev, u8 qid, u8 normal_type_enable,
+               u32 key, bool enable, u8 flag);
+
+int hinic_set_fdir_tcam(void *hwdev, u16 type_mask,
+       struct tag_pa_rule *filter_rule, struct tag_pa_action *filter_action);
+
+int hinic_clear_fdir_tcam(void *hwdev, u16 type_mask);
+
+int hinic_add_tcam_rule(void *hwdev, struct tag_tcam_cfg_rule *tcam_rule);
+
+int hinic_del_tcam_rule(void *hwdev, u32 index);
+
+int hinic_alloc_tcam_block(void *hwdev, u8 block_type, u16 *index);
+
+int hinic_free_tcam_block(void *hwdev, u8 block_type, u16 *index);
+
+int hinic_flush_tcam_rule(void *hwdev);
+
+int hinic_set_fdir_tcam_rule_filter(void *hwdev, bool enable);
+
 #endif /* _HINIC_PMD_NICCFG_H_ */