qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v1 15/22] Add iommufd configure option


From: Cédric Le Goater
Subject: Re: [PATCH v1 15/22] Add iommufd configure option
Date: Tue, 19 Sep 2023 19:07:35 +0200
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0

On 8/30/23 12:37, Zhenzhong Duan wrote:
This adds "--enable-iommufd/--disable-iommufd" to enable or disable
iommufd support, enabled by default.

Why would someone want to disable support at compile time ? It might
have been useful for dev but now QEMU should self-adjust at runtime
depending only on the host capabilities AFAIUI. Am I missing something ?

Thanks,

C.



Signed-off-by: Zhenzhong Duan <zhenzhong.duan@intel.com>
---
  meson.build                   | 6 ++++++
  meson_options.txt             | 2 ++
  scripts/meson-buildoptions.sh | 3 +++
  3 files changed, 11 insertions(+)

diff --git a/meson.build b/meson.build
index 98e68ef0b1..6526d8cc9b 100644
--- a/meson.build
+++ b/meson.build
@@ -574,6 +574,10 @@ have_tpm = get_option('tpm') \
    .require(targetos != 'windows', error_message: 'TPM emulation only 
available on POSIX systems') \
    .allowed()
+have_iommufd = get_option('iommufd') \
+  .require(targetos == 'linux', error_message: 'iommufd is supported only on 
Linux') \
+  .allowed()
+
  # vhost
  have_vhost_user = get_option('vhost_user') \
    .disable_auto_if(targetos != 'linux') \
@@ -2129,6 +2133,7 @@ endif
  config_host_data.set('CONFIG_SNAPPY', snappy.found())
  config_host_data.set('CONFIG_TPM', have_tpm)
  config_host_data.set('CONFIG_TSAN', get_option('tsan'))
+config_host_data.set('CONFIG_IOMMUFD', have_iommufd)
  config_host_data.set('CONFIG_USB_LIBUSB', libusb.found())
  config_host_data.set('CONFIG_VDE', vde.found())
  config_host_data.set('CONFIG_VHOST_NET', have_vhost_net)
@@ -4051,6 +4056,7 @@ summary_info += {'vhost-user-crypto support': 
have_vhost_user_crypto}
  summary_info += {'vhost-user-blk server support': have_vhost_user_blk_server}
  summary_info += {'vhost-vdpa support': have_vhost_vdpa}
  summary_info += {'build guest agent': have_ga}
+summary_info += {'iommufd support': have_iommufd}
  summary(summary_info, bool_yn: true, section: 'Configurable features')
# Compilation information
diff --git a/meson_options.txt b/meson_options.txt
index aaea5ddd77..aed91d173b 100644
--- a/meson_options.txt
+++ b/meson_options.txt
@@ -105,6 +105,8 @@ option('dbus_display', type: 'feature', value: 'auto',
         description: '-display dbus support')
  option('tpm', type : 'feature', value : 'auto',
         description: 'TPM support')
+option('iommufd', type : 'feature', value : 'auto',
+       description: 'iommufd support')
# Do not enable it by default even for Mingw32, because it doesn't
  # work on Wine.
diff --git a/scripts/meson-buildoptions.sh b/scripts/meson-buildoptions.sh
index 9da3fe299b..719401ffb0 100644
--- a/scripts/meson-buildoptions.sh
+++ b/scripts/meson-buildoptions.sh
@@ -113,6 +113,7 @@ meson_options_help() {
    printf "%s\n" '  hax             HAX acceleration support'
    printf "%s\n" '  hvf             HVF acceleration support'
    printf "%s\n" '  iconv           Font glyph conversion support'
+  printf "%s\n" '  iommufd         iommufd support'
    printf "%s\n" '  jack            JACK sound support'
    printf "%s\n" '  keyring         Linux keyring support'
    printf "%s\n" '  kvm             KVM acceleration support'
@@ -325,6 +326,8 @@ _meson_option_parse() {
      --enable-install-blobs) printf "%s" -Dinstall_blobs=true ;;
      --disable-install-blobs) printf "%s" -Dinstall_blobs=false ;;
      --interp-prefix=*) quote_sh "-Dinterp_prefix=$2" ;;
+    --enable-iommufd) printf "%s" -Diommufd=enabled ;;
+    --disable-iommufd) printf "%s" -Diommufd=disabled ;;
      --enable-jack) printf "%s" -Djack=enabled ;;
      --disable-jack) printf "%s" -Djack=disabled ;;
      --enable-keyring) printf "%s" -Dkeyring=enabled ;;




reply via email to

[Prev in Thread] Current Thread [Next in Thread]