All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jan Kiszka <jan.kiszka@siemens.com>
To: Alexander Graf <agraf@suse.de>
Cc: qemu-devel@nongnu.org, hollisb@us.ibm.com
Subject: [Qemu-devel] Re: [PATCH 7/7] Fake dirty loggin when it's not there
Date: Fri, 17 Jul 2009 17:47:53 +0200	[thread overview]
Message-ID: <4A609D29.2060701@siemens.com> (raw)
In-Reply-To: <E80FE1B9-4E31-457E-BDA1-2AA7C207EAE7@suse.de>

Alexander Graf wrote:
> 
> On 17.07.2009, at 16:37, Jan Kiszka wrote:
> 
>> Alexander Graf wrote:
>>> Some KVM platforms don't support dirty logging yet, like IA64 and PPC,
>>> so in order to still have screen updates on those, we need to fake it.
>>>
>>> This patch just tells the getter function for dirty bitmaps, that all
>>> pages within a slot are dirty when the slot has dirty logging enabled.
>>>
>>> That way we can implement dirty logging on those platforms sometime when
>>> it drags down performance, but share the rest of the code with dirty
>>> logging capable platforms.
>>>
>>> Signed-off-by: Alexander Graf <agraf@suse.de>
>>> ---
>>> kvm-all.c |   13 ++++++++++++-
>>> 1 files changed, 12 insertions(+), 1 deletions(-)
>>>
>>> diff --git a/kvm-all.c b/kvm-all.c
>>> index 60b76cf..72b7935 100644
>>> --- a/kvm-all.c
>>> +++ b/kvm-all.c
>>> @@ -300,6 +300,7 @@ int
>>> kvm_physical_sync_dirty_bitmap(target_phys_addr_t start_addr,
>>>     KVMDirtyLog d;
>>>     KVMSlot *mem;
>>>     int ret = 0;
>>> +    int r;
>>>
>>>     d.dirty_bitmap = NULL;
>>>     while (start_addr < end_addr) {
>>> @@ -308,6 +309,11 @@ int
>>> kvm_physical_sync_dirty_bitmap(target_phys_addr_t start_addr,
>>>             break;
>>>         }
>>>
>>> +        /* We didn't activate dirty logging? Don't care then. */
>>> +        if(!(mem->flags & KVM_MEM_LOG_DIRTY_PAGES)) {
>>> +            continue;
>>> +        }
>>> +
>>
>> Isn't this worth a separate patch? Do we already run into this patch on
>> dirty-logging archs (ie. x86)? I'm still wondering why it's needed.
> 
> We don't. I'm just being paranoid.
> 
>>>         size = ((mem->memory_size >> TARGET_PAGE_BITS) + 7) / 8;
>>>         if (!d.dirty_bitmap) {
>>>             d.dirty_bitmap = qemu_malloc(size);
>>> @@ -319,7 +325,8 @@ int
>>> kvm_physical_sync_dirty_bitmap(target_phys_addr_t start_addr,
>>>
>>>         d.slot = mem->slot;
>>>
>>> -        if (kvm_vm_ioctl(s, KVM_GET_DIRTY_LOG, &d) == -1) {
>>> +        r = kvm_vm_ioctl(s, KVM_GET_DIRTY_LOG, &d);
>>> +        if (r == -EINVAL) {
>>
>> I would say, better exclude 0 and the error you for missing support here
>> than to assume only EINVAL is a "real" error.
> 
> Hum, this was the logic that was there before and it makes sense.
> -EINVAL is used for errors whole -ENOTSUPP is used for N/A.
> Unfortunately -ENOTSUPP is only exported when __KERNEL__ is defined.

Uuh, kvm returns a private error code to user space? That would be a
bug. So we need a check for the to-be-fixed error code and >= 512.

Jan

-- 
Siemens AG, Corporate Technology, CT SE 2
Corporate Competence Center Embedded Linux

  reply	other threads:[~2009-07-17 15:48 UTC|newest]

Thread overview: 32+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-07-17 11:51 [Qemu-devel] [PATCH 0/4] Add preliminary KVM support for non-embedded PPC v3 Alexander Graf
2009-07-17 11:51 ` [Qemu-devel] [PATCH 1/7] Enable PPC KVM for non-embedded Alexander Graf
2009-07-17 11:51   ` [Qemu-devel] [PATCH 2/7] Set PVR in sregs Alexander Graf
2009-07-17 11:51     ` [Qemu-devel] [PATCH 3/7] Add mp_state to PPC CPU struct Alexander Graf
2009-07-17 11:51       ` [Qemu-devel] [PATCH 4/7] Fix warning in kvm-all.c Alexander Graf
2009-07-17 11:51         ` [Qemu-devel] [PATCH 5/7] Use correct input constant Alexander Graf
2009-07-17 11:51           ` [Qemu-devel] [PATCH 6/7] Set slots more carefully Alexander Graf
2009-07-17 11:51             ` [Qemu-devel] [PATCH 7/7] Fake dirty loggin when it's not there Alexander Graf
2009-07-17 12:10               ` Stefano Stabellini
2009-07-17 12:14                 ` Alexander Graf
2009-07-17 12:18                 ` Alexander Graf
2009-07-17 12:25                   ` Stefano Stabellini
2009-07-17 12:27                   ` Alexander Graf
2009-07-17 13:18                     ` Stefano Stabellini
2009-07-17 13:23                       ` Alexander Graf
2009-07-17 14:37               ` [Qemu-devel] " Jan Kiszka
2009-07-17 15:00                 ` Alexander Graf
2009-07-17 15:47                   ` Jan Kiszka [this message]
2009-07-17 13:48             ` [Qemu-devel] Re: [PATCH 6/7] Set slots more carefully Jan Kiszka
2009-07-17 13:53               ` Alexander Graf
2009-07-17 14:18                 ` Jan Kiszka
2009-07-17 14:23                   ` Alexander Graf
2009-07-17 14:30                     ` Jan Kiszka
2009-07-21 22:55             ` [Qemu-devel] " Anthony Liguori
2009-07-22 15:34       ` [Qemu-devel] [PATCH 3/7] Add mp_state to PPC CPU struct Anthony Liguori
2009-07-22 15:59         ` Hollis Blanchard
2009-07-22 16:22           ` Anthony Liguori
2009-07-22 16:26             ` Hollis Blanchard
2009-07-22 16:51               ` [Qemu-devel] " Jan Kiszka
2009-07-22 18:11                 ` Anthony Liguori
2009-07-22 19:11                   ` Jan Kiszka
2009-07-21 22:36 ` [Qemu-devel] Re: [PATCH 0/4] Add preliminary KVM support for non-embedded PPC v3 Hollis Blanchard

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=4A609D29.2060701@siemens.com \
    --to=jan.kiszka@siemens.com \
    --cc=agraf@suse.de \
    --cc=hollisb@us.ibm.com \
    --cc=qemu-devel@nongnu.org \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.