diff options
author | Vitaly Kuznetsov <vkuznets@redhat.com> | 2016-06-03 17:09:22 -0700 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2016-08-31 13:05:40 +0200 |
commit | a9f61ca793becabdefab03b77568d6c6f8c1bc79 (patch) | |
tree | 422f0e2eb47880341e6ebe69a1afa918458c4dd4 /drivers/hv/hyperv_vmbus.h | |
parent | 069b188f43d9a44422eb35a8f95533d2c44ad315 (diff) | |
download | linux-stable-a9f61ca793becabdefab03b77568d6c6f8c1bc79.tar.gz linux-stable-a9f61ca793becabdefab03b77568d6c6f8c1bc79.tar.bz2 linux-stable-a9f61ca793becabdefab03b77568d6c6f8c1bc79.zip |
Drivers: hv: avoid vfree() on crash
When we crash from NMI context (e.g. after NMI injection from host when
'sysctl -w kernel.unknown_nmi_panic=1' is set) we hit
kernel BUG at mm/vmalloc.c:1530!
as vfree() is denied. While the issue could be solved with in_nmi() check
instead I opted for skipping vfree on all sorts of crashes to reduce the
amount of work which can cause consequent crashes. We don't really need to
free anything on crash.
Signed-off-by: Vitaly Kuznetsov <vkuznets@redhat.com>
Signed-off-by: K. Y. Srinivasan <kys@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/hv/hyperv_vmbus.h')
-rw-r--r-- | drivers/hv/hyperv_vmbus.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/hv/hyperv_vmbus.h b/drivers/hv/hyperv_vmbus.h index 718b5c72f0c8..dfa9fac100d8 100644 --- a/drivers/hv/hyperv_vmbus.h +++ b/drivers/hv/hyperv_vmbus.h @@ -495,7 +495,7 @@ struct hv_ring_buffer_debug_info { extern int hv_init(void); -extern void hv_cleanup(void); +extern void hv_cleanup(bool crash); extern int hv_post_message(union hv_connection_id connection_id, enum hv_message_type message_type, |