qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Aurelien Jarno <aurelien@aurel32.net>
To: qemu-devel@nongnu.org
Cc: kvm <kvm@vger.kernel.org>
Subject: Re: [Qemu-devel] [PATCH] hpet config mask fix
Date: Fri, 16 Jan 2009 22:39:06 +0100	[thread overview]
Message-ID: <20090116213906.GC22128@volta.aurel32.net> (raw)
In-Reply-To: <496DFA90.8050100@us.ibm.com>

On Wed, Jan 14, 2009 at 09:45:36AM -0500, Beth Kon wrote:
> I discovered a bug in the hpet code that caused Windows to boot without  
> hpet. The config mask I was using was preventing the guest from placing  
> the hpet into 32 bit mode.
>

Thanks, applied.

> diff --git a/qemu/hw/hpet.c b/qemu/hw/hpet.c
> index 5c1aca2..7df2d05 100644
> --- a/qemu/hw/hpet.c
> +++ b/qemu/hw/hpet.c
> @@ -388,7 +388,8 @@ static void hpet_ram_writel(void *opaque, target_phys_addr_t addr,
>          switch ((addr - 0x100) % 0x20) {
>              case HPET_TN_CFG:
>                  dprintf("qemu: hpet_ram_writel HPET_TN_CFG\n");
> -                timer->config = hpet_fixup_reg(new_val, old_val, 0x3e4e);
> +                timer->config = hpet_fixup_reg(new_val, old_val, 
> +                                               HPET_TN_CFG_WRITE_MASK);
>                  if (new_val & HPET_TN_32BIT) {
>                      timer->cmp = (uint32_t)timer->cmp;
>                      timer->period = (uint32_t)timer->period;
> @@ -456,7 +457,8 @@ static void hpet_ram_writel(void *opaque, target_phys_addr_t addr,
>              case HPET_ID:
>                  return;
>              case HPET_CFG:
> -                s->config = hpet_fixup_reg(new_val, old_val, 0x3);
> +                s->config = hpet_fixup_reg(new_val, old_val, 
> +                                           HPET_CFG_WRITE_MASK);
>                  if (activating_bit(old_val, new_val, HPET_CFG_ENABLE)) {
>                      /* Enable main counter and interrupt generation. */
>                      s->hpet_offset = ticks_to_ns(s->hpet_counter)
> diff --git a/qemu/hw/hpet_emul.h b/qemu/hw/hpet_emul.h
> index fbe7a44..60893b6 100644
> --- a/qemu/hw/hpet_emul.h
> +++ b/qemu/hw/hpet_emul.h
> @@ -36,6 +36,7 @@
>  #define HPET_TN_CFG     0x000
>  #define HPET_TN_CMP     0x008
>  #define HPET_TN_ROUTE   0x010
> +#define HPET_CFG_WRITE_MASK  0x3
>  
>  
>  #define HPET_TN_ENABLE           0x004
> @@ -45,6 +46,7 @@
>  #define HPET_TN_SETVAL           0x040
>  #define HPET_TN_32BIT            0x100
>  #define HPET_TN_INT_ROUTE_MASK  0x3e00
> +#define HPET_TN_CFG_WRITE_MASK  0x3f4e
>  #define HPET_TN_INT_ROUTE_SHIFT      9
>  #define HPET_TN_INT_ROUTE_CAP_SHIFT 32
>  #define HPET_TN_CFG_BITS_READONLY_OR_RESERVED 0xffff80b1U


-- 
  .''`.  Aurelien Jarno	            | GPG: 1024D/F1BCDB73
 : :' :  Debian developer           | Electrical Engineer
 `. `'   aurel32@debian.org         | aurelien@aurel32.net
   `-    people.debian.org/~aurel32 | www.aurel32.net

      reply	other threads:[~2009-01-16 21:39 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-01-14 14:45 [Qemu-devel] [PATCH] hpet config mask fix Beth Kon
2009-01-16 21:39 ` Aurelien Jarno [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=20090116213906.GC22128@volta.aurel32.net \
    --to=aurelien@aurel32.net \
    --cc=kvm@vger.kernel.org \
    --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).