From: Anthony Liguori <anthony@codemonkey.ws>
To: Avi Kivity <avi@redhat.com>
Cc: qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [PATCH] memory: fix rendering of a region obscured by another
Date: Mon, 29 Oct 2012 15:47:27 -0500 [thread overview]
Message-ID: <871ughf1k0.fsf@codemonkey.ws> (raw)
In-Reply-To: <1351527756-13782-1-git-send-email-avi@redhat.com>
Avi Kivity <avi@redhat.com> writes:
> The memory core drops regions that are hidden by another region (for example,
> during BAR sizing), but it doesn't do so correctly if the lower address of the
> existing range is below the lower address of the new range.
>
> Example (qemu-system-mips -M malta -kernel vmlinux-2.6.32-5-4kc-malta
> -append "console=ttyS0" -nographic -vga cirrus):
>
> Existing range: 10000000-107fffff
> New range: 100a0000-100bffff
>
> Correct behaviour: drop new range
> Incorrect behaviour: add new range
>
> Fix by taking this case into account (previously we only considered
> equal lower boundaries).
>
> Tested-by: Aurelien Jarno <aurelien@aurel32.net>
> Signed-off-by: Avi Kivity <avi@redhat.com>
Applied. Thanks.
Regards,
Anthony Liguori
> ---
> memory.c | 12 ++++++------
> 1 file changed, 6 insertions(+), 6 deletions(-)
>
> diff --git a/memory.c b/memory.c
> index 36bb9a5..243cb23 100644
> --- a/memory.c
> +++ b/memory.c
> @@ -539,12 +539,12 @@ static void render_memory_region(FlatView *view,
> offset_in_region += int128_get64(now);
> int128_subfrom(&remain, now);
> }
> - if (int128_eq(base, view->ranges[i].addr.start)) {
> - now = int128_min(remain, view->ranges[i].addr.size);
> - int128_addto(&base, now);
> - offset_in_region += int128_get64(now);
> - int128_subfrom(&remain, now);
> - }
> + now = int128_sub(int128_min(int128_add(base, remain),
> + addrrange_end(view->ranges[i].addr)),
> + base);
> + int128_addto(&base, now);
> + offset_in_region += int128_get64(now);
> + int128_subfrom(&remain, now);
> }
> if (int128_nz(remain)) {
> fr.mr = mr;
> --
> 1.7.12
prev parent reply other threads:[~2012-10-29 20:47 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-10-29 16:22 [Qemu-devel] [PATCH] memory: fix rendering of a region obscured by another Avi Kivity
2012-10-29 20:47 ` Anthony Liguori [this message]
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=871ughf1k0.fsf@codemonkey.ws \
--to=anthony@codemonkey.ws \
--cc=avi@redhat.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 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).