On Tue, Apr 09, 2019 at 11:34:24AM +0100, Luca Boccassi wrote:
> On Tue, 2019-04-09 at 10:29 +0100, Bruce Richardson wrote:
> > Within EAL we had a series of if statements for selecting the EAL
> > directory to use. Now that the directory names match those of the OS's
> > they are for we can instead just use a generated subdirectory name,
> > shortening the code.  To avoid strange errors, we still need to check
> > for unsupported OS's, but do this check up-front in the config
> > meson.build file.
> > 
> > Signed-off-by: Bruce Richardson < bruce.richard...@intel.com
> > >
> > --- config/meson.build         |  7 +++++++ lib/librte_eal/meson.build
> > | 17 ++--------------- 2 files changed, 9 insertions(+), 15
> > deletions(-)
> > 
> > diff --git a/config/meson.build b/config/meson.build index
> > 483139b10..ce6af2595 100644 --- a/config/meson.build +++
> > b/config/meson.build @@ -1,6 +1,13 @@ # SPDX-License-Identifier:
> > BSD-3-Clause # Copyright(c) 2017-2019 Intel Corporation
> >  
> > +# check the OS is supported, rather than going any further
> > +supported_exec_envs = ['freebsd', 'linux', 'windows'] +exec_env =
> > host_machine.system() +if not supported_exec_envs.contains(exec_env) +
> > error('unsupported system type "@0@"'.format(exec_env)) +endif + # set
> > the major version, which might be used by drivers and libraries #
> > depending on the configuration options pver =
> > meson.project_version().split('.') diff --git
> > a/lib/librte_eal/meson.build b/lib/librte_eal/meson.build index
> > 1863622c0..fa36b20e0 100644 --- a/lib/librte_eal/meson.build +++
> > b/lib/librte_eal/meson.build @@ -9,21 +9,8 @@ subdir('common') #
> > defines common_sources, common_objs, etc.
> >  
> >  # Now do OS/exec-env specific settings, including building kernel
> >  modules # The <exec-env>/eal/meson.build file should define
> >  env_sources, etc.  -if host_machine.system() == 'linux' -
> >  dpdk_conf.set('RTE_EXEC_ENV_LINUX', 1) -   subdir('linux/eal') - -elif
> >  host_machine.system() == 'freebsd' -
> >  dpdk_conf.set('RTE_EXEC_ENV_FREEBSD', 1) - subdir('freebsd/eal') -
> >  -elif host_machine.system() == 'windows' -
> >  dpdk_conf.set('RTE_EXEC_ENV_WINDOWS', 1) - subdir('windows/eal') -
> >  -else -    error('unsupported system type
> >  "@0@"'.format(host_machine.system())) -endif
> >  +dpdk_conf.set('RTE_EXEC_ENV_' + exec_env.to_upper(), 1)
> >  +subdir(exec_env + '/eal')
> 
> Shouldn't this use join_paths() for cross-platform compat? Or does
> foo/bar work fine these days in Windows?
> 
It should work fine on Windows. We have plenty of other places where we use
"/" for separation, e.g. the subdir() function in EAL

/Bruce

Reply via email to