Imported Upstream version 16.11
[deb_dpdk.git] / drivers / net / thunderx / base / nicvf_mbox.h
index 7c0c6a9..084f3a7 100644 (file)
@@ -36,6 +36,7 @@
 #include <stdint.h>
 
 #include "nicvf_plat.h"
+#include "../nicvf_struct.h"
 
 /* PF <--> VF Mailbox communication
  * Two 64bit registers are shared between PF and VF for each VF
 #define        NIC_MBOX_MSG_ALLOC_SQS          0x12    /* Allocate secondary Qset */
 #define        NIC_MBOX_MSG_LOOPBACK           0x16    /* Set interface in loopback */
 #define        NIC_MBOX_MSG_RESET_STAT_COUNTER 0x17    /* Reset statistics counters */
-#define        NIC_MBOX_MSG_CFG_DONE           0xF0    /* VF configuration done */
-#define        NIC_MBOX_MSG_SHUTDOWN           0xF1    /* VF is being shutdown */
+#define        NIC_MBOX_MSG_CFG_DONE           0x7E    /* VF configuration done */
+#define        NIC_MBOX_MSG_SHUTDOWN           0x7F    /* VF is being shutdown */
+#define        NIC_MBOX_MSG_RES_BIT            0x80    /* Reset bit from PF */
 #define        NIC_MBOX_MSG_MAX                0x100   /* Maximum number of messages */
 
+#define NIC_MBOX_MSG_RSS_SIZE_RES_BIT \
+       (NIC_MBOX_MSG_RSS_SIZE | NIC_MBOX_MSG_RES_BIT)
+#define NIC_MBOX_MSG_ALLOC_SQS_RES_BIT \
+       (NIC_MBOX_MSG_ALLOC_SQS | NIC_MBOX_MSG_RES_BIT)
+
 /* Get vNIC VF configuration */
 struct nic_cfg_msg {
        uint8_t    msg;
@@ -155,6 +162,14 @@ struct bgx_link_status {
        uint32_t   speed;
 };
 
+/* Allocate additional SQS to VF */
+struct sqs_alloc {
+       uint8_t    msg;
+       uint8_t    spec;
+       uint8_t    qs_count;
+       uint8_t    svf[MAX_SQS_PER_VF];
+};
+
 /* Set interface in loopback mode */
 struct set_loopback {
        uint8_t    msg;
@@ -201,6 +216,7 @@ union {
        struct rss_sz_msg       rss_size;
        struct rss_cfg_msg      rss_cfg;
        struct bgx_link_status  link_status;
+       struct sqs_alloc        sqs_alloc;
        struct set_loopback     lbk;
        struct reset_stat_cfg   reset_stat;
 };
@@ -211,6 +227,7 @@ NICVF_STATIC_ASSERT(sizeof(struct nic_mbx) <= 16);
 int nicvf_handle_mbx_intr(struct nicvf *nic);
 int nicvf_mbox_check_pf_ready(struct nicvf *nic);
 int nicvf_mbox_qset_config(struct nicvf *nic, struct pf_qs_cfg *qs_cfg);
+int nicvf_mbox_request_sqs(struct nicvf *nic);
 int nicvf_mbox_rq_config(struct nicvf *nic, uint16_t qidx,
                         struct pf_rq_cfg *pf_rq_cfg);
 int nicvf_mbox_sq_config(struct nicvf *nic, uint16_t qidx);