net/liquidio: add APIs to enable and disable multicast
[dpdk.git] / drivers / net / liquidio / base / lio_hw_defs.h
index 9282068..781e929 100644 (file)
@@ -76,11 +76,100 @@ enum lio_card_type {
 
 #define LIO_23XX_NAME "23xx"
 
+#define LIO_DEV_RUNNING                0xc
+
+#define LIO_OQ_REFILL_THRESHOLD_CFG(cfg)                               \
+               ((cfg)->default_config->oq.refill_threshold)
+#define LIO_NUM_DEF_TX_DESCS_CFG(cfg)                                  \
+               ((cfg)->default_config->num_def_tx_descs)
+
+#define LIO_IQ_INSTR_TYPE(cfg)         ((cfg)->default_config->iq.instr_type)
+
+/* The following config values are fixed and should not be modified. */
+
+/* Maximum number of Instruction queues */
+#define LIO_MAX_INSTR_QUEUES(lio_dev)          CN23XX_MAX_RINGS_PER_VF
+
+#define LIO_MAX_POSSIBLE_INSTR_QUEUES          CN23XX_MAX_INPUT_QUEUES
+#define LIO_MAX_POSSIBLE_OUTPUT_QUEUES         CN23XX_MAX_OUTPUT_QUEUES
+
 #define LIO_DEVICE_NAME_LEN            32
 #define LIO_BASE_MAJOR_VERSION         1
 #define LIO_BASE_MINOR_VERSION         5
 #define LIO_BASE_MICRO_VERSION         1
 
+#define LIO_FW_VERSION_LENGTH          32
+
+/** Tag types used by Octeon cores in its work. */
+enum octeon_tag_type {
+       OCTEON_ORDERED_TAG      = 0,
+       OCTEON_ATOMIC_TAG       = 1,
+};
+
+/* pre-defined host->NIC tag values */
+#define LIO_CONTROL    (0x11111110)
+#define LIO_DATA(i)    (0x11111111 + (i))
+
+/* used for NIC operations */
+#define LIO_OPCODE     1
+
+/* Subcodes are used by host driver/apps to identify the sub-operation
+ * for the core. They only need to by unique for a given subsystem.
+ */
+#define LIO_OPCODE_SUBCODE(op, sub)            \
+               ((((op) & 0x0f) << 8) | ((sub) & 0x7f))
+
+/** LIO_OPCODE subcodes */
+/* This subcode is sent by core PCI driver to indicate cores are ready. */
+#define LIO_OPCODE_NW_DATA             0x02 /* network packet data */
+#define LIO_OPCODE_CMD                 0x03
+#define LIO_OPCODE_INFO                        0x04
+#define LIO_OPCODE_IF_CFG              0x09
+
+#define LIO_MIN_RX_BUF_SIZE            64
+#define LIO_MAX_RX_PKTLEN              (64 * 1024)
+
+/* NIC Command types */
+#define LIO_CMD_CHANGE_DEVFLAGS                0x3
+#define LIO_CMD_RX_CTL                 0x4
+#define LIO_CMD_SET_RSS                        0xD
+
+/* RX(packets coming from wire) Checksum verification flags */
+/* TCP/UDP csum */
+#define LIO_L4_CSUM_VERIFIED           0x1
+#define LIO_IP_CSUM_VERIFIED           0x2
+
+/* RSS */
+#define LIO_RSS_PARAM_DISABLE_RSS              0x10
+#define LIO_RSS_PARAM_HASH_KEY_UNCHANGED       0x08
+#define LIO_RSS_PARAM_ITABLE_UNCHANGED         0x04
+#define LIO_RSS_PARAM_HASH_INFO_UNCHANGED      0x02
+
+#define LIO_RSS_HASH_IPV4                      0x100
+#define LIO_RSS_HASH_TCP_IPV4                  0x200
+#define LIO_RSS_HASH_IPV6                      0x400
+#define LIO_RSS_HASH_TCP_IPV6                  0x1000
+#define LIO_RSS_HASH_IPV6_EX                   0x800
+#define LIO_RSS_HASH_TCP_IPV6_EX               0x2000
+
+#define LIO_RSS_OFFLOAD_ALL (          \
+               LIO_RSS_HASH_IPV4 |     \
+               LIO_RSS_HASH_TCP_IPV4 | \
+               LIO_RSS_HASH_IPV6 |     \
+               LIO_RSS_HASH_TCP_IPV6 | \
+               LIO_RSS_HASH_IPV6_EX |  \
+               LIO_RSS_HASH_TCP_IPV6_EX)
+
+#define LIO_RSS_MAX_TABLE_SZ           128
+#define LIO_RSS_MAX_KEY_SZ             40
+#define LIO_RSS_PARAM_SIZE             16
+
+/* Interface flags communicated between host driver and core app. */
+enum lio_ifflags {
+       LIO_IFFLAG_ALLMULTI     = 0x02,
+       LIO_IFFLAG_UNICAST      = 0x10
+};
+
 /* Routines for reading and writing CSRs */
 #ifdef RTE_LIBRTE_LIO_DEBUG_REGS
 #define lio_write_csr(lio_dev, reg_off, value)                         \