summaryrefslogtreecommitdiffstats
path: root/src/spdk/dpdk/doc/guides/rawdevs/octeontx2_dma.rst
blob: 1e1dfbe931aadf28f11846217bfcd7f11f6982fb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
..  SPDX-License-Identifier: BSD-3-Clause
    Copyright(c) 2019 Marvell International Ltd.

OCTEON TX2 DMA Driver
=====================

OCTEON TX2 has an internal DMA unit which can be used by applications to initiate
DMA transaction internally, from/to host when OCTEON TX2 operates in PCIe End
Point mode. The DMA PF function supports 8 VFs corresponding to 8 DMA queues.
Each DMA queue was exposed as a VF function when SRIOV enabled.

Features
--------

This DMA PMD supports below 3 modes of memory transfers

#. Internal - OCTEON TX2 DRAM to DRAM without core intervention

#. Inbound  - Host DRAM to OCTEON TX2 DRAM without host/OCTEON TX2 cores involvement

#. Outbound - OCTEON TX2 DRAM to Host DRAM without host/OCTEON TX2 cores involvement

Prerequisites and Compilation procedure
---------------------------------------

   See :doc:`../platform/octeontx2` for setup information.


Pre-Installation Configuration
------------------------------

Config File Options
~~~~~~~~~~~~~~~~~~~

The following options can be modified in the ``config`` file.

- ``CONFIG_RTE_LIBRTE_PMD_OCTEONTX2_DMA_RAWDEV`` (default ``y``)

  Toggle compilation of the ``lrte_pmd_octeontx2_dma`` driver.

Enabling logs
-------------

For enabling logs, use the following EAL parameter:

.. code-block:: console

   ./your_dma_application <EAL args> --log-level=pmd.raw.octeontx2.dpi,<level>

Using ``pmd.raw.octeontx2.dpi`` as log matching criteria, all Event PMD logs
can be enabled which are lower than logging ``level``.

Initialization
--------------

The number of DMA VFs (queues) enabled can be controlled by setting sysfs
entry, `sriov_numvfs` for the corresponding PF driver.

.. code-block:: console

 echo <num_vfs> > /sys/bus/pci/drivers/octeontx2-dpi/0000\:05\:00.0/sriov_numvfs

Once the required VFs are enabled, to be accessible from DPDK, VFs need to be
bound to vfio-pci driver.

Device Setup
-------------

The OCTEON TX2 DPI DMA HW devices will need to be bound to a
user-space IO driver for use. The script ``dpdk-devbind.py`` script
included with DPDK can be used to view the state of the devices and to bind
them to a suitable DPDK-supported kernel driver. When querying the status
of the devices, they will appear under the category of "Misc (rawdev)
devices", i.e. the command ``dpdk-devbind.py --status-dev misc`` can be
used to see the state of those devices alone.

Device Configuration
--------------------

Configuring DMA rawdev device is done using the ``rte_rawdev_configure()``
API, which takes the mempool as parameter. PMD uses this pool to submit DMA
commands to HW.

The following code shows how the device is configured

.. code-block:: c

   struct dpi_rawdev_conf_s conf = {0};
   struct rte_rawdev_info rdev_info = {.dev_private = &conf};

   conf.chunk_pool = (void *)rte_mempool_create_empty(...);
   rte_mempool_set_ops_byname(conf.chunk_pool, rte_mbuf_platform_mempool_ops(), NULL);
   rte_mempool_populate_default(conf.chunk_pool);

   rte_rawdev_configure(dev_id, (rte_rawdev_obj_t)&rdev_info);

Performing Data Transfer
------------------------

To perform data transfer using OCTEON TX2 DMA rawdev devices use standard
``rte_rawdev_enqueue_buffers()`` and ``rte_rawdev_dequeue_buffers()`` APIs.

Self test
---------

On EAL initialization, dma devices will be probed and populated into the
raw devices. The rawdev ID of the device can be obtained using

* Invoke ``rte_rawdev_get_dev_id("DPI:x")`` from the application
  where x is the VF device's bus id specified in "bus:device.func" format. Use this
  index for further rawdev function calls.

* This PMD supports driver self test, to test DMA internal mode from test
  application one can directly calls
  ``rte_rawdev_selftest(rte_rawdev_get_dev_id("DPI:x"))``