qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Richard Henderson <richard.henderson@linaro.org>
To: "Philippe Mathieu-Daudé" <philmd@linaro.org>, qemu-devel@nongnu.org
Cc: "Fabiano Rosas" <farosas@suse.de>,
	"Paolo Bonzini" <pbonzini@redhat.com>,
	"Alex Bennée" <alex.bennee@linaro.org>,
	"Marc-André Lureau" <marcandre.lureau@redhat.com>,
	"Thomas Huth" <thuth@redhat.com>,
	"Laurent Vivier" <laurent@vivier.eu>
Subject: Re: [PATCH] gdbstub: Only build libgdb_user.fa / libgdb_softmmu.fa if necessary
Date: Wed, 29 Mar 2023 09:39:33 -0700	[thread overview]
Message-ID: <3f659630-f990-a2e8-d498-2c4c4888fc5f@linaro.org> (raw)
In-Reply-To: <20230329161852.84992-1-philmd@linaro.org>

On 3/29/23 09:18, Philippe Mathieu-Daudé wrote:
> It is pointless to build libgdb_user.fa in a system-only build
> (or libgdb_softmmu.fa in a user-only build). Besides, in some
> restricted build configurations, some APIs might be restricted /
> not available. Example in a KVM-only builds where TCG is disabled:
> 
>    $ ninja qemu-system-x86_64
>    [99/2187] Compiling C object gdbstub/libgdb_user.fa.p/user.c.o
>    FAILED: gdbstub/libgdb_user.fa.p/user.c.o
>    ../../gdbstub/user.c: In function ‘gdb_breakpoint_insert’:
>    ../../gdbstub/user.c:438:19: error: implicit declaration of function ‘cpu_breakpoint_insert’; did you mean ‘gdb_breakpoint_insert’? [-Werror=implicit-function-declaration]
>      438 |             err = cpu_breakpoint_insert(cpu, addr, BP_GDB, NULL);
>          |                   ^~~~~~~~~~~~~~~~~~~~~
>          |                   gdb_breakpoint_insert
>    ../../gdbstub/user.c:438:19: error: nested extern declaration of ‘cpu_breakpoint_insert’ [-Werror=nested-externs]
>    ../../gdbstub/user.c: In function ‘gdb_breakpoint_remove’:
>    ../../gdbstub/user.c:459:19: error: implicit declaration of function ‘cpu_breakpoint_remove’; did you mean ‘gdb_breakpoint_remove’? [-Werror=implicit-function-declaration]
>      459 |             err = cpu_breakpoint_remove(cpu, addr, BP_GDB);
>          |                   ^~~~~~~~~~~~~~~~~~~~~
>          |                   gdb_breakpoint_remove
>    ../../gdbstub/user.c:459:19: error: nested extern declaration of ‘cpu_breakpoint_remove’ [-Werror=nested-externs]
>    cc1: all warnings being treated as errors
>    ninja: build stopped: subcommand failed.
> 
> Fixes: 61b2e136db ("gdbstub: only compile gdbstub twice for whole build")
> Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
> ---

Reviewed-by: Richard Henderson <richard.henderson@linaro.org>

r~

>   gdbstub/meson.build | 6 ++++--
>   1 file changed, 4 insertions(+), 2 deletions(-)
> 
> diff --git a/gdbstub/meson.build b/gdbstub/meson.build
> index bd5c5cd67d..cdb4d28691 100644
> --- a/gdbstub/meson.build
> +++ b/gdbstub/meson.build
> @@ -20,11 +20,13 @@ gdb_softmmu_ss = gdb_softmmu_ss.apply(config_host, strict: false)
>   libgdb_user = static_library('gdb_user',
>                                gdb_user_ss.sources() + genh,
>                                name_suffix: 'fa',
> -                             c_args: '-DCONFIG_USER_ONLY')
> +                             c_args: '-DCONFIG_USER_ONLY',
> +                             build_by_default: have_user)
>   
>   libgdb_softmmu = static_library('gdb_softmmu',
>                                   gdb_softmmu_ss.sources() + genh,
> -                                name_suffix: 'fa')
> +                                name_suffix: 'fa',
> +                                build_by_default: have_system)
>   
>   gdb_user = declare_dependency(link_whole: libgdb_user)
>   user_ss.add(gdb_user)



  reply	other threads:[~2023-03-29 16:40 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-03-29 16:18 [PATCH] gdbstub: Only build libgdb_user.fa / libgdb_softmmu.fa if necessary Philippe Mathieu-Daudé
2023-03-29 16:39 ` Richard Henderson [this message]
2023-03-29 17:03 ` Alex Bennée

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=3f659630-f990-a2e8-d498-2c4c4888fc5f@linaro.org \
    --to=richard.henderson@linaro.org \
    --cc=alex.bennee@linaro.org \
    --cc=farosas@suse.de \
    --cc=laurent@vivier.eu \
    --cc=marcandre.lureau@redhat.com \
    --cc=pbonzini@redhat.com \
    --cc=philmd@linaro.org \
    --cc=qemu-devel@nongnu.org \
    --cc=thuth@redhat.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).