From: Paolo Bonzini <pbonzini@redhat.com>
To: "Philippe Mathieu-Daudé" <philmd@redhat.com>, qemu-devel@nongnu.org
Cc: Richard Henderson <rth@twiddle.net>
Subject: Re: [PATCH] cpus: Move CPU code from exec.c to cpus.c
Date: Thu, 2 Jul 2020 12:21:35 +0200 [thread overview]
Message-ID: <34ef8d81-4559-9887-3420-c0045bb83d46@redhat.com> (raw)
In-Reply-To: <b476ded8-fbd6-f9d5-66b7-67e7128e86fd@redhat.com>
On 02/07/20 11:38, Paolo Bonzini wrote:
> On 01/07/20 19:54, Philippe Mathieu-Daudé wrote:
>> This code was introduced with SMP support in commit 6a00d60127,
>> later commit 296af7c952 moved CPU parts to cpus.c but forgot this
>> code. Move now and simplify ifdef'ry.
>>
>> Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
>> ---
>> cpus.c | 18 ++++++++++++++++++
>> exec.c | 22 ----------------------
>> 2 files changed, 18 insertions(+), 22 deletions(-)
>>
>> diff --git a/cpus.c b/cpus.c
>> index 41d1c5099f..472686cbbc 100644
>> --- a/cpus.c
>> +++ b/cpus.c
>> @@ -92,6 +92,11 @@ static unsigned int throttle_percentage;
>> #define CPU_THROTTLE_PCT_MAX 99
>> #define CPU_THROTTLE_TIMESLICE_NS 10000000
>>
>> +CPUTailQ cpus = QTAILQ_HEAD_INITIALIZER(cpus);
>> +
>> +/* current CPU in the current thread. It is only valid inside cpu_exec() */
>> +__thread CPUState *current_cpu;
>> +
>> bool cpu_is_stopped(CPUState *cpu)
>> {
>> return cpu->stopped || !runstate_is_running();
>> @@ -134,6 +139,19 @@ static bool all_cpu_threads_idle(void)
>> return true;
>> }
>>
>> +CPUState *qemu_get_cpu(int index)
>> +{
>> + CPUState *cpu;
>> +
>> + CPU_FOREACH(cpu) {
>> + if (cpu->cpu_index == index) {
>> + return cpu;
>> + }
>> + }
>> +
>> + return NULL;
>> +}
>> +
>> /***********************************************************/
>> /* guest cycle counter */
>>
>> diff --git a/exec.c b/exec.c
>> index 21926dc9c7..997b7db15f 100644
>> --- a/exec.c
>> +++ b/exec.c
>> @@ -98,12 +98,6 @@ AddressSpace address_space_memory;
>> static MemoryRegion io_mem_unassigned;
>> #endif
>>
>> -CPUTailQ cpus = QTAILQ_HEAD_INITIALIZER(cpus);
>> -
>> -/* current CPU in the current thread. It is only valid inside
>> - cpu_exec() */
>> -__thread CPUState *current_cpu;
>> -
>> uintptr_t qemu_host_page_size;
>> intptr_t qemu_host_page_mask;
>>
>> @@ -832,22 +826,6 @@ const VMStateDescription vmstate_cpu_common = {
>> }
>> };
>>
>> -#endif
>> -
>> -CPUState *qemu_get_cpu(int index)
>> -{
>> - CPUState *cpu;
>> -
>> - CPU_FOREACH(cpu) {
>> - if (cpu->cpu_index == index) {
>> - return cpu;
>> - }
>> - }
>> -
>> - return NULL;
>> -}
>> -
>> -#if !defined(CONFIG_USER_ONLY)
>> void cpu_address_space_init(CPUState *cpu, int asidx,
>> const char *prefix, MemoryRegion *mr)
>> {
>>
>
> Queued, thanks.
>
> Paolo
>
>
Wait... this is in exec.c because cpus.c is not linked into user-mode
emulators.
Paolo
next prev parent reply other threads:[~2020-07-02 10:22 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-07-01 17:54 [PATCH] cpus: Move CPU code from exec.c to cpus.c Philippe Mathieu-Daudé
2020-07-02 4:06 ` Richard Henderson
2020-07-02 9:38 ` Paolo Bonzini
2020-07-02 10:21 ` Paolo Bonzini [this message]
2020-07-02 10:31 ` Philippe Mathieu-Daudé
2020-07-02 10:33 ` Alex Bennée
2020-07-02 10:26 ` 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=34ef8d81-4559-9887-3420-c0045bb83d46@redhat.com \
--to=pbonzini@redhat.com \
--cc=philmd@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=rth@twiddle.net \
/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).