VirtualBox

source: vbox/trunk/src/VBox/Additions/WINNT/VBoxGuest/HelperBugCheck.cpp@ 26163

Last change on this file since 26163 was 26163, checked in by vboxsync, 15 years ago

PDM: s/pUsbReg/pReg/g (2nd try, backed out r57176)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.4 KB
Line 
1/** @file
2 * VBoxGuest -- VirtualBox Win32 guest support driver
3 */
4
5/*
6 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
17 * Clara, CA 95054 USA or visit http://www.sun.com if you need
18 * additional information or have any questions.
19 */
20
21#ifdef VBOX_WITH_GUEST_BUGCHECK_DETECTION
22/*******************************************************************************
23* Header Files *
24*******************************************************************************/
25#include "VBoxGuest_Internal.h"
26#include "Helper.h"
27#include <VBox/err.h>
28#include <VBox/log.h>
29#include <VBox/VBoxGuestLib.h>
30
31#ifndef TARGET_NT4
32# include <aux_klib.h>
33#endif
34
35
36/**
37 * Called when a bug check occurs.
38 *
39 * @param pvBuffer Pointer to our device extension, just in case it
40 * comes in handy some day.
41 * @param cbBuffer The size of our device extension.
42 */
43static VOID hlpVBoxGuestBugCheckCallback(PVOID pvBuffer, ULONG cbBuffer)
44{
45 /*PVBOXGUESTDEVEXT pDevExt = (PVBOXGUESTDEVEXT)pvBuffer;*/
46
47 LogRelBackdoor(("Windows bug check (bluescreen) detected!\n"));
48
49# ifndef TARGET_NT4
50 /*
51 * Try get details.
52 */
53 KBUGCHECK_DATA bugCheckData;
54 bugCheckData.BugCheckDataSize = sizeof(KBUGCHECK_DATA);
55 NTSTATUS rc = AuxKlibGetBugCheckData(&bugCheckData);
56 if (NT_SUCCESS(rc))
57 {
58 LogRelBackdoor(("Bug check code: 0x%08x\n", bugCheckData.BugCheckCode));
59 LogRelBackdoor(("Bug check parameters: 1=0x%p 2=0x%p 3=0x%p 4=0x%p\n",
60 bugCheckData.Parameter1,
61 bugCheckData.Parameter2,
62 bugCheckData.Parameter3,
63 bugCheckData.Parameter4));
64 LogRelBackdoor(("For details run \"!analyze -show %x %p %p %p %p\" in WinDbg.\n",
65 bugCheckData.BugCheckCode,
66 bugCheckData.Parameter1,
67 bugCheckData.Parameter2,
68 bugCheckData.Parameter3,
69 bugCheckData.Parameter4));
70 }
71 else
72 LogRelBackdoor(("Unable to retrieve bugcheck details! Error: %#x\n", rc));
73# else /* NT4 */
74 LogRelBackdoor(("No additional information for Windows NT 4.0 bugcheck available.\n"));
75# endif /* NT4 */
76
77 /*
78 * Notify the host that we've panicked.
79 */
80 /** @todo Notify the host somehow over DevVMM. */
81
82 NOREF(pvBuffer); NOREF(cbBuffer);
83}
84
85void hlpRegisterBugCheckCallback(PVBOXGUESTDEVEXT pDevExt)
86{
87 pDevExt->bBugcheckCallbackRegistered = FALSE;
88
89# ifndef TARGET_NT4
90 /*
91 * This is required for calling AuxKlibGetBugCheckData() in hlpVBoxGuestBugCheckCallback().
92 */
93 NTSTATUS rc = AuxKlibInitialize();
94 if (NT_ERROR(rc))
95 {
96 LogRelBackdoor(("VBoxGuest: Failed to initialize AuxKlib! rc=%#x\n", rc));
97 return;
98 }
99# endif
100
101 /*
102 * Setup bugcheck callback routine.
103 */
104 pDevExt->bBugcheckCallbackRegistered = FALSE;
105 KeInitializeCallbackRecord(&pDevExt->bugcheckRecord);
106 if (KeRegisterBugCheckCallback(&pDevExt->bugcheckRecord,
107 &hlpVBoxGuestBugCheckCallback,
108 pDevExt,
109 sizeof(*pDevExt),
110 (PUCHAR)"VBoxGuest"))
111 {
112 pDevExt->bBugcheckCallbackRegistered = TRUE;
113 dprintf(("VBoxGuest::hlpRegisterBugCheckCallback: Bugcheck callback registered.\n"));
114 }
115 else
116 LogRelBackdoor(("VBoxGuest: Could not register bugcheck callback routine!\n"));
117}
118
119void hlpDeregisterBugCheckCallback(PVBOXGUESTDEVEXT pDevExt)
120{
121 if (pDevExt->bBugcheckCallbackRegistered)
122 {
123 if (!KeDeregisterBugCheckCallback(&pDevExt->bugcheckRecord))
124 dprintf(("VBoxGuest::VBoxGuestUnload: Unregistering bugcheck callback routine failed!\n"));
125 pDevExt->bBugcheckCallbackRegistered = FALSE;
126 }
127}
128
129#endif /* VBOX_WITH_GUEST_BUGCHECK_DETECTION */
130
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette