Imported Upstream version 16.11
[deb_dpdk.git] / drivers / net / qede / base / ecore_init_fw_funcs.h
index 5280cd7..9df0e7d 100644 (file)
@@ -26,12 +26,14 @@ struct init_qm_pq_params;
  * @return The required host memory size in 4KB units.
  */
 u32 ecore_qm_pf_mem_size(u8 pf_id,
-                        u32 num_pf_cids,
-                        u32 num_vf_cids,
-                        u32 num_tids, u16 num_pf_pqs, u16 num_vf_pqs);
+                                                u32 num_pf_cids,
+                                                u32 num_vf_cids,
+                                                u32 num_tids,
+                                                u16 num_pf_pqs,
+                                                u16 num_vf_pqs);
 /**
- * @brief ecore_qm_common_rt_init -
- * Prepare QM runtime init values for the engine phase
+ * @brief ecore_qm_common_rt_init - Prepare QM runtime init values for engine
+ *                                  phase
  *
  * @param p_hwfn
  * @param max_ports_per_engine - max number of ports per engine in HW
@@ -40,38 +42,64 @@ u32 ecore_qm_pf_mem_size(u8 pf_id,
  * @param pf_wfq_en                            - enable per-PF WFQ
  * @param vport_rl_en                  - enable per-VPORT rate limiters
  * @param vport_wfq_en                 - enable per-VPORT WFQ
- * @param port_params- array of size MAX_NUM_PORTS with parameters for each port
+ * @param port_params - array of size MAX_NUM_PORTS with params for each port
  *
  * @return 0 on success, -1 on error.
  */
 int ecore_qm_common_rt_init(struct ecore_hwfn *p_hwfn,
-                           u8 max_ports_per_engine,
-                           u8 max_phys_tcs_per_port,
-                           bool pf_rl_en,
-                           bool pf_wfq_en,
-                           bool vport_rl_en,
-                           bool vport_wfq_en,
-                           struct init_qm_port_params
-                           port_params[MAX_NUM_PORTS]);
-
+                        u8 max_ports_per_engine,
+                        u8 max_phys_tcs_per_port,
+                        bool pf_rl_en,
+                        bool pf_wfq_en,
+                        bool vport_rl_en,
+                        bool vport_wfq_en,
+                        struct init_qm_port_params port_params[MAX_NUM_PORTS]);
+/**
+ * @brief ecore_qm_pf_rt_init  Prepare QM runtime init values for the PF phase
+ *
+ * @param p_hwfn
+ * @param p_ptt                        - ptt window used for writing the registers
+ * @param port_id                              - port ID
+ * @param pf_id                                        - PF ID
+ * @param max_phys_tcs_per_port        - max number of physical TCs per port in HW
+ * @param is_first_pf                  - 1 = first PF in engine, 0 = othwerwise
+ * @param num_pf_cids                  - number of connections used by this PF
+ * @param num_vf_cids          - number of connections used by VFs of this PF
+ * @param num_tids                     - number of tasks used by this PF
+ * @param start_pq                     - first Tx PQ ID associated with this PF
+ * @param num_pf_pqs   - number of Tx PQs associated with this PF (non-VF)
+ * @param num_vf_pqs                   - number of Tx PQs associated with a VF
+ * @param start_vport                  - first VPORT ID associated with this PF
+ * @param num_vports - number of VPORTs associated with this PF
+ * @param pf_wfq - WFQ weight. if PF WFQ is globally disabled, the weight must
+ *                be 0. otherwise, the weight must be non-zero.
+ * @param pf_rl - rate limit in Mb/sec units. a value of 0 means don't
+ *                configure. ignored if PF RL is globally disabled.
+ * @param pq_params - array of size (num_pf_pqs+num_vf_pqs) with parameters for
+ *                    each Tx PQ associated with the specified PF.
+ * @param vport_params - array of size num_vports with parameters for each
+ *                       associated VPORT.
+ *
+ * @return 0 on success, -1 on error.
+ */
 int ecore_qm_pf_rt_init(struct ecore_hwfn *p_hwfn,
-                       struct ecore_ptt *p_ptt,
-                       u8 port_id,
-                       u8 pf_id,
-                       u8 max_phys_tcs_per_port,
-                       bool is_first_pf,
-                       u32 num_pf_cids,
-                       u32 num_vf_cids,
-                       u32 num_tids,
-                       u16 start_pq,
-                       u16 num_pf_pqs,
-                       u16 num_vf_pqs,
-                       u8 start_vport,
-                       u8 num_vports,
-                       u16 pf_wfq,
-                       u32 pf_rl,
-                       struct init_qm_pq_params *pq_params,
-                       struct init_qm_vport_params *vport_params);
+                               struct ecore_ptt *p_ptt,
+                               u8 port_id,
+                               u8 pf_id,
+                               u8 max_phys_tcs_per_port,
+                               bool is_first_pf,
+                               u32 num_pf_cids,
+                               u32 num_vf_cids,
+                               u32 num_tids,
+                               u16 start_pq,
+                               u16 num_pf_pqs,
+                               u16 num_vf_pqs,
+                               u8 start_vport,
+                               u8 num_vports,
+                               u16 pf_wfq,
+                               u32 pf_rl,
+                               struct init_qm_pq_params *pq_params,
+                               struct init_qm_vport_params *vport_params);
 /**
  * @brief ecore_init_pf_wfq  Initializes the WFQ weight of the specified PF
  *
@@ -83,7 +111,9 @@ int ecore_qm_pf_rt_init(struct ecore_hwfn *p_hwfn,
  * @return 0 on success, -1 on error.
  */
 int ecore_init_pf_wfq(struct ecore_hwfn *p_hwfn,
-                     struct ecore_ptt *p_ptt, u8 pf_id, u16 pf_wfq);
+                                         struct ecore_ptt *p_ptt,
+                                         u8 pf_id,
+                                         u16 pf_wfq);
 /**
  * @brief ecore_init_pf_rl  Initializes the rate limit of the specified PF
  *
@@ -95,9 +125,11 @@ int ecore_init_pf_wfq(struct ecore_hwfn *p_hwfn,
  * @return 0 on success, -1 on error.
  */
 int ecore_init_pf_rl(struct ecore_hwfn *p_hwfn,
-                    struct ecore_ptt *p_ptt, u8 pf_id, u32 pf_rl);
+                                        struct ecore_ptt *p_ptt,
+                                        u8 pf_id,
+                                        u32 pf_rl);
 /**
- * @brief ecore_init_vport_wfq Initializes the WFQ weight of the specified VPORT
+ * @brief ecore_init_vport_wfq  Initializes the WFQ weight of specified VPORT
  *
  * @param p_hwfn
  * @param p_ptt                        - ptt window used for writing the registers
@@ -109,8 +141,9 @@ int ecore_init_pf_rl(struct ecore_hwfn *p_hwfn,
  * @return 0 on success, -1 on error.
  */
 int ecore_init_vport_wfq(struct ecore_hwfn *p_hwfn,
-                        struct ecore_ptt *p_ptt,
-                        u16 first_tx_pq_id[NUM_OF_TCS], u16 vport_wfq);
+                                                struct ecore_ptt *p_ptt,
+                                                u16 first_tx_pq_id[NUM_OF_TCS],
+                                                u16 vport_wfq);
 /**
  * @brief ecore_init_vport_rl  Initializes the rate limit of the specified VPORT
  *
@@ -122,7 +155,9 @@ int ecore_init_vport_wfq(struct ecore_hwfn *p_hwfn,
  * @return 0 on success, -1 on error.
  */
 int ecore_init_vport_rl(struct ecore_hwfn *p_hwfn,
-                       struct ecore_ptt *p_ptt, u8 vport_id, u32 vport_rl);
+                                               struct ecore_ptt *p_ptt,
+                                               u8 vport_id,
+                                               u32 vport_rl);
 /**
  * @brief ecore_send_qm_stop_cmd  Sends a stop command to the QM
  *
@@ -133,13 +168,16 @@ int ecore_init_vport_rl(struct ecore_hwfn *p_hwfn,
  * @param start_pq       - first PQ ID to stop
  * @param num_pqs        - Number of PQs to stop, starting from start_pq.
  *
- * @return bool, true if successful, false if timeout occurred while
- * waiting for QM command done.
+ * @return bool, true if successful, false if timeout occurred while waiting
+ *  for QM command done.
  */
 bool ecore_send_qm_stop_cmd(struct ecore_hwfn *p_hwfn,
-                           struct ecore_ptt *p_ptt,
-                           bool is_release_cmd,
-                           bool is_tx_pq, u16 start_pq, u16 num_pqs);
+                                                       struct ecore_ptt *p_ptt,
+                                                       bool is_release_cmd,
+                                                       bool is_tx_pq,
+                                                       u16 start_pq,
+                                                       u16 num_pqs);
+#ifndef UNUSED_HSI_FUNC
 /**
  * @brief ecore_init_nig_ets - initializes the NIG ETS arbiter
  *
@@ -152,8 +190,9 @@ bool ecore_send_qm_stop_cmd(struct ecore_hwfn *p_hwfn,
  *               requirements are ignored when is_lb is cleared.
  */
 void ecore_init_nig_ets(struct ecore_hwfn *p_hwfn,
-                       struct ecore_ptt *p_ptt,
-                       struct init_ets_req *req, bool is_lb);
+                                               struct ecore_ptt *p_ptt,
+                                               struct init_ets_req *req,
+                                               bool is_lb);
 /**
  * @brief ecore_init_nig_lb_rl - initializes the NIG LB RLs
  *
@@ -163,8 +202,9 @@ void ecore_init_nig_ets(struct ecore_hwfn *p_hwfn,
  * @param req  - the NIG LB RLs initialization requirements.
  */
 void ecore_init_nig_lb_rl(struct ecore_hwfn *p_hwfn,
-                         struct ecore_ptt *p_ptt,
-                         struct init_nig_lb_rl_req *req);
+                                 struct ecore_ptt *p_ptt,
+                                 struct init_nig_lb_rl_req *req);
+#endif /* UNUSED_HSI_FUNC */
 /**
  * @brief ecore_init_nig_pri_tc_map - initializes the NIG priority to TC map.
  *
@@ -174,8 +214,9 @@ void ecore_init_nig_lb_rl(struct ecore_hwfn *p_hwfn,
  * @param req  - required mapping from prioirties to TCs.
  */
 void ecore_init_nig_pri_tc_map(struct ecore_hwfn *p_hwfn,
-                              struct ecore_ptt *p_ptt,
-                              struct init_nig_pri_tc_map_req *req);
+                                          struct ecore_ptt *p_ptt,
+                                          struct init_nig_pri_tc_map_req *req);
+#ifndef UNUSED_HSI_FUNC
 /**
  * @brief ecore_init_prs_ets - initializes the PRS Rx ETS arbiter
  *
@@ -185,7 +226,10 @@ void ecore_init_nig_pri_tc_map(struct ecore_hwfn *p_hwfn,
  * @param req  - the PRS ETS initialization requirements.
  */
 void ecore_init_prs_ets(struct ecore_hwfn *p_hwfn,
-                       struct ecore_ptt *p_ptt, struct init_ets_req *req);
+                                               struct ecore_ptt *p_ptt,
+                                               struct init_ets_req *req);
+#endif /* UNUSED_HSI_FUNC */
+#ifndef UNUSED_HSI_FUNC
 /**
  * @brief ecore_init_brb_ram - initializes BRB RAM sizes per TC
  *
@@ -195,43 +239,52 @@ void ecore_init_prs_ets(struct ecore_hwfn *p_hwfn,
  * @param req  - the BRB RAM initialization requirements.
  */
 void ecore_init_brb_ram(struct ecore_hwfn *p_hwfn,
-                       struct ecore_ptt *p_ptt, struct init_brb_ram_req *req);
+                                               struct ecore_ptt *p_ptt,
+                                               struct init_brb_ram_req *req);
+#endif /* UNUSED_HSI_FUNC */
+#ifndef UNUSED_HSI_FUNC
 /**
- * @brief ecore_set_engine_mf_ovlan_eth_type - initializes Nig,Prs,Pbf
- * and llh ethType Regs to  input ethType
- * should Be called once per engine if engine is in BD mode.
+ * @brief ecore_set_engine_mf_ovlan_eth_type - initializes Nig,Prs,Pbf and llh
+ *                                             ethType Regs to  input ethType
+ *                                             should Be called once per engine
+ *                                             if engine
+ *  is in BD mode.
  *
  * @param p_ptt    - ptt window used for writing the registers.
  * @param ethType - etherType to configure
  */
 void ecore_set_engine_mf_ovlan_eth_type(struct ecore_hwfn *p_hwfn,
-                                       struct ecore_ptt *p_ptt, u32 eth_type);
+                       struct ecore_ptt *p_ptt, u32 ethType);
 /**
- * @brief ecore_set_port_mf_ovlan_eth_type - initializes DORQ ethType Regs
- * to input ethType
- * should Be called once per port.
+ * @brief ecore_set_port_mf_ovlan_eth_type - initializes DORQ ethType Regs to
+ *                                           input ethType should Be called
+ *                                           once per port.
  *
  * @param p_ptt    - ptt window used for writing the registers.
  * @param ethType - etherType to configure
  */
 void ecore_set_port_mf_ovlan_eth_type(struct ecore_hwfn *p_hwfn,
-                                     struct ecore_ptt *p_ptt, u32 eth_type);
+                       struct ecore_ptt *p_ptt, u32 ethType);
+#endif /* UNUSED_HSI_FUNC */
 /**
- * @brief ecore_set_vxlan_dest_port - init vxlan tunnel destination udp port
+ * @brief ecore_set_vxlan_dest_port - initializes vxlan tunnel destination udp
+ *                                    port
  *
  * @param p_ptt     - ptt window used for writing the registers.
  * @param dest_port - vxlan destination udp port.
  */
 void ecore_set_vxlan_dest_port(struct ecore_hwfn *p_hwfn,
-                              struct ecore_ptt *p_ptt, u16 dest_port);
+                              struct ecore_ptt *p_ptt,
+                              u16 dest_port);
 /**
  * @brief ecore_set_vxlan_enable - enable or disable VXLAN tunnel in HW
  *
- * @param p_ptt        - ptt window used for writing the registers.
+ * @param p_ptt        - ptt window used for writing the registers.
  * @param vxlan_enable - vxlan enable flag.
  */
 void ecore_set_vxlan_enable(struct ecore_hwfn *p_hwfn,
-                           struct ecore_ptt *p_ptt, bool vxlan_enable);
+                           struct ecore_ptt *p_ptt,
+                           bool vxlan_enable);
 /**
  * @brief ecore_set_gre_enable - enable or disable GRE tunnel in HW
  *
@@ -241,15 +294,18 @@ void ecore_set_vxlan_enable(struct ecore_hwfn *p_hwfn,
  */
 void ecore_set_gre_enable(struct ecore_hwfn *p_hwfn,
                          struct ecore_ptt *p_ptt,
-                         bool eth_gre_enable, bool ip_gre_enable);
+                         bool eth_gre_enable,
+                         bool ip_gre_enable);
 /**
- * @brief ecore_set_geneve_dest_port - init geneve tunnel destination udp port
+ * @brief ecore_set_geneve_dest_port - initializes geneve tunnel destination
+ *                                     udp port
  *
  * @param p_ptt     - ptt window used for writing the registers.
  * @param dest_port - geneve destination udp port.
  */
 void ecore_set_geneve_dest_port(struct ecore_hwfn *p_hwfn,
-                               struct ecore_ptt *p_ptt, u16 dest_port);
+                               struct ecore_ptt *p_ptt,
+                               u16 dest_port);
 /**
  * @brief ecore_set_gre_enable - enable or disable GRE tunnel in HW
  *
@@ -259,5 +315,65 @@ void ecore_set_geneve_dest_port(struct ecore_hwfn *p_hwfn,
   */
 void ecore_set_geneve_enable(struct ecore_hwfn *p_hwfn,
                             struct ecore_ptt *p_ptt,
-                            bool eth_geneve_enable, bool ip_geneve_enable);
+                            bool eth_geneve_enable,
+                            bool ip_geneve_enable);
+#ifndef UNUSED_HSI_FUNC
+/**
+* @brief ecore_set_gft_event_id_cm_hdr - configure GFT event id and cm header
+*
+* @param p_ptt          - ptt window used for writing the registers.
+*/
+void ecore_set_gft_event_id_cm_hdr(struct ecore_hwfn *p_hwfn,
+                                  struct ecore_ptt *p_ptt);
+/**
+* @brief ecore_set_rfs_mode_enable - enable and configure HW for RFS
+*
+*
+* @param p_ptt             - ptt window used for writing the registers.
+* @param pf_id - pf on which to enable RFS.
+* @param tcp -  set profile tcp packets.
+* @param udp -  set profile udp  packet.
+* @param ipv4 - set profile ipv4 packet.
+* @param ipv6 - set profile ipv6 packet.
+*/
+void ecore_set_rfs_mode_enable(struct ecore_hwfn *p_hwfn,
+       struct ecore_ptt *p_ptt,
+       u16 pf_id,
+       bool tcp,
+       bool udp,
+       bool ipv4,
+       bool ipv6);
+#endif /* UNUSED_HSI_FUNC */
+/**
+* @brief ecore_config_vf_zone_size_mode - Configure VF zone size mode. Must be
+*                                         used before first ETH queue started.
+*
+*
+* @param p_ptt        -  ptt window used for writing the registers. Don't care
+*                        if runtime_init used
+* @param mode         -  VF zone size mode. Use enum vf_zone_size_mode.
+* @param runtime_init -  Set 1 to init runtime registers in engine phase. Set 0
+*                        if VF zone size mode configured after engine phase.
+*/
+void ecore_config_vf_zone_size_mode(struct ecore_hwfn *p_hwfn, struct ecore_ptt
+                                   *p_ptt, u16 mode, bool runtime_init);
+/**
+* @brief ecore_get_mstorm_queue_stat_offset - get mstorm statistics offset by VF
+*                                             zone size mode.
+*
+* @param stat_cnt_id         -  statistic counter id
+* @param vf_zone_size_mode   -  VF zone size mode. Use enum vf_zone_size_mode.
+*/
+u32 ecore_get_mstorm_queue_stat_offset(struct ecore_hwfn *p_hwfn,
+                                      u16 stat_cnt_id, u16 vf_zone_size_mode);
+/**
+* @brief ecore_get_mstorm_eth_vf_prods_offset - VF producer offset by VF zone
+*                                               size mode.
+*
+* @param vf_id               -  vf id.
+* @param vf_queue_id         -  per VF rx queue id.
+* @param vf_zone_size_mode   -  vf zone size mode. Use enum vf_zone_size_mode.
+*/
+u32 ecore_get_mstorm_eth_vf_prods_offset(struct ecore_hwfn *p_hwfn, u8 vf_id, u8
+                                        vf_queue_id, u16 vf_zone_size_mode);
 #endif