[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 02/11] meson: Add rust_block_ss and link tools with it
From: |
Kevin Wolf |
Subject: |
[PATCH v2 02/11] meson: Add rust_block_ss and link tools with it |
Date: |
Tue, 18 Feb 2025 19:20:10 +0100 |
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
---
meson.build | 36 ++++++++++++++++++++++++++++++++----
storage-daemon/meson.build | 2 +-
2 files changed, 33 insertions(+), 5 deletions(-)
diff --git a/meson.build b/meson.build
index 6ee1757828..a08d029032 100644
--- a/meson.build
+++ b/meson.build
@@ -3640,6 +3640,7 @@ qom_ss = ss.source_set()
system_ss = ss.source_set()
specific_fuzz_ss = ss.source_set()
specific_ss = ss.source_set()
+rust_block_ss = ss.source_set()
rust_devices_ss = ss.source_set()
stub_ss = ss.source_set()
trace_ss = ss.source_set()
@@ -4217,7 +4218,11 @@ foreach target : target_dirs
arch_deps += target_specific.dependencies()
if have_rust and target_type == 'system'
- target_rust = rust_devices_ss.apply(config_target, strict: false)
+ target_rust_ss = ss.source_set()
+ target_rust_ss.add_all(rust_block_ss)
+ target_rust_ss.add_all(rust_devices_ss)
+
+ target_rust = target_rust_ss.apply(config_target, strict: false)
crates = []
foreach dep : target_rust.dependencies()
crates += dep.get_variable('crate')
@@ -4357,15 +4362,38 @@ if xkbcommon.found()
endif
if have_tools
+ tools_deps = []
+ if have_rust
+ tools_rust = rust_block_ss.apply({})
+ crates = []
+ foreach dep : tools_rust.dependencies()
+ crates += dep.get_variable('crate')
+ endforeach
+ if crates.length() > 0
+ rlib_rs = custom_target('rust_tools.rs',
+ output: 'rust_tools.rs',
+ command: [rust_root_crate, crates],
+ capture: true,
+ build_by_default: true,
+ build_always_stale: true)
+ rlib = static_library('rust_tools',
+ rlib_rs,
+ dependencies: tools_rust.dependencies(),
+ override_options: ['rust_std=2021',
'build.rust_std=2021'],
+ rust_abi: 'c')
+ tools_deps += declare_dependency(link_whole: [rlib])
+ endif
+ endif
+
qemu_img = executable('qemu-img', [files('qemu-img.c'), hxdep],
link_args: '@block.syms', link_depends: block_syms,
- dependencies: [authz, block, crypto, io, qom, qemuutil], install:
true)
+ dependencies: tools_deps + [authz, block, crypto, io, qom,
qemuutil], install: true)
qemu_io = executable('qemu-io', files('qemu-io.c'),
link_args: '@block.syms', link_depends: block_syms,
- dependencies: [block, qemuutil], install: true)
+ dependencies: tools_deps + [block, qemuutil], install: true)
qemu_nbd = executable('qemu-nbd', files('qemu-nbd.c'),
link_args: '@block.syms', link_depends: block_syms,
- dependencies: [blockdev, qemuutil, selinux],
+ dependencies: tools_deps + [blockdev, qemuutil, selinux],
install: true)
subdir('storage-daemon')
diff --git a/storage-daemon/meson.build b/storage-daemon/meson.build
index 5e61a9d1bd..92bc2e0cba 100644
--- a/storage-daemon/meson.build
+++ b/storage-daemon/meson.build
@@ -9,6 +9,6 @@ if have_tools
qsd = executable('qemu-storage-daemon',
qsd_ss.sources(),
link_args: '@block.syms', link_depends: block_syms,
- dependencies: qsd_ss.dependencies(),
+ dependencies: tools_deps + qsd_ss.dependencies(),
install: true)
endif
--
2.48.1
- [PATCH v2 00/11] rust/block: Add minimal block driver bindings, Kevin Wolf, 2025/02/18
- [PATCH v2 02/11] meson: Add rust_block_ss and link tools with it,
Kevin Wolf <=
- [PATCH v2 01/11] rust: Build separate qemu_api_tools and qemu_api_system, Kevin Wolf, 2025/02/18
- [PATCH v2 05/11] rust/block: Add empty crate, Kevin Wolf, 2025/02/18
- [PATCH v2 04/11] rust/qemu-api: Add wrappers to run futures in QEMU, Kevin Wolf, 2025/02/18
- [PATCH v2 06/11] rust/block: Add I/O buffer traits, Kevin Wolf, 2025/02/18
- [PATCH v2 08/11] rust/block: Add driver module, Kevin Wolf, 2025/02/18