On 9/25/2023 12:33 PM, Ferruh Yigit wrote:
> On 9/20/2023 4:48 PM, David Young wrote:
>> ---
>>  .../appendix/cross_compile_dpdk.rst           |  37 +++
>>  .../appendix/dpdk_meson_build_options.rst     |  57 ++++
>>  .../getting_started_guide/appendix/index.rst  |  17 +
>>  .../running_dpdk_apps_without_root.rst        |  36 +++
>>  .../appendix/vfio_advanced.rst                | 295 ++++++++++++++++++
>>  5 files changed, 442 insertions(+)
>>  create mode 100644 
>> doc/guides/getting_started_guide/appendix/cross_compile_dpdk.rst
>>  create mode 100644 
>> doc/guides/getting_started_guide/appendix/dpdk_meson_build_options.rst
>>  create mode 100644 doc/guides/getting_started_guide/appendix/index.rst
>>  create mode 100644 
>> doc/guides/getting_started_guide/appendix/running_dpdk_apps_without_root.rst
>>  create mode 100644 
>> doc/guides/getting_started_guide/appendix/vfio_advanced.rst
>>
> 
> These files are put under 'appendix' folder,
> and I can see these documents are linked from other 'getting started
> guide' documentations, which I assume the reason to put these under
> 'appendix' folder.
> But these are not limited to getting started, perhaps we can do a better
> organization of them out of getting started appendix.
> 
> 
> 
>> diff --git 
>> a/doc/guides/getting_started_guide/appendix/cross_compile_dpdk.rst 
>> b/doc/guides/getting_started_guide/appendix/cross_compile_dpdk.rst
>> new file mode 100644
>> index 0000000000..3e4efe23a4
>> --- /dev/null
>> +++ b/doc/guides/getting_started_guide/appendix/cross_compile_dpdk.rst
>> @@ -0,0 +1,37 @@
>> +..  SPDX-License-Identifier: BSD-3-Clause
>> +    Copyright(c) 2010-2025 Intel Corporation.
>> +
>> +.. _cross_compile_dpdk:
>> +
>> +Cross-compiling DPDK for Different Architectures on Linux
>> +=========================================================
>> +
>> +Cross-compiling DPDK for different architectures follows a similar process. 
>> Here are the general steps:
>> +
>> +1. **Get Compiler and Libraries**: Obtain the cross-compiler toolchain and 
>> any required libraries specific to the target architecture.
>> +
>> +2. **Build Using Cross-File**: Use Meson to set up the build with a 
>> cross-file specific to the target architecture, and then build with Ninja.
>> +
>> +Prerequisites
>> +-------------
>> +
>> +- NUMA Library (if required)
>> +- Meson and Ninja
>> +- pkg-config for the target architecture
>> +- Specific GNU or LLVM/Clang toolchain for the target architecture
>> +
>> +Cross-Compiling DPDK
>> +--------------------
>> +
>> +1. **Set Up the Cross Toolchain**: Download and extract the toolchain for 
>> the target architecture. Add it to the PATH.
>> +
>> +2. **Compile Any Required Libraries**: Compile libraries like NUMA if 
>> required.
>> +
>> +3. **Cross-Compile DPDK with Meson**:
>> +
>> +   .. code-block:: bash
>> +
>> +      meson setup cross-build --cross-file <target_machine_configuration>
>> +      ninja -C cross-build
>> +
>> +Refer to the specific sections for ARM64, LoongArch, and RISC-V for 
>> detailed instructions and architecture-specific considerations.

Mentioned sections are not in this document, so can be good to provide
link for them.



