All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH][QEMU] Allow more IDE power management
@ 2007-08-27 18:45 Ben Guthro
  2007-08-27 19:19 ` Daniel P. Berrange
  0 siblings, 1 reply; 2+ messages in thread
From: Ben Guthro @ 2007-08-27 18:45 UTC (permalink / raw)
  To: xen-devel; +Cc: Dave Lively

[-- Attachment #1: Type: text/plain, Size: 884 bytes --]

Made the QEMU IDE disk tolerate more power-mgmt commands, specifically:
	WIN_SETFEATURE(EN_AAM)	- enable automatic acoustic mgmt
	WIN_SETFEATURE(DIS_AAM)	- disable automatic acoustic mgmt
	WIN_SETFEATURE(DIS_APM)	- disable automatic power mgmt
	WIN_STANDBY
	WIN_SETIDLE1
	WIN_SLEEPNOW1
	WIN_STANDBY2
	WIN_SETIDLE2
	WIN_SLEEPNOW2
	WIN_STANDBYNOW2
These are all essentially no-ops, like existing support for EN_RLA (enable
read lookahead) and WIN_STANDBYNOW1.

This fixes a crash in the SLES9-SP3 64bit kernel when the powersaved was
started (with ACPI or ACM).  This guest really only needs EN_AAM, DIS_APM,
and WIN_SETIDLE1 support, but the others seemed sensible to include.

I've excluded EN_APM since I'm unsure of what that's agreeing to do.  It's
probably ok to include.

Signed-off-by: Ben Guthro <bguthro@virtualiron.com>
Signed-off-by: David Lively <dlively@virtualiron.com>


[-- Attachment #2: qemu-ide-allow-more-powermgmt.patch --]
[-- Type: text/x-patch, Size: 1111 bytes --]

diff -r b9f911005829 tools/ioemu/hw/ide.c
--- a/tools/ioemu/hw/ide.c	Wed Aug 01 19:06:43 2007 -0400
+++ b/tools/ioemu/hw/ide.c	Wed Aug 01 19:06:43 2007 -0400
@@ -2136,6 +2136,9 @@ static void ide_ioport_write(void *opaqu
                 break;
             case 0xaa: /* read look-ahead enable */
             case 0x55: /* read look-ahead disable */
+	    case 0x42: /* enable Automatic Acoustic Mode */
+	    case 0xc2: /* disable Automatic Acoustic Mode */
+	    case 0x85: /* disable APM */
                 s->status = READY_STAT | SEEK_STAT;
                 ide_set_irq(s);
                 break;
@@ -2174,8 +2177,15 @@ static void ide_ioport_write(void *opaqu
 	    s->status = READY_STAT;
             ide_set_irq(s);
             break;
+        case WIN_IDLEIMMEDIATE:
+        case WIN_STANDBY:
+        case WIN_SETIDLE1:
 	case WIN_STANDBYNOW1:
-        case WIN_IDLEIMMEDIATE:
+        case WIN_SLEEPNOW1:
+        case WIN_STANDBY2:
+        case WIN_SETIDLE2:
+	case WIN_STANDBYNOW2:
+        case WIN_SLEEPNOW2:
 	    s->status = READY_STAT;
             ide_set_irq(s);
             break;

[-- Attachment #3: Type: text/plain, Size: 138 bytes --]

_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xensource.com
http://lists.xensource.com/xen-devel

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [PATCH][QEMU] Allow more IDE power management
  2007-08-27 18:45 [PATCH][QEMU] Allow more IDE power management Ben Guthro
@ 2007-08-27 19:19 ` Daniel P. Berrange
  0 siblings, 0 replies; 2+ messages in thread
From: Daniel P. Berrange @ 2007-08-27 19:19 UTC (permalink / raw)
  To: Ben Guthro; +Cc: Dave Lively, xen-devel

On Mon, Aug 27, 2007 at 02:45:40PM -0400, Ben Guthro wrote:
> Made the QEMU IDE disk tolerate more power-mgmt commands, specifically:
> 	WIN_SETFEATURE(EN_AAM)	- enable automatic acoustic mgmt
> 	WIN_SETFEATURE(DIS_AAM)	- disable automatic acoustic mgmt
> 	WIN_SETFEATURE(DIS_APM)	- disable automatic power mgmt
> 	WIN_STANDBY
> 	WIN_SETIDLE1
> 	WIN_SLEEPNOW1
> 	WIN_STANDBY2
> 	WIN_SETIDLE2
> 	WIN_SLEEPNOW2
> 	WIN_STANDBYNOW2
> These are all essentially no-ops, like existing support for EN_RLA (enable
> read lookahead) and WIN_STANDBYNOW1.
> 
> This fixes a crash in the SLES9-SP3 64bit kernel when the powersaved was
> started (with ACPI or ACM).  This guest really only needs EN_AAM, DIS_APM,
> and WIN_SETIDLE1 support, but the others seemed sensible to include.
> 
> I've excluded EN_APM since I'm unsure of what that's agreeing to do.  It's
> probably ok to include.

This and other QEMU patches should really be sent to upstream QEMU for review
and inclusion first so we don't have to maintain extra patches in Xen forever.

Dan.
-- 
|=- Red Hat, Engineering, Emerging Technologies, Boston.  +1 978 392 2496 -=|
|=-           Perl modules: http://search.cpan.org/~danberr/              -=|
|=-               Projects: http://freshmeat.net/~danielpb/               -=|
|=-  GnuPG: 7D3B9505   F3C9 553F A1DA 4AC2 5648 23C1 B3DF F742 7D3B 9505  -=| 

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2007-08-27 19:19 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-08-27 18:45 [PATCH][QEMU] Allow more IDE power management Ben Guthro
2007-08-27 19:19 ` Daniel P. Berrange

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.