aboutsummaryrefslogtreecommitdiffstats
path: root/doc/guides/prog_guide/dev_kit_build_system.rst
blob: da83a31ee0e93b5ab3738bdc9a8a85df895a9154 (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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
..  SPDX-License-Identifier: BSD-3-Clause
    Copyright(c) 2010-2014 Intel Corporation.

.. _Development_Kit_Build_System:

Development Kit Build System
============================

The DPDK requires a build system for compilation activities and so on.
This section describes the constraints and the mechanisms used in the DPDK framework.

There are two use-cases for the framework:

*   Compilation of the DPDK libraries and sample applications;
    the framework generates specific binary libraries,
    include files and sample applications

*   Compilation of an external application or library, using an installed binary DPDK

Building the Development Kit Binary
-----------------------------------

The following provides details on how to build the DPDK binary.

Build Directory Concept
~~~~~~~~~~~~~~~~~~~~~~~

After installation, a build directory structure is created.
Each build directory contains include files, libraries, and applications.

A build directory is specific to a configuration that includes architecture + execution environment + toolchain.
It is possible to have several build directories sharing the same sources with different configurations.

For instance, to create a new build directory called my_sdk_build_dir using the default configuration template config/defconfig_x86_64-linuxapp,
we use:

.. code-block:: console

    cd ${RTE_SDK}
    make config T=x86_64-native-linuxapp-gcc O=my_sdk_build_dir

This creates a new my_sdk_build_dir directory. After that, we can compile by doing:

.. code-block:: console

    cd my_sdk_build_dir
    make

which is equivalent to:

.. code-block:: console

    make O=my_sdk_build_dir

The content of the my_sdk_build_dir is then:

::

    -- .config                         # used configuration

    -- Makefile                        # wrapper that calls head Makefile
                                       # with $PWD as build directory


        -- build                              #All temporary files used during build
        +--app                                # process, including . o, .d, and .cmd files.
            |  +-- test                       # For libraries, we have the .a file.
            |  +-- test.o                     # For applications, we have the elf file.
            |  `-- ...
            +-- lib
                +-- librte_eal
                |   `-- ...
                +-- librte_mempool
                |  +--  mempool-file1.o
                |  +--  .mempool-file1.o.cmd
                |  +--  .mempool-file1.o.d
                |  +--   mempool-file2.o
                |  +--  .mempool-file2.o.cmd
                |  +--  .mempool-file2.o.d
                |  `--  mempool.a
                `-- ...

    -- include                # All include files installed by libraries
        +-- librte_mempool.h  # and applications are located in this
        +-- rte_eal.h         # directory. The installed files can depend
        +-- rte_spinlock.h    # on configuration if needed (environment,
        +-- rte_atomic.h      # architecture, ..)
        `-- \*.h ...

    -- lib                    # all compiled libraries are copied in this
        +-- librte_eal.a      # directory
        +-- librte_mempool.a
        `-- \*.a ...

    -- app                    # All compiled applications are installed
    + --test                  # here. It includes the binary in elf format

Refer to
:ref:`Development Kit Root Makefile Help <Development_Kit_Root_Makefile_Help>`
for details about make commands that can be used from the root of DPDK.

Building External Applications
------------------------------

Since DPDK is in essence a development kit, the first objective of end users will be to create an application using this SDK.
To compile an application, the user must set the RTE_SDK and RTE_TARGET environment variables.

.. code-block:: console

    export RTE_SDK=/opt/DPDK
    export RTE_TARGET=x86_64-native-linuxapp-gcc
    cd /path/to/my_app

For a new application, the user must create their own Makefile that includes some .mk files, such as
${RTE_SDK}/mk/rte.vars.mk, and ${RTE_SDK}/mk/ rte.app.mk.
This is described in
:ref:`Building Your Own Application <Building_Your_Own_Application>`.

Depending on the chosen target (architecture, machine, executive environment, toolchain) defined in the Makefile or as an environment variable,
the applications and libraries will compile using the appropriate .h files and will link with the appropriate .a files.
These files are located in ${RTE_SDK}/arch-machine-execenv-toolchain, which is referenced internally by ${RTE_BIN_SDK}.

To compile their application, the user just has to call make.
The compilation result will be located in /path/to/my_app/build directory.

Sample applications are provided in the examples directory.

.. _Makefile_Description:

Makefile Description
--------------------

General Rules For DPDK Makefiles
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

In the DPDK, Makefiles always follow the same scheme:

#. Include $(RTE_SDK)/mk/rte.vars.mk at the beginning.

#. Define specific variables for RTE build system.

#. Include a specific $(RTE_SDK)/mk/rte.XYZ.mk, where XYZ can be app, lib, extapp, extlib, obj, gnuconfigure,
   and so on, depending on what kind of object you want to build.
   :ref:`See Makefile Types <Makefile_Types>` below.

#. Include user-defined rules and variables.

   The following is a very simple example of an external application Makefile:

   ..  code-block:: make

        include $(RTE_SDK)/mk/rte.vars.mk

        # binary name
        APP = helloworld

        # all source are stored in SRCS-y
        SRCS-y := main.c

        CFLAGS += -O3
        CFLAGS += $(WERROR_FLAGS)

        include $(RTE_SDK)/mk/rte.extapp.mk

.. _Makefile_Types:

Makefile Types
~~~~~~~~~~~~~~

Depending on the .mk file which is included at the end of the user Makefile, the Makefile will have a different role.
Note that it is not possible to build a library and an application in the same Makefile.
For that, the user must create two separate Makefiles, possibly in two different directories.

In any case, the rte.vars.mk file must be included in the user Makefile as soon as possible.

Application
^^^^^^^^^^^

These Makefiles generate a binary application.

*   rte.app.mk: Application in the development kit framework

*   rte.extapp.mk: External application

*   rte.hostapp.mk: prerequisite tool to build dpdk

Library
^^^^^^^

Generate a .a library.

*   rte.lib.mk: Library in the development kit framework

*   rte.extlib.mk: external library

*   rte.hostlib.mk: host library in the development kit framework

Install
^^^^^^^

*   rte.install.mk: Does not build anything, it is only used to create links or copy files to the installation directory.
    This is useful for including files in the development kit framework.

Kernel Module
^^^^^^^^^^^^^

*   rte.module.mk: Build a kernel module in the development kit framework.

Objects
^^^^^^^

*   rte.obj.mk: Object aggregation (merge several .o in one) in the development kit framework.

*   rte.extobj.mk: Object aggregation (merge several .o in one) outside the development kit framework.

Misc
^^^^

*   rte.doc.mk: Documentation in the development kit framework

*   rte.gnuconfigure.mk: Build an application that is configure-based.

*   rte.subdir.mk: Build several directories in the development kit framework.

.. _Internally_Generated_Build_Tools:

Internally Generated Build Tools
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

``app/dpdk-pmdinfogen``


``dpdk-pmdinfogen`` scans an object (.o) file for various well known symbol names.
These well known symbol names are defined by various macros and used to export
important information about hardware support and usage for pmd files.  For
instance the macro:

.. code-block:: c

   RTE_PMD_REGISTER_PCI(name, drv)

Creates the following symbol:

.. code-block:: c

   static char this_pmd_name0[] __attribute__((used)) = "<name>";


Which ``dpdk-pmdinfogen`` scans for.  Using this information other relevant
bits of data can be exported from the object file and used to produce a
hardware support description, that ``dpdk-pmdinfogen`` then encodes into a
json formatted string in the following format:

.. code-block:: c

   static char <name_pmd_string>="PMD_INFO_STRING=\"{'name' : '<name>', ...}\"";


These strings can then be searched for by external tools to determine the
hardware support of a given library or application.


.. _Useful_Variables_Provided_by_the_Build_System:

Useful Variables Provided by the Build System
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

*   RTE_SDK: The absolute path to the DPDK sources.
    When compiling the development kit, this variable is automatically set by the framework.
    It has to be defined by the user as an environment variable if compiling an external application.

*   RTE_SRCDIR: The path to the root of the sources. When compiling the development kit, RTE_SRCDIR = RTE_SDK.
    When compiling an external application, the variable points to the root of external application sources.

*   RTE_OUTPUT: The path to which output files are written.
    Typically, it is $(RTE_SRCDIR)/build, but it can be overridden by the O= option in the make command line.

*   RTE_TARGET: A string identifying the target for which we are building.
    The format is arch-machine-execenv-toolchain.
    When compiling the SDK, the target is deduced by the build system from the configuration (.config).
    When building an external application, it must be specified by the user in the Makefile or as an environment variable.

*   RTE_SDK_BIN: References $(RTE_SDK)/$(RTE_TARGET).

*   RTE_ARCH: Defines the architecture (i686, x86_64).
    It is the same value as CONFIG_RTE_ARCH  but without the double-quotes around the string.

*   RTE_MACHINE: Defines the machine.
    It is the same value as CONFIG_RTE_MACHINE but without the double-quotes around the string.

*   RTE_TOOLCHAIN: Defines the toolchain (gcc , icc).
    It is the same value as CONFIG_RTE_TOOLCHAIN but without the double-quotes around the string.

*   RTE_EXEC_ENV: Defines the executive environment (linuxapp).
    It is the same value as CONFIG_RTE_EXEC_ENV but without the double-quotes around the string.

*   RTE_KERNELDIR: This variable contains the absolute path to the kernel sources that will be used to compile the kernel modules.
    The kernel headers must be the same as the ones that will be used on the target machine (the machine that will run the application).
    By default, the variable is set to /lib/modules/$(shell uname -r)/build,
    which is correct when the target machine is also the build machine.

*   RTE_DEVEL_BUILD: Stricter options (stop on warning). It defaults to y in a git tree.

Variables that Can be Set/Overridden in a Makefile Only
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

*   VPATH: The path list that the build system will search for sources. By default, RTE_SRCDIR will be included in VPATH.

*   CFLAGS: Flags to use for C compilation. The user should use +=  to append data in this variable.

*   LDFLAGS: Flags to use for linking. The user should use +=  to append data in this variable.

*   ASFLAGS: Flags to use for assembly. The user should use +=  to append data in this variable.

*   CPPFLAGS: Flags to use to give flags to C preprocessor (only useful when assembling .S files).
    The user should use += to append data in this variable.

*   LDLIBS: In an application, the list of libraries to link with (for example, -L  /path/to/libfoo -lfoo ).
    The user should use  +=  to append data in this variable.

*   SRC-y: A list of source files (.c, .S, or .o  if the source is a binary) in case of application, library or object Makefiles.
    The sources must be available from VPATH.

*   INSTALL-y-$(INSTPATH): A list of files to be installed in  $(INSTPATH).
    The files must be available from VPATH and will be copied in $(RTE_OUTPUT)/$(INSTPATH). Can be used in almost any RTE Makefile.

*   SYMLINK-y-$(INSTPATH): A list of files to be installed in $(INSTPATH).
    The files must be available from VPATH and will be linked (symbolically) in  $(RTE_OUTPUT)/$(INSTPATH).
    This variable can be used in almost any DPDK Makefile.

*   PREBUILD: A list of prerequisite actions to be taken before building. The user should use +=  to append data in this variable.

*   POSTBUILD: A list of actions to be taken after the main build. The user should use += to append data in this variable.

*   PREINSTALL: A list of prerequisite actions to be taken before installing. The user should use += to append data in this variable.

*   POSTINSTALL: A list of actions to be taken after installing. The user should use += to append data in this variable.

*   PRECLEAN: A list of prerequisite actions to be taken before cleaning. The user should use += to append data in this variable.

*   POSTCLEAN: A list of actions to be taken after cleaning. The user should use += to append data in this variable.

*   DEPDIRS-$(DIR): Only used in the development kit framework to specify if the build of the current directory depends on build of another one.
    This is needed to support parallel builds correctly.

Variables that can be Set/Overridden by the User on the Command Line Only
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Some variables can be used to configure the build system behavior. They are documented in
:ref:`Development Kit Root Makefile Help <Development_Kit_Root_Makefile_Help>` and
:ref:`External Application/Library Makefile Help <External_Application/Library_Makefile_Help>`

    *   WERROR_CFLAGS: By default, this is set to a specific value that depends on the compiler.
        Users are encouraged to use this variable as follows:

            CFLAGS += $(WERROR_CFLAGS)

This avoids the use of different cases depending on the compiler (icc or gcc).
Also, this variable can be overridden from the command line, which allows bypassing of the flags for testing purposes.

Variables that Can be Set/Overridden by the User in a Makefile or Command Line
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

*   CFLAGS_my_file.o: Specific flags to add for C compilation of my_file.c.

*   LDFLAGS_my_app: Specific flags to add when linking my_app.

*   EXTRA_CFLAGS: The content of this variable is appended after CFLAGS when compiling.

*   EXTRA_LDFLAGS: The content of this variable is appended after LDFLAGS when linking.

*   EXTRA_LDLIBS: The content of this variable is appended after LDLIBS when linking.

*   EXTRA_ASFLAGS: The content of this variable is appended after ASFLAGS when assembling.

*   EXTRA_CPPFLAGS: The content of this variable is appended after CPPFLAGS when using a C preprocessor on assembly files.