Note: I _also_ screwed up this rebase a bit unfortunately but this one should 
be clean: 
https://github.com/mediouni-m/qemu/commit/66f052d80b6b51a60374074cec876f9bfc8a756c
 

To not cause too much spam on the ML will most likely batch this when I have 
more changes...

> On 2. Aug 2025, at 10:17, Mohamed Mediouni <moha...@unpredictable.fr> wrote:
> 
> Switch to a design where we can share whpx code between x86 and AArch64 when 
> it makes sense to do so.
> 
> Signed-off-by: Mohamed Mediouni <moha...@unpredictable.fr>
> 
> Reviewed-by: Philippe Mathieu-Daudé <phi...@linaro.org>
> ---
> MAINTAINERS                                           | 2 ++
> accel/meson.build                                     | 1 +
> accel/whpx/meson.build                                | 6 ++++++
> {target/i386 => accel}/whpx/whpx-accel-ops.c          | 4 ++--
> {target/i386/whpx => include/system}/whpx-accel-ops.h | 0
> target/i386/whpx/meson.build                          | 1 -
> target/i386/whpx/whpx-all.c                           | 4 ++--
> target/i386/whpx/whpx-internal.h                      | 1 +
> 8 files changed, 14 insertions(+), 5 deletions(-)
> create mode 100644 accel/whpx/meson.build
> rename {target/i386 => accel}/whpx/whpx-accel-ops.c (97%)
> rename {target/i386/whpx => include/system}/whpx-accel-ops.h (100%)
> 
> diff --git a/MAINTAINERS b/MAINTAINERS
> index 28cea34271..238065e1c9 100644
> --- a/MAINTAINERS
> +++ b/MAINTAINERS
> @@ -542,9 +542,11 @@ F: include/system/hvf_int.h
> WHPX CPUs
> M: Sunil Muthuswamy <sunil...@microsoft.com>
> S: Supported
> +F: accel/whpx/
> F: target/i386/whpx/
> F: accel/stubs/whpx-stub.c
> F: include/system/whpx.h
> +F: include/system/whpx-accel-ops.h
> 
> X86 Instruction Emulator
> M: Cameron Esfahani <di...@apple.com>
> diff --git a/accel/meson.build b/accel/meson.build
> index 25b0f100b5..de927a3b37 100644
> --- a/accel/meson.build
> +++ b/accel/meson.build
> @@ -6,6 +6,7 @@ user_ss.add(files('accel-user.c'))
> subdir('tcg')
> if have_system
>   subdir('hvf')
> +  subdir('whpx')
>   subdir('qtest')
>   subdir('kvm')
>   subdir('xen')
> diff --git a/accel/whpx/meson.build b/accel/whpx/meson.build
> new file mode 100644
> index 0000000000..7b3d6f1c1c
> --- /dev/null
> +++ b/accel/whpx/meson.build
> @@ -0,0 +1,6 @@
> +whpx_ss = ss.source_set()
> +whpx_ss.add(files(
> +  'whpx-accel-ops.c',
> +))
> +
> +specific_ss.add_all(when: 'CONFIG_WHPX', if_true: whpx_ss)
> diff --git a/target/i386/whpx/whpx-accel-ops.c b/accel/whpx/whpx-accel-ops.c
> similarity index 97%
> rename from target/i386/whpx/whpx-accel-ops.c
> rename to accel/whpx/whpx-accel-ops.c
> index da58805b1a..18488421bc 100644
> --- a/target/i386/whpx/whpx-accel-ops.c
> +++ b/accel/whpx/whpx-accel-ops.c
> @@ -16,8 +16,8 @@
> #include "qemu/guest-random.h"
> 
> #include "system/whpx.h"
> -#include "whpx-internal.h"
> -#include "whpx-accel-ops.h"
> +#include "system/whpx-internal.h"
> +#include "system/whpx-accel-ops.h"
> 
> static void *whpx_cpu_thread_fn(void *arg)
> {
> diff --git a/target/i386/whpx/whpx-accel-ops.h 
> b/include/system/whpx-accel-ops.h
> similarity index 100%
> rename from target/i386/whpx/whpx-accel-ops.h
> rename to include/system/whpx-accel-ops.h
> diff --git a/target/i386/whpx/meson.build b/target/i386/whpx/meson.build
> index 9c54aaad39..c3aaaff9fd 100644
> --- a/target/i386/whpx/meson.build
> +++ b/target/i386/whpx/meson.build
> @@ -1,5 +1,4 @@
> i386_system_ss.add(when: 'CONFIG_WHPX', if_true: files(
>   'whpx-all.c',
>   'whpx-apic.c',
> -  'whpx-accel-ops.c',
> ))
> diff --git a/target/i386/whpx/whpx-all.c b/target/i386/whpx/whpx-all.c
> index b72dcff3c8..5a431fc3c7 100644
> --- a/target/i386/whpx/whpx-all.c
> +++ b/target/i386/whpx/whpx-all.c
> @@ -31,8 +31,8 @@
> #include "accel/accel-cpu-target.h"
> #include <winerror.h>
> 
> -#include "whpx-internal.h"
> -#include "whpx-accel-ops.h"
> +#include "system/whpx-internal.h"
> +#include "system/whpx-accel-ops.h"
> 
> #include <winhvplatform.h>
> #include <winhvemulation.h>
> diff --git a/target/i386/whpx/whpx-internal.h 
> b/target/i386/whpx/whpx-internal.h
> index 6633e9c4ca..435e0c5046 100644
> --- a/target/i386/whpx/whpx-internal.h
> +++ b/target/i386/whpx/whpx-internal.h
> @@ -117,3 +117,4 @@ typedef enum WHPFunctionList {
> } WHPFunctionList;
> 
> #endif /* TARGET_I386_WHPX_INTERNAL_H */
> +
> -- 
> 2.39.5 (Apple Git-154)
> 

Reply via email to