From: Anoob Joseph <anoobj@marvell.com>
To: Chengwen Feng <fengchengwen@huawei.com>,
Kevin Laatz <kevin.laatz@intel.com>,
Bruce Richardson <bruce.richardson@intel.com>,
"Jerin Jacob" <jerinj@marvell.com>,
Thomas Monjalon <thomas@monjalon.net>
Cc: Gowrishankar Muthukrishnan <gmuthukrishn@marvell.com>,
"Vidya Sagar Velumuri" <vvelumuri@marvell.com>, <dev@dpdk.org>
Subject: [PATCH v2 2/7] dma/odm: add hardware defines
Date: Wed, 17 Apr 2024 12:57:03 +0530 [thread overview]
Message-ID: <20240417072708.322-3-anoobj@marvell.com> (raw)
In-Reply-To: <20240417072708.322-1-anoobj@marvell.com>
Add ODM registers and structures. Add mailbox structs as well.
Signed-off-by: Anoob Joseph <anoobj@marvell.com>
Signed-off-by: Gowrishankar Muthukrishnan <gmuthukrishn@marvell.com>
Signed-off-by: Vidya Sagar Velumuri <vvelumuri@marvell.com>
---
drivers/dma/odm/odm.h | 116 +++++++++++++++++++++++++++++++++++++
drivers/dma/odm/odm_priv.h | 49 ++++++++++++++++
2 files changed, 165 insertions(+)
create mode 100644 drivers/dma/odm/odm_priv.h
diff --git a/drivers/dma/odm/odm.h b/drivers/dma/odm/odm.h
index aeeb6f9e9a..7564ffbed4 100644
--- a/drivers/dma/odm/odm.h
+++ b/drivers/dma/odm/odm.h
@@ -9,6 +9,47 @@
extern int odm_logtype;
+/* ODM VF register offsets from VF_BAR0 */
+#define ODM_VDMA_EN(x) (0x00 | (x << 3))
+#define ODM_VDMA_REQQ_CTL(x) (0x80 | (x << 3))
+#define ODM_VDMA_DBELL(x) (0x100 | (x << 3))
+#define ODM_VDMA_RING_CFG(x) (0x180 | (x << 3))
+#define ODM_VDMA_IRING_BADDR(x) (0x200 | (x << 3))
+#define ODM_VDMA_CRING_BADDR(x) (0x280 | (x << 3))
+#define ODM_VDMA_COUNTS(x) (0x300 | (x << 3))
+#define ODM_VDMA_IRING_NADDR(x) (0x380 | (x << 3))
+#define ODM_VDMA_CRING_NADDR(x) (0x400 | (x << 3))
+#define ODM_VDMA_IRING_DBG(x) (0x480 | (x << 3))
+#define ODM_VDMA_CNT(x) (0x580 | (x << 3))
+#define ODM_VF_INT (0x1000)
+#define ODM_VF_INT_W1S (0x1008)
+#define ODM_VF_INT_ENA_W1C (0x1010)
+#define ODM_VF_INT_ENA_W1S (0x1018)
+#define ODM_MBOX_VF_PF_DATA(i) (0x2000 | (i << 3))
+
+#define ODM_MBOX_RETRY_CNT (0xfffffff)
+#define ODM_MBOX_ERR_CODE_MAX (0xf)
+#define ODM_IRING_IDLE_WAIT_CNT (0xfffffff)
+
+/**
+ * Enumeration odm_hdr_xtype_e
+ *
+ * ODM Transfer Type Enumeration
+ * Enumerates the pointer type in ODM_DMA_INSTR_HDR_S[XTYPE]
+ */
+#define ODM_XTYPE_INTERNAL 2
+#define ODM_XTYPE_FILL0 4
+#define ODM_XTYPE_FILL1 5
+
+/**
+ * ODM Header completion type enumeration
+ * Enumerates the completion type in ODM_DMA_INSTR_HDR_S[CT]
+ */
+#define ODM_HDR_CT_CW_CA 0x0
+#define ODM_HDR_CT_CW_NC 0x1
+
+#define ODM_MAX_QUEUES_PER_DEV 16
+
#define odm_err(...) \
rte_log(RTE_LOG_ERR, odm_logtype, \
RTE_FMT("%s(): %u" RTE_FMT_HEAD(__VA_ARGS__, ), __func__, __LINE__, \
@@ -18,6 +59,81 @@ extern int odm_logtype;
RTE_FMT("%s(): %u" RTE_FMT_HEAD(__VA_ARGS__, ), __func__, __LINE__, \
RTE_FMT_TAIL(__VA_ARGS__, )))
+/**
+ * Structure odm_instr_hdr_s for ODM
+ *
+ * ODM DMA Instruction Header Format
+ */
+union odm_instr_hdr_s {
+ uint64_t u;
+ struct odm_instr_hdr {
+ uint64_t nfst : 3;
+ uint64_t reserved_3 : 1;
+ uint64_t nlst : 3;
+ uint64_t reserved_7_9 : 3;
+ uint64_t ct : 2;
+ uint64_t stse : 1;
+ uint64_t reserved_13_28 : 16;
+ uint64_t sts : 1;
+ uint64_t reserved_30_49 : 20;
+ uint64_t xtype : 3;
+ uint64_t reserved_53_63 : 11;
+ } s;
+};
+
+/**
+ * ODM Completion Entry Structure
+ *
+ */
+union odm_cmpl_ent_s {
+ uint32_t u;
+ struct odm_cmpl_ent {
+ uint32_t cmp_code : 8;
+ uint32_t rsvd : 23;
+ uint32_t valid : 1;
+ } s;
+};
+
+/**
+ * ODM DMA Ring Configuration Register
+ */
+union odm_vdma_ring_cfg_s {
+ uint64_t u;
+ struct {
+ uint64_t isize : 8;
+ uint64_t rsvd_8_15 : 8;
+ uint64_t csize : 8;
+ uint64_t rsvd_24_63 : 40;
+ } s;
+};
+
+/**
+ * ODM DMA Instruction Ring DBG
+ */
+union odm_vdma_iring_dbg_s {
+ uint64_t u;
+ struct {
+ uint64_t dbell_cnt : 32;
+ uint64_t offset : 16;
+ uint64_t rsvd_48_62 : 15;
+ uint64_t iwbusy : 1;
+ } s;
+};
+
+/**
+ * ODM DMA Counts
+ */
+union odm_vdma_counts_s {
+ uint64_t u;
+ struct {
+ uint64_t dbell : 32;
+ uint64_t buf_used_cnt : 9;
+ uint64_t rsvd_41_43 : 3;
+ uint64_t rsvd_buf_used_cnt : 3;
+ uint64_t rsvd_47_63 : 17;
+ } s;
+};
+
struct __rte_cache_aligned odm_dev {
struct rte_pci_device *pci_dev;
uint8_t *rbase;
diff --git a/drivers/dma/odm/odm_priv.h b/drivers/dma/odm/odm_priv.h
new file mode 100644
index 0000000000..1878f4d9a6
--- /dev/null
+++ b/drivers/dma/odm/odm_priv.h
@@ -0,0 +1,49 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright(C) 2024 Marvell.
+ */
+
+#ifndef _ODM_PRIV_H_
+#define _ODM_PRIV_H_
+
+#define ODM_MAX_VFS 16
+#define ODM_MAX_QUEUES 32
+
+#define ODM_CMD_QUEUE_SIZE 4096
+
+#define ODM_DEV_INIT 0x1
+#define ODM_DEV_CLOSE 0x2
+#define ODM_QUEUE_OPEN 0x3
+#define ODM_QUEUE_CLOSE 0x4
+#define ODM_REG_DUMP 0x5
+
+struct odm_mbox_dev_msg {
+ /* Response code */
+ uint64_t rsp : 8;
+ /* Number of VFs */
+ uint64_t nvfs : 2;
+ /* Error code */
+ uint64_t err : 6;
+ /* Reserved */
+ uint64_t rsvd_16_63 : 48;
+};
+
+struct odm_mbox_queue_msg {
+ /* Command code */
+ uint64_t cmd : 8;
+ /* VF ID to configure */
+ uint64_t vfid : 8;
+ /* Queue index in the VF */
+ uint64_t qidx : 8;
+ /* Reserved */
+ uint64_t rsvd_24_63 : 40;
+};
+
+union odm_mbox_msg {
+ uint64_t u[2];
+ struct {
+ struct odm_mbox_dev_msg d;
+ struct odm_mbox_queue_msg q;
+ };
+};
+
+#endif /* _ODM_PRIV_H_ */
--
2.25.1
next prev parent reply other threads:[~2024-04-17 7:27 UTC|newest]
Thread overview: 37+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-04-15 15:31 [PATCH 0/8] Add ODM DMA device Anoob Joseph
2024-04-15 15:31 ` [PATCH 1/8] usertools/devbind: add " Anoob Joseph
2024-04-15 15:31 ` [PATCH 2/8] dma/odm: add framework for " Anoob Joseph
2024-04-15 15:31 ` [PATCH 3/8] dma/odm: add hardware defines Anoob Joseph
2024-04-15 15:31 ` [PATCH 4/8] dma/odm: add dev init and fini Anoob Joseph
2024-04-15 15:31 ` [PATCH 5/8] dma/odm: add device ops Anoob Joseph
2024-04-15 15:31 ` [PATCH 6/8] dma/odm: add stats Anoob Joseph
2024-04-15 15:31 ` [PATCH 7/8] dma/odm: add copy and copy sg ops Anoob Joseph
2024-04-15 15:31 ` [PATCH 8/8] dma/odm: add remaining ops Anoob Joseph
2024-04-17 7:27 ` [PATCH v2 0/7] Add ODM DMA device Anoob Joseph
2024-04-17 7:27 ` [PATCH v2 1/7] dma/odm: add framework for " Anoob Joseph
2024-04-17 7:27 ` Anoob Joseph [this message]
2024-04-17 7:27 ` [PATCH v2 3/7] dma/odm: add dev init and fini Anoob Joseph
2024-04-17 7:27 ` [PATCH v2 4/7] dma/odm: add device ops Anoob Joseph
2024-04-17 7:27 ` [PATCH v2 5/7] dma/odm: add stats Anoob Joseph
2024-04-17 7:27 ` [PATCH v2 6/7] dma/odm: add copy and copy sg ops Anoob Joseph
2024-04-17 7:27 ` [PATCH v2 7/7] dma/odm: add remaining ops Anoob Joseph
2024-04-19 6:43 ` [PATCH v3 0/7] Add ODM DMA device Anoob Joseph
2024-04-19 6:43 ` [PATCH v3 1/7] dma/odm: add framework for " Anoob Joseph
2024-05-24 13:26 ` Jerin Jacob
2024-04-19 6:43 ` [PATCH v3 2/7] dma/odm: add hardware defines Anoob Joseph
2024-05-24 13:29 ` Jerin Jacob
2024-04-19 6:43 ` [PATCH v3 3/7] dma/odm: add dev init and fini Anoob Joseph
2024-04-19 6:43 ` [PATCH v3 4/7] dma/odm: add device ops Anoob Joseph
2024-05-24 13:37 ` Jerin Jacob
2024-04-19 6:43 ` [PATCH v3 5/7] dma/odm: add stats Anoob Joseph
2024-04-19 6:43 ` [PATCH v3 6/7] dma/odm: add copy and copy sg ops Anoob Joseph
2024-04-19 6:43 ` [PATCH v3 7/7] dma/odm: add remaining ops Anoob Joseph
2024-05-27 15:16 ` [PATCH v4 0/7] Add ODM DMA device Anoob Joseph
2024-05-27 15:16 ` [PATCH v4 1/7] dma/odm: add framework for " Anoob Joseph
2024-05-27 15:16 ` [PATCH v4 2/7] dma/odm: add hardware defines Anoob Joseph
2024-05-27 15:16 ` [PATCH v4 3/7] dma/odm: add dev init and fini Anoob Joseph
2024-05-27 15:16 ` [PATCH v4 4/7] dma/odm: add device ops Anoob Joseph
2024-05-27 15:16 ` [PATCH v4 5/7] dma/odm: add stats Anoob Joseph
2024-05-27 15:16 ` [PATCH v4 6/7] dma/odm: add copy and copy sg ops Anoob Joseph
2024-05-27 15:16 ` [PATCH v4 7/7] dma/odm: add remaining ops Anoob Joseph
2024-05-28 8:12 ` [PATCH v4 0/7] Add ODM DMA device Jerin Jacob
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20240417072708.322-3-anoobj@marvell.com \
--to=anoobj@marvell.com \
--cc=bruce.richardson@intel.com \
--cc=dev@dpdk.org \
--cc=fengchengwen@huawei.com \
--cc=gmuthukrishn@marvell.com \
--cc=jerinj@marvell.com \
--cc=kevin.laatz@intel.com \
--cc=thomas@monjalon.net \
--cc=vvelumuri@marvell.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).