Message ID | 20200916162621.100141-3-pbonzini@redhat.com |
---|---|
State | New |
Headers | show |
Series | meson: move libmpathpersist test | expand |
On 16/09/2020 18.26, Paolo Bonzini wrote: > This is the first compiler/linker test that has been moved to Meson. > Add more section headings to keep things clearer. > > Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> > --- > configure | 77 +++------------------------------------------ > meson.build | 80 ++++++++++++++++++++++++++++++++++++++++++----- > meson_options.txt | 2 ++ > 3 files changed, 78 insertions(+), 81 deletions(-) [...] > diff --git a/meson.build b/meson.build > index 5092aec439..60ef988d9d 100644 > --- a/meson.build > +++ b/meson.build > @@ -86,6 +86,14 @@ if 'SPARSE_CFLAGS' in config_host > 'compile_commands.json']) > endif > > +########################################### > +# Target-specific checks and dependencies # > +########################################### > + > +if targetos != 'linux' and get_option('mpath').enabled() > + error('Multipath is supported only on Linux') > +endif > + > m = cc.find_library('m', required: false) > util = cc.find_library('util', required: false) > winmm = [] > @@ -117,6 +125,11 @@ elif targetos == 'haiku' > cc.find_library('network'), > cc.find_library('bsd')] > endif > + > +################ > +# Dependencies # > +################ > + > # The path to glib.h is added to all compilation commands. This was > # grandfathered in from the QEMU Makefiles. > add_project_arguments(config_host['GLIB_CFLAGS'].split(), > @@ -223,10 +236,6 @@ if 'CONFIG_SPICE' in config_host > link_args: config_host['SPICE_LIBS'].split()) > endif > rt = cc.find_library('rt', required: false) > -libmpathpersist = not_found > -if config_host.has_key('CONFIG_MPATH') > - libmpathpersist = cc.find_library('mpathpersist') > -endif > libdl = not_found > if 'CONFIG_PLUGIN' in config_host > libdl = cc.find_library('dl', required: true) > @@ -257,9 +266,62 @@ if 'CONFIG_CURL' in config_host > link_args: config_host['CURL_LIBS'].split()) > endif > libudev = not_found > -if target_os == 'linux' > - libudev = dependency('libudev', static: enable_static) > +if targetos == 'linux' > + libudev = dependency('libudev', > + required: get_option('mpath'), > + static: enable_static) > +endif > + > +mpathpersist = not_found > +if targetos == 'linux' and not get_option('mpath').disabled() > + libmultipath = cc.find_library('multipath', > + required: get_option('mpath'), > + static: enable_static) > + libmpathpersist = cc.find_library('mpathpersist', > + required: get_option('mpath'), > + static: enable_static) > + if libmultipath.found() and libmpathpersist.found() and libudev.found() > + if cc.links(''' > + #include <libudev.h> > + #include <mpath_persist.h> > + unsigned mpath_mx_alloc_len = 1024; > + int logsink; > + static struct config *multipath_conf; > + extern struct udev *udev; > + extern struct config *get_multipath_config(void); > + extern void put_multipath_config(struct config *conf); > + struct udev *udev; > + struct config *get_multipath_config(void) { return multipath_conf; } > + void put_multipath_config(struct config *conf) { } > + int main(void) { > + udev = udev_new(); > + multipath_conf = mpath_lib_init(); > + return 0; > + }''', dependencies: [libmultipath, libmpathpersist, libudev]) > + mpathpersist = declare_dependency(dependencies: [libmultipath, libmpathpersist, libudev]) > + mpathpersist_new_api = true > + elif cc.links(''' > + #include <libudev.h> > + #include <mpath_persist.h> > + unsigned mpath_mx_alloc_len = 1024; > + int logsink; > + int main(void) { > + struct udev *udev = udev_new(); > + mpath_lib_init(udev); > + return 0; > + }''', dependencies: [libmultipath, libmpathpersist, libudev]) > + mpathpersist = declare_dependency(dependencies: [libmultipath, libmpathpersist, libudev]) > + mpathpersist_new_api = false > + else > + if get_option('mpath').enabled() > + error('Cannot detect libmpathpersist API') > + else > + warning('Cannot detect libmpathpersist API, disabling') > + endif > + endif > + endif > endif > + I just gave this a try on my laptop, but I'm seeing: ../../devel/qemu/meson.build:508:17: ERROR: Unknown variable "mpathpersist_new_api". ... I guess it should only be printed if mpathpersist.found() ? Thomas
Yes, or easier the "false" assignment can be moved out of the "if". Paolo Il mer 16 set 2020, 19:09 Thomas Huth <thuth@redhat.com> ha scritto: > On 16/09/2020 18.26, Paolo Bonzini wrote: > > This is the first compiler/linker test that has been moved to Meson. > > Add more section headings to keep things clearer. > > > > Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> > > --- > > configure | 77 +++------------------------------------------ > > meson.build | 80 ++++++++++++++++++++++++++++++++++++++++++----- > > meson_options.txt | 2 ++ > > 3 files changed, 78 insertions(+), 81 deletions(-) > [...] > > diff --git a/meson.build b/meson.build > > index 5092aec439..60ef988d9d 100644 > > --- a/meson.build > > +++ b/meson.build > > @@ -86,6 +86,14 @@ if 'SPARSE_CFLAGS' in config_host > > 'compile_commands.json']) > > endif > > > > +########################################### > > +# Target-specific checks and dependencies # > > +########################################### > > + > > +if targetos != 'linux' and get_option('mpath').enabled() > > + error('Multipath is supported only on Linux') > > +endif > > + > > m = cc.find_library('m', required: false) > > util = cc.find_library('util', required: false) > > winmm = [] > > @@ -117,6 +125,11 @@ elif targetos == 'haiku' > > cc.find_library('network'), > > cc.find_library('bsd')] > > endif > > + > > +################ > > +# Dependencies # > > +################ > > + > > # The path to glib.h is added to all compilation commands. This was > > # grandfathered in from the QEMU Makefiles. > > add_project_arguments(config_host['GLIB_CFLAGS'].split(), > > @@ -223,10 +236,6 @@ if 'CONFIG_SPICE' in config_host > > link_args: > config_host['SPICE_LIBS'].split()) > > endif > > rt = cc.find_library('rt', required: false) > > -libmpathpersist = not_found > > -if config_host.has_key('CONFIG_MPATH') > > - libmpathpersist = cc.find_library('mpathpersist') > > -endif > > libdl = not_found > > if 'CONFIG_PLUGIN' in config_host > > libdl = cc.find_library('dl', required: true) > > @@ -257,9 +266,62 @@ if 'CONFIG_CURL' in config_host > > link_args: config_host['CURL_LIBS'].split()) > > endif > > libudev = not_found > > -if target_os == 'linux' > > - libudev = dependency('libudev', static: enable_static) > > +if targetos == 'linux' > > + libudev = dependency('libudev', > > + required: get_option('mpath'), > > + static: enable_static) > > +endif > > + > > +mpathpersist = not_found > > +if targetos == 'linux' and not get_option('mpath').disabled() > > + libmultipath = cc.find_library('multipath', > > + required: get_option('mpath'), > > + static: enable_static) > > + libmpathpersist = cc.find_library('mpathpersist', > > + required: get_option('mpath'), > > + static: enable_static) > > + if libmultipath.found() and libmpathpersist.found() and > libudev.found() > > + if cc.links(''' > > + #include <libudev.h> > > + #include <mpath_persist.h> > > + unsigned mpath_mx_alloc_len = 1024; > > + int logsink; > > + static struct config *multipath_conf; > > + extern struct udev *udev; > > + extern struct config *get_multipath_config(void); > > + extern void put_multipath_config(struct config *conf); > > + struct udev *udev; > > + struct config *get_multipath_config(void) { return > multipath_conf; } > > + void put_multipath_config(struct config *conf) { } > > + int main(void) { > > + udev = udev_new(); > > + multipath_conf = mpath_lib_init(); > > + return 0; > > + }''', dependencies: [libmultipath, libmpathpersist, libudev]) > > + mpathpersist = declare_dependency(dependencies: [libmultipath, > libmpathpersist, libudev]) > > + mpathpersist_new_api = true > > + elif cc.links(''' > > + #include <libudev.h> > > + #include <mpath_persist.h> > > + unsigned mpath_mx_alloc_len = 1024; > > + int logsink; > > + int main(void) { > > + struct udev *udev = udev_new(); > > + mpath_lib_init(udev); > > + return 0; > > + }''', dependencies: [libmultipath, libmpathpersist, libudev]) > > + mpathpersist = declare_dependency(dependencies: [libmultipath, > libmpathpersist, libudev]) > > + mpathpersist_new_api = false > > + else > > + if get_option('mpath').enabled() > > + error('Cannot detect libmpathpersist API') > > + else > > + warning('Cannot detect libmpathpersist API, disabling') > > + endif > > + endif > > + endif > > endif > > + > > I just gave this a try on my laptop, but I'm seeing: > > ../../devel/qemu/meson.build:508:17: ERROR: Unknown variable > "mpathpersist_new_api". > > ... I guess it should only be printed if mpathpersist.found() ? > > Thomas > > <div dir="auto">Yes, or easier the "false" assignment can be moved out of the "if".<div dir="auto"><br></div><div dir="auto">Paolo</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">Il mer 16 set 2020, 19:09 Thomas Huth <<a href="mailto:thuth@redhat.com">thuth@redhat.com</a>> ha scritto:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">On 16/09/2020 18.26, Paolo Bonzini wrote:<br> > This is the first compiler/linker test that has been moved to Meson.<br> > Add more section headings to keep things clearer.<br> > <br> > Signed-off-by: Paolo Bonzini <<a href="mailto:pbonzini@redhat.com" target="_blank" rel="noreferrer">pbonzini@redhat.com</a>><br> > ---<br> > configure | 77 +++------------------------------------------<br> > meson.build | 80 ++++++++++++++++++++++++++++++++++++++++++-----<br> > meson_options.txt | 2 ++<br> > 3 files changed, 78 insertions(+), 81 deletions(-)<br> [...]<br> > diff --git a/meson.build b/meson.build<br> > index 5092aec439..60ef988d9d 100644<br> > --- a/meson.build<br> > +++ b/meson.build<br> > @@ -86,6 +86,14 @@ if 'SPARSE_CFLAGS' in config_host<br> > 'compile_commands.json'])<br> > endif<br> > <br> > +###########################################<br> > +# Target-specific checks and dependencies #<br> > +###########################################<br> > +<br> > +if targetos != 'linux' and get_option('mpath').enabled()<br> > + error('Multipath is supported only on Linux')<br> > +endif<br> > +<br> > m = cc.find_library('m', required: false)<br> > util = cc.find_library('util', required: false)<br> > winmm = []<br> > @@ -117,6 +125,11 @@ elif targetos == 'haiku'<br> > cc.find_library('network'),<br> > cc.find_library('bsd')]<br> > endif<br> > +<br> > +################<br> > +# Dependencies #<br> > +################<br> > +<br> > # The path to glib.h is added to all compilation commands. This was<br> > # grandfathered in from the QEMU Makefiles.<br> > add_project_arguments(config_host['GLIB_CFLAGS'].split(),<br> > @@ -223,10 +236,6 @@ if 'CONFIG_SPICE' in config_host<br> > link_args: config_host['SPICE_LIBS'].split())<br> > endif<br> > rt = cc.find_library('rt', required: false)<br> > -libmpathpersist = not_found<br> > -if config_host.has_key('CONFIG_MPATH')<br> > - libmpathpersist = cc.find_library('mpathpersist')<br> > -endif<br> > libdl = not_found<br> > if 'CONFIG_PLUGIN' in config_host<br> > libdl = cc.find_library('dl', required: true)<br> > @@ -257,9 +266,62 @@ if 'CONFIG_CURL' in config_host<br> > link_args: config_host['CURL_LIBS'].split())<br> > endif<br> > libudev = not_found<br> > -if target_os == 'linux'<br> > - libudev = dependency('libudev', static: enable_static)<br> > +if targetos == 'linux'<br> > + libudev = dependency('libudev',<br> > + required: get_option('mpath'),<br> > + static: enable_static)<br> > +endif<br> > +<br> > +mpathpersist = not_found<br> > +if targetos == 'linux' and not get_option('mpath').disabled()<br> > + libmultipath = cc.find_library('multipath',<br> > + required: get_option('mpath'),<br> > + static: enable_static)<br> > + libmpathpersist = cc.find_library('mpathpersist',<br> > + required: get_option('mpath'),<br> > + static: enable_static)<br> > + if libmultipath.found() and libmpathpersist.found() and libudev.found()<br> > + if cc.links('''<br> > + #include <libudev.h><br> > + #include <mpath_persist.h><br> > + unsigned mpath_mx_alloc_len = 1024;<br> > + int logsink;<br> > + static struct config *multipath_conf;<br> > + extern struct udev *udev;<br> > + extern struct config *get_multipath_config(void);<br> > + extern void put_multipath_config(struct config *conf);<br> > + struct udev *udev;<br> > + struct config *get_multipath_config(void) { return multipath_conf; }<br> > + void put_multipath_config(struct config *conf) { }<br> > + int main(void) {<br> > + udev = udev_new();<br> > + multipath_conf = mpath_lib_init();<br> > + return 0;<br> > + }''', dependencies: [libmultipath, libmpathpersist, libudev])<br> > + mpathpersist = declare_dependency(dependencies: [libmultipath, libmpathpersist, libudev])<br> > + mpathpersist_new_api = true<br> > + elif cc.links('''<br> > + #include <libudev.h><br> > + #include <mpath_persist.h><br> > + unsigned mpath_mx_alloc_len = 1024;<br> > + int logsink;<br> > + int main(void) {<br> > + struct udev *udev = udev_new();<br> > + mpath_lib_init(udev);<br> > + return 0;<br> > + }''', dependencies: [libmultipath, libmpathpersist, libudev])<br> > + mpathpersist = declare_dependency(dependencies: [libmultipath, libmpathpersist, libudev])<br> > + mpathpersist_new_api = false<br> > + else<br> > + if get_option('mpath').enabled()<br> > + error('Cannot detect libmpathpersist API')<br> > + else<br> > + warning('Cannot detect libmpathpersist API, disabling')<br> > + endif<br> > + endif<br> > + endif<br> > endif<br> > +<br> <br> I just gave this a try on my laptop, but I'm seeing:<br> <br> ../../devel/qemu/meson.build:508:17: ERROR: Unknown variable<br> "mpathpersist_new_api".<br> <br> ... I guess it should only be printed if mpathpersist.found() ?<br> <br> Thomas<br> <br> </blockquote></div>
diff --git a/configure b/configure index 83ccbc6d70..cc38516e06 100755 --- a/configure +++ b/configure @@ -371,7 +371,7 @@ netmap="no" sdl="auto" sdl_image="auto" virtfs="" -mpath="" +mpath="auto" vnc="enabled" sparse="no" vde="" @@ -1084,9 +1084,9 @@ for opt do ;; --enable-virtfs) virtfs="yes" ;; - --disable-mpath) mpath="no" + --disable-mpath) mpath="disabled" ;; - --enable-mpath) mpath="yes" + --enable-mpath) mpath="enabled" ;; --disable-vnc) vnc="disabled" ;; @@ -3823,57 +3823,6 @@ if test "$modules" = yes; then fi fi -########################################## -# libmpathpersist probe - -if test "$mpath" != "no" ; then - # probe for the new API - cat > $TMPC <<EOF -#include <libudev.h> -#include <mpath_persist.h> -unsigned mpath_mx_alloc_len = 1024; -int logsink; -static struct config *multipath_conf; -extern struct udev *udev; -extern struct config *get_multipath_config(void); -extern void put_multipath_config(struct config *conf); -struct udev *udev; -struct config *get_multipath_config(void) { return multipath_conf; } -void put_multipath_config(struct config *conf) { } - -int main(void) { - udev = udev_new(); - multipath_conf = mpath_lib_init(); - return 0; -} -EOF - if compile_prog "" "-ludev -lmultipath -lmpathpersist" ; then - mpathpersist=yes - mpathpersist_new_api=yes - else - # probe for the old API - cat > $TMPC <<EOF -#include <libudev.h> -#include <mpath_persist.h> -unsigned mpath_mx_alloc_len = 1024; -int logsink; -int main(void) { - struct udev *udev = udev_new(); - mpath_lib_init(udev); - return 0; -} -EOF - if compile_prog "" "-ludev -lmultipath -lmpathpersist" ; then - mpathpersist=yes - mpathpersist_new_api=no - else - mpathpersist=no - fi - fi -else - mpathpersist=no -fi - ########################################## # pthread probe PTHREADLIBS_LIST="-pthread -lpthread -lpthreadGC2" @@ -6315,23 +6264,11 @@ if test "$softmmu" = yes ; then fi virtfs=no fi - if test "$mpath" != no && test "$mpathpersist" = yes ; then - mpath=yes - else - if test "$mpath" = yes; then - error_exit "Multipath requires libmpathpersist devel" - fi - mpath=no - fi else if test "$virtfs" = yes; then error_exit "VirtFS is supported only on Linux" fi virtfs=no - if test "$mpath" = yes; then - error_exit "Multipath is supported only on Linux" - fi - mpath=no fi fi @@ -6872,12 +6809,6 @@ fi if test "$virtfs" = "yes" ; then echo "CONFIG_VIRTFS=y" >> $config_host_mak fi -if test "$mpath" = "yes" ; then - echo "CONFIG_MPATH=y" >> $config_host_mak - if test "$mpathpersist_new_api" = "yes"; then - echo "CONFIG_MPATH_NEW_API=y" >> $config_host_mak - fi -fi if test "$vhost_scsi" = "yes" ; then echo "CONFIG_VHOST_SCSI=y" >> $config_host_mak fi @@ -7965,7 +7896,7 @@ NINJA=${ninja:-$PWD/ninjatool} $meson setup \ -Dstrip=$(if test "$strip_opt" = yes; then echo true; else echo false; fi) \ -Db_pie=$(if test "$pie" = yes; then echo true; else echo false; fi) \ -Db_coverage=$(if test "$gcov" = yes; then echo true; else echo false; fi) \ - -Dsdl=$sdl -Dsdl_image=$sdl_image \ + -Dmpath=$mpath -Dsdl=$sdl -Dsdl_image=$sdl_image \ -Dvnc=$vnc -Dvnc_sasl=$vnc_sasl -Dvnc_jpeg=$vnc_jpeg -Dvnc_png=$vnc_png \ -Dgettext=$gettext -Dxkbcommon=$xkbcommon -Du2f=$u2f\ $cross_arg \ diff --git a/meson.build b/meson.build index 5092aec439..60ef988d9d 100644 --- a/meson.build +++ b/meson.build @@ -86,6 +86,14 @@ if 'SPARSE_CFLAGS' in config_host 'compile_commands.json']) endif +########################################### +# Target-specific checks and dependencies # +########################################### + +if targetos != 'linux' and get_option('mpath').enabled() + error('Multipath is supported only on Linux') +endif + m = cc.find_library('m', required: false) util = cc.find_library('util', required: false) winmm = [] @@ -117,6 +125,11 @@ elif targetos == 'haiku' cc.find_library('network'), cc.find_library('bsd')] endif + +################ +# Dependencies # +################ + # The path to glib.h is added to all compilation commands. This was # grandfathered in from the QEMU Makefiles. add_project_arguments(config_host['GLIB_CFLAGS'].split(), @@ -223,10 +236,6 @@ if 'CONFIG_SPICE' in config_host link_args: config_host['SPICE_LIBS'].split()) endif rt = cc.find_library('rt', required: false) -libmpathpersist = not_found -if config_host.has_key('CONFIG_MPATH') - libmpathpersist = cc.find_library('mpathpersist') -endif libdl = not_found if 'CONFIG_PLUGIN' in config_host libdl = cc.find_library('dl', required: true) @@ -257,9 +266,62 @@ if 'CONFIG_CURL' in config_host link_args: config_host['CURL_LIBS'].split()) endif libudev = not_found -if target_os == 'linux' - libudev = dependency('libudev', static: enable_static) +if targetos == 'linux' + libudev = dependency('libudev', + required: get_option('mpath'), + static: enable_static) +endif + +mpathpersist = not_found +if targetos == 'linux' and not get_option('mpath').disabled() + libmultipath = cc.find_library('multipath', + required: get_option('mpath'), + static: enable_static) + libmpathpersist = cc.find_library('mpathpersist', + required: get_option('mpath'), + static: enable_static) + if libmultipath.found() and libmpathpersist.found() and libudev.found() + if cc.links(''' + #include <libudev.h> + #include <mpath_persist.h> + unsigned mpath_mx_alloc_len = 1024; + int logsink; + static struct config *multipath_conf; + extern struct udev *udev; + extern struct config *get_multipath_config(void); + extern void put_multipath_config(struct config *conf); + struct udev *udev; + struct config *get_multipath_config(void) { return multipath_conf; } + void put_multipath_config(struct config *conf) { } + int main(void) { + udev = udev_new(); + multipath_conf = mpath_lib_init(); + return 0; + }''', dependencies: [libmultipath, libmpathpersist, libudev]) + mpathpersist = declare_dependency(dependencies: [libmultipath, libmpathpersist, libudev]) + mpathpersist_new_api = true + elif cc.links(''' + #include <libudev.h> + #include <mpath_persist.h> + unsigned mpath_mx_alloc_len = 1024; + int logsink; + int main(void) { + struct udev *udev = udev_new(); + mpath_lib_init(udev); + return 0; + }''', dependencies: [libmultipath, libmpathpersist, libudev]) + mpathpersist = declare_dependency(dependencies: [libmultipath, libmpathpersist, libudev]) + mpathpersist_new_api = false + else + if get_option('mpath').enabled() + error('Cannot detect libmpathpersist API') + else + warning('Cannot detect libmpathpersist API, disabling') + endif + endif + endif endif + brlapi = not_found if 'CONFIG_BRLAPI' in config_host brlapi = declare_dependency(link_args: config_host['BRLAPI_LIBS'].split()) @@ -447,6 +509,8 @@ has_gettid = cc.has_function('gettid') # Create config-host.h config_host_data.set('CONFIG_LIBUDEV', libudev.found()) +config_host_data.set('CONFIG_MPATH', mpathpersist.found()) +config_host_data.set('CONFIG_MPATH_NEW_API', mpathpersist_new_api) config_host_data.set('CONFIG_SDL', sdl.found()) config_host_data.set('CONFIG_SDL_IMAGE', sdl_image.found()) config_host_data.set('CONFIG_VNC', vnc.found()) @@ -1197,7 +1261,7 @@ if have_tools executable('qemu-pr-helper', files('scsi/qemu-pr-helper.c', 'scsi/utils.c'), dependencies: [authz, crypto, io, qom, qemuutil, - libcap_ng, libudev, libmpathpersist], + libcap_ng, mpathpersist], install: true) endif @@ -1419,7 +1483,7 @@ summary_info += {'Audio drivers': config_host['CONFIG_AUDIO_DRIVERS']} summary_info += {'Block whitelist (rw)': config_host['CONFIG_BDRV_RW_WHITELIST']} summary_info += {'Block whitelist (ro)': config_host['CONFIG_BDRV_RO_WHITELIST']} summary_info += {'VirtFS support': config_host.has_key('CONFIG_VIRTFS')} -summary_info += {'Multipath support': config_host.has_key('CONFIG_MPATH')} +summary_info += {'Multipath support': mpathpersist.found()} summary_info += {'VNC support': vnc.found()} if vnc.found() summary_info += {'VNC SASL support': sasl.found()} diff --git a/meson_options.txt b/meson_options.txt index 543cf70043..b38a6ae92a 100644 --- a/meson_options.txt +++ b/meson_options.txt @@ -6,6 +6,8 @@ option('docdir', type : 'string', value : 'doc', option('gettext', type : 'boolean', value : true, description: 'Localization of the GTK+ user interface') +option('mpath', type : 'feature', value : 'auto', + description: 'Multipath persistent reservation passthrough') option('sdl', type : 'feature', value : 'auto', description: 'SDL user interface') option('sdl_image', type : 'feature', value : 'auto',
This is the first compiler/linker test that has been moved to Meson. Add more section headings to keep things clearer. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> --- configure | 77 +++------------------------------------------ meson.build | 80 ++++++++++++++++++++++++++++++++++++++++++----- meson_options.txt | 2 ++ 3 files changed, 78 insertions(+), 81 deletions(-)