diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-12 09:20:28 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-12 09:20:28 -0400 |
commit | ccff9b1db693062b0a9c9070f4304deb47ef215c (patch) | |
tree | a956cc800a03f11254105fbd9926bab537b6863f /drivers/xen | |
parent | 3dc329baa2ed1740036183041cefaf8ceb714038 (diff) | |
parent | cb6b6df111e46b9d0f79eb971575fd50555f43f4 (diff) |
Merge tag 'stable/for-linus-3.7-rc0-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/xen
Pull Xen fixes from Konrad Rzeszutek Wilk:
"This has four bug-fixes and one tiny feature that I forgot to put
initially in my tree due to oversight.
The feature is for kdump kernels to speed up the /proc/vmcore reading.
There is a ram_is_pfn helper function that the different platforms can
register for. We are now doing that.
The bug-fixes cover some embarrassing struct pv_cpu_ops variables
being set to NULL on Xen (but not baremetal). We had a similar issue
in the past with {write|read}_msr_safe and this fills the three
missing ones. The other bug-fix is to make the console output (hvc)
be capable of dealing with misbehaving backends and not fall flat on
its face. Lastly, a quirk for older XenBus implementations that came
with an ancient v3.4 hypervisor (so RHEL5 based) - reading of certain
non-existent attributes just hangs the guest during bootup - so we
take precaution of not doing that on such older installations.
Feature:
- Register a pfn_is_ram helper to speed up reading of /proc/vmcore.
Bug-fixes:
- Three pvops call for Xen were undefined causing BUG_ONs.
- Add a quirk so that the shutdown watches (used by kdump) are not
used with older Xen (3.4).
- Fix ungraceful state transition for the HVC console."
* tag 'stable/for-linus-3.7-rc0-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/xen:
xen/pv-on-hvm kexec: add quirk for Xen 3.4 and shutdown watches.
xen/bootup: allow {read|write}_cr8 pvops call.
xen/bootup: allow read_tscp call for Xen PV guests.
xen pv-on-hvm: add pfn_is_ram helper for kdump
xen/hvc: handle backend CLOSED without CLOSING
Diffstat (limited to 'drivers/xen')
-rw-r--r-- | drivers/xen/xenbus/xenbus_xs.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/drivers/xen/xenbus/xenbus_xs.c b/drivers/xen/xenbus/xenbus_xs.c index 131dec04794..48220e129f8 100644 --- a/drivers/xen/xenbus/xenbus_xs.c +++ b/drivers/xen/xenbus/xenbus_xs.c | |||
@@ -48,6 +48,7 @@ | |||
48 | #include <xen/xenbus.h> | 48 | #include <xen/xenbus.h> |
49 | #include <xen/xen.h> | 49 | #include <xen/xen.h> |
50 | #include "xenbus_comms.h" | 50 | #include "xenbus_comms.h" |
51 | #include <asm/xen/hypervisor.h> | ||
51 | 52 | ||
52 | struct xs_stored_msg { | 53 | struct xs_stored_msg { |
53 | struct list_head list; | 54 | struct list_head list; |
@@ -618,7 +619,24 @@ static struct xenbus_watch *find_watch(const char *token) | |||
618 | 619 | ||
619 | return NULL; | 620 | return NULL; |
620 | } | 621 | } |
622 | /* | ||
623 | * Certain older XenBus toolstack cannot handle reading values that are | ||
624 | * not populated. Some Xen 3.4 installation are incapable of doing this | ||
625 | * so if we are running on anything older than 4 do not attempt to read | ||
626 | * control/platform-feature-xs_reset_watches. | ||
627 | */ | ||
628 | static bool xen_strict_xenbus_quirk() | ||
629 | { | ||
630 | uint32_t eax, ebx, ecx, edx, base; | ||
631 | |||
632 | base = xen_cpuid_base(); | ||
633 | cpuid(base + 1, &eax, &ebx, &ecx, &edx); | ||
621 | 634 | ||
635 | if ((eax >> 16) < 4) | ||
636 | return true; | ||
637 | return false; | ||
638 | |||
639 | } | ||
622 | static void xs_reset_watches(void) | 640 | static void xs_reset_watches(void) |
623 | { | 641 | { |
624 | int err, supported = 0; | 642 | int err, supported = 0; |
@@ -626,6 +644,9 @@ static void xs_reset_watches(void) | |||
626 | if (!xen_hvm_domain() || xen_initial_domain()) | 644 | if (!xen_hvm_domain() || xen_initial_domain()) |
627 | return; | 645 | return; |
628 | 646 | ||
647 | if (xen_strict_xenbus_quirk()) | ||
648 | return; | ||
649 | |||
629 | err = xenbus_scanf(XBT_NIL, "control", | 650 | err = xenbus_scanf(XBT_NIL, "control", |
630 | "platform-feature-xs_reset_watches", "%d", &supported); | 651 | "platform-feature-xs_reset_watches", "%d", &supported); |
631 | if (err != 1 || !supported) | 652 | if (err != 1 || !supported) |