>> \ No newline at end of file
>> diff --git 
>> a/doc/guides/getting_started_guide/appendix/dpdk_meson_build_options.rst 
>> b/doc/guides/getting_started_guide/appendix/dpdk_meson_build_options.rst
>> new file mode 100644
>> index 0000000000..6669f98371
>> --- /dev/null
>> +++ b/doc/guides/getting_started_guide/appendix/dpdk_meson_build_options.rst
>> @@ -0,0 +1,57 @@
>> +..  SPDX-License-Identifier: BSD-3-Clause
>> +    Copyright(c) 2010-2025 Intel Corporation.
>> +
>> +.. _dpdk_meson_build_options:
>> +
>> +DPDK Meson Build Configuration Options
>> +======================================
>> +
>> +DPDK provides a number of build configuration options that can be adjusted 
>> using the Meson build system. These options can be listed by running ``meson 
>> configure`` inside a configured build
>> +folder.
>> +
>> +Changing the Build Type
>> +-----------------------
>> +
>> +To change the build type from the default "release" to a regular "debug" 
>> build,
>> +you can either:
>> +
>> +- Pass ``-Dbuildtype=debug`` or ``--buildtype=debug`` to meson when 
>> configuring the build folder initially.
>> +- Run ``meson configure -Dbuildtype=debug`` inside the build folder after 
>> the initial meson run.
>> +
>> +Platform Options
>> +----------------
>> +
>> +The "platform" option specifies a set of configuration parameters that will 
>> be used. 
>> +The valid values are:
>> +
>> +- ``-Dplatform=native`` will tailor the configuration to the build machine.
>> +- ``-Dplatform=generic`` will use configuration that works on all machines 
>> of the same architecture as the build machine.
>> +- ``-Dplatform=<SoC>`` will use configuration optimized for a particular 
>> SoC.
>> +
>> +Consult the "socs" dictionary in ``config/arm/meson.build`` to see which 
>> SoCs are supported.
>> +
>> +Overriding Platform Parameters
>> +------------------------------
>> +
>> +The values determined by the platform parameter may be overwritten. For 
>> example,
>> +to set the ``max_lcores`` value to 256, you can either:
>> +
>> +- Pass ``-Dmax_lcores=256`` to meson when configuring the build folder 
>> initially.
>> +- Run ``meson configure -Dmax_lcores=256`` inside the build folder after 
>> the initial meson run.
>> +
>> +Building Sample Applications
>> +----------------------------
>> +
>> +Some of the DPDK sample applications in the examples directory can be 
>> automatically built as
>> +part of a meson build. To do so, pass a comma-separated list of the 
>> examples to build to the
>> +``-Dexamples`` meson option as below::
>> +
>> +    meson setup -Dexamples=l2fwd,l3fwd build
>> +
>> +There is also a special value "all" to request that all example 
>> applications whose dependencies
>> +are met on the current system are built. When ``-Dexamples=all`` is set as 
>> a meson option,
>> +meson will check each example application to see if it can be built, and 
>> add all which can be
>> +built to the list of tasks in the ninja build configuration file.
>> +
>> +For a complete list of options, run ``meson configure`` inside your 
>> configured build
>> +folder.
>> \ No newline at end of file
>> diff --git a/doc/guides/getting_started_guide/appendix/index.rst 
>> b/doc/guides/getting_started_guide/appendix/index.rst
>> new file mode 100644
>> index 0000000000..23bb1fcf78
>> --- /dev/null
>> +++ b/doc/guides/getting_started_guide/appendix/index.rst
>> @@ -0,0 +1,17 @@
>> +..  SPDX-License-Identifier: BSD-3-Clause
>> +    Copyright(c) 2010-2025 Intel Corporation.
>> +
>> +.. _appendix:
>> +
>> +Appendix
>> +========
>> +
>> +This section covers specific guides related to DPDK.
>> +
>> +.. toctree::
>> +    :maxdepth: 2
>> +
>> +    dpdk_meson_build_options
>> +    running_dpdk_apps_without_root
>> +    vfio_advanced
>> +    cross_compile_dpdk
>> \ No newline at end of file
>> diff --git 
>> a/doc/guides/getting_started_guide/appendix/running_dpdk_apps_without_root.rst
>>  
>> b/doc/guides/getting_started_guide/appendix/running_dpdk_apps_without_root.rst
>> new file mode 100644
>> index 0000000000..9f214bbdc8
>> --- /dev/null
>> +++ 
>> b/doc/guides/getting_started_guide/appendix/running_dpdk_apps_without_root.rst
>> @@ -0,0 +1,36 @@
>> +..  SPDX-License-Identifier: BSD-3-Clause
>> +    Copyright(c) 2010-2025 Intel Corporation.
>> +
>> +.. _running_dpdk_apps_without_root:
>> +
>> +Running DPDK Applications Without Root Privileges
>> +=================================================
>> +
>> +Although applications using the DPDK use network ports and other hardware 
>> resources
>> +directly, with a number of small permission adjustments, 
>> +it is possible to run these applications as a user other than “root”. 
>> +To do so, the ownership, or permissions, on the following file system 
>> objects should be
>> +adjusted so the user account being used to run the DPDK application has
>> +access to them:
>> +
>> +Linux
>> +-----
>> +
>> +1. **Create a DPDK User Group**: Create a new user group for DPDK and add 
>> the desired user to this group.
>> +
>> +2. **Set Up Hugepages**: Configure hugepages for the user.
>> +
>> +3. **Bind the NIC to a User-Space Driver**: Use the DPDK tool 
>> ``dpdk-devbind.py`` to bind the NIC to a user-space driver like ``vfio-pci`` 
>> or ``igb_uio``.
>> +
>> +4. **Set Permissions for UIO/VFIO Devices**: Change the ownership and 
>> permissions of the UIO or VFIO devices to allow access by the DPDK user 
>> group.
>> +
>> +5. **Run the DPDK Application**: Run the desired DPDK application as the 
>> user who has been added to the DPDK group.
>> +
>>
> 
> I think we need a sample commands, additional to description, on how to
> run an application as a non-priviledged user.
> 
> 
>> +FreeBSD
>> +-------
>> +
>> +- The userspace-io device files in ``/dev``, for example, ``/dev/uio0``, 
>> ``/dev/uio1``, and so on
>> +- The userspace contiguous memory device: ``/dev/contigmem``
>> +
>> +
>> +Refer to the `DPDK Release Notes 
>> <https://doc.dpdk.org/guides/rel_notes/index.html>`_ for supported 
>> applications.
>>
> 
> Applications that run without root privileges? Do we have that kind of
> list in release notes?
> 
> 
> 
>> \ No newline at end of file
>> diff --git a/doc/guides/getting_started_guide/appendix/vfio_advanced.rst 
>> b/doc/guides/getting_started_guide/appendix/vfio_advanced.rst
>> new file mode 100644
>> index 0000000000..1cdb138eb7
>> --- /dev/null
>> +++ b/doc/guides/getting_started_guide/appendix/vfio_advanced.rst
>> @@ -0,0 +1,295 @@
>> +..  SPDX-License-Identifier: BSD-3-Clause
>> +    Copyright(c) 2010-2025 Intel Corporation.
>> +
>> +.. _vfio_advanced:
>> +
>> +.. |reg| unicode:: U+000AE
>> +
>> +VFIO Advanced
>> +=============
>> +
>> +
>> +.. contents:: Table of Contents
>> +   :local:
>> +
>> +.. _vfio_no_iommu_mode:
>> +
>> +VFIO no-IOMMU mode
>> +------------------
>> +
> 
> I guess this is the only documentation specific to "VFIO", (and title is
> VFIO advanced), I think it can be better to start with describing VFIO,
> instead of starting with no-iommu mode.
> 
> 

Reply via email to