build: disable experimental API check internally
[dpdk.git] / drivers / meson.build
index 72eec46..4d8f842 100644 (file)
@@ -9,16 +9,18 @@ endif
 dpdk_driver_classes = ['common',
               'bus',
               'mempool', # depends on common and bus.
-              'raw',     # depends on common and bus.
-              'net',     # depends on common, bus, mempool and raw.
+              'net',     # depends on common, bus, mempool
+              'raw',     # depends on common, bus and net.
               'crypto',  # depends on common, bus and mempool (net in future).
               'compress', # depends on common, bus, mempool.
+              'vdpa',    # depends on common, bus and mempool.
               'event',   # depends on common, bus, mempool and net.
               'baseband'] # depends on common and bus.
 
-disabled_drivers = get_option('disable_drivers').split(',')
+disabled_drivers = run_command(list_dir_globs, get_option('disable_drivers'),
+               ).stdout().split()
 
-default_cflags = machine_args
+default_cflags = machine_args + ['-DALLOW_EXPERIMENTAL_API']
 if cc.has_argument('-Wno-format-truncation')
        default_cflags += '-Wno-format-truncation'
 endif
@@ -41,7 +43,7 @@ foreach class:dpdk_driver_classes
                build = true # set to false to disable, e.g. missing deps
                reason = '<unknown reason>' # set if build == false to explain
                name = drv
-               allow_experimental_apis = false
+               fmt_name = ''
                sources = []
                objs = []
                cflags = default_cflags
@@ -97,12 +99,11 @@ foreach class:dpdk_driver_classes
                else
                        class_drivers += name
 
-                       dpdk_conf.set(config_flag_fmt.format(name.to_upper()),1)
-                       lib_name = driver_name_fmt.format(name)
-
-                       if allow_experimental_apis
-                               cflags += '-DALLOW_EXPERIMENTAL_API'
+                       if fmt_name == ''
+                               fmt_name = name
                        endif
+                       dpdk_conf.set(config_flag_fmt.format(fmt_name.to_upper()),1)
+                       lib_name = driver_name_fmt.format(fmt_name)
 
                        dpdk_extra_ldflags += pkgconfig_extra_libs
 
@@ -132,10 +133,10 @@ foreach class:dpdk_driver_classes
 
                        if is_experimental != 0
                                lib_version = experimental_abi_version
-                               so_version = experimental_abi_version
+                               so_version = experimental_so_version
                        else
                                lib_version = abi_version
-                               so_version = abi_version
+                               so_version = stable_so_version
                        endif
 
                        # now build the static driver