#include <ntoskrnl.h>
#include <debug.h>
Go to the source code of this file.
◆ NDEBUG
◆ IopBootLog()
Definition at line 53 of file bootlog.c.
55{
58 WCHAR ValueNameBuffer[8];
64
66 return;
67
69
70 DPRINT(
"Boot log: %wS %wZ\n",
71 Success ?
L"Loaded driver" :
L"Did not load driver",
72 DriverName);
73
76 Success ?
L"Loaded driver" :
L"Did not load driver",
77 DriverName);
78
82
84 L"\\Registry\\Machine\\System\\CurrentControlSet");
90 Status = ZwOpenKey(&ControlSetKey,
94 {
97 return;
98 }
99
104 ControlSetKey,
106 Status = ZwCreateKey(&BootLogKey,
109 0,
114 {
118 return;
119 }
120
122 Status = ZwSetValueKey(BootLogKey,
124 0,
130
132 {
134 }
135 else
136 {
138 }
139
141}
static ULONG IopLogEntryCount
static ERESOURCE IopBootLogResource
static BOOLEAN IopBootLogEnabled
IN PUNICODE_STRING IN POBJECT_ATTRIBUTES ObjectAttributes
#define NT_SUCCESS(StatCode)
#define ExAcquireResourceExclusiveLite(res, wait)
_CRTIMP size_t __cdecl wcslen(_In_z_ const wchar_t *_Str)
#define OBJ_CASE_INSENSITIVE
#define InitializeObjectAttributes(p, n, a, r, s)
NTSYSAPI NTSTATUS NTAPI ZwClose(_In_ HANDLE Handle)
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
#define REG_OPTION_NON_VOLATILE
VOID FASTCALL ExReleaseResourceLite(IN PERESOURCE Resource)
_Must_inspect_result_ _In_ WDFDEVICE _In_ PCUNICODE_STRING KeyName
_Must_inspect_result_ _In_ WDFKEY _In_ PCUNICODE_STRING ValueName
◆ IopCreateLogFile()
Definition at line 225 of file bootlog.c.
226{
234
235 DPRINT(
"IopSaveBootLogToFile() called\n");
236
238
240 L"\\SystemRoot\\rosboot.log");
246
252 0,
253 0,
257 0);
259 {
262 }
263
265
277 {
279 }
280
282
284}
#define FILE_NON_DIRECTORY_FILE
static const WCHAR Signature[]
IN PDCB IN PCCB IN VBO IN OUT PULONG OUT PDIRENT OUT PBCB OUT PVBO ByteOffset
struct _FileName FileName
_Must_inspect_result_ _In_opt_ PFLT_INSTANCE _Out_ PHANDLE FileHandle
#define FILE_SYNCHRONOUS_IO_NONALERT
static OUT PIO_STATUS_BLOCK IoStatusBlock
Referenced by IopSaveBootLogToFile().
◆ IopInitBootLog()
Definition at line 29 of file bootlog.c.
30{
33}
VOID IopStartBootLog(VOID)
NTSTATUS ExInitializeResourceLite(PULONG res)
◆ IopSaveBootLogToFile()
Definition at line 288 of file bootlog.c.
289{
291 WCHAR ValueNameBuffer[8];
300
302 return;
303
304 DPRINT(
"IopSaveBootLogToFile() called\n");
305
307
310 {
313 return;
314 }
315
316
317
319 {
322 return;
323 }
324
327 {
330 return;
331 }
332
333
338 {
340 return;
341 }
342
344 L"\\Registry\\Machine\\System\\CurrentControlSet\\BootLog");
354 {
357 return;
358 }
359
361 {
364
366 ValueNameBuffer);
367
371 KeyInfo,
375 {
376 break;
377 }
378
380 {
384 return;
385 }
386
389 {
393 return;
394 }
395
396
399 }
400
402
404
407
408 DPRINT(
"IopSaveBootLogToFile() done\n");
409}
static NTSTATUS IopCreateLogFile(VOID)
static NTSTATUS IopWriteLogFile(PWSTR LogText)
static BOOLEAN IopLogFileEnabled
static BOOLEAN IopBootLogCreate
#define ExAllocatePool(type, size)
NTSYSAPI NTSTATUS NTAPI ZwDeleteValueKey(__in IN HANDLE Key, __in IN PUNICODE_STRING ValueName)
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
_Must_inspect_result_ _Out_ PNDIS_STATUS _In_ NDIS_HANDLE _In_ ULONG _Out_ PNDIS_STRING _Out_ PNDIS_HANDLE KeyHandle
@ KeyValuePartialInformation
struct _KEY_VALUE_PARTIAL_INFORMATION KEY_VALUE_PARTIAL_INFORMATION
#define STATUS_OBJECT_NAME_NOT_FOUND
_Must_inspect_result_ _In_ WDFDEVICE _In_ DEVICE_REGISTRY_PROPERTY _In_ ULONG _Out_ PULONG ResultLength
_In_ WDFMEMORY _Out_opt_ size_t * BufferSize
◆ IopStartBootLog()
◆ IopStopBootLog()
◆ IopWriteLogFile()
Definition at line 146 of file bootlog.c.
147{
154
155 DPRINT(
"IopWriteLogFile() called\n");
156
158 L"\\SystemRoot\\rosboot.log");
164
170 0,
171 0,
175 0);
177 {
180 }
181
183 {
189 LogText,
194 {
198 }
199 }
200
201
211
213
215 {
217 }
218
220}
Referenced by IopSaveBootLogToFile().
◆ IopBootLogCreate
◆ IopBootLogEnabled
◆ IopBootLogResource
◆ IopLogEntryCount
ULONG IopLogEntryCount = 0 |
|
static |
◆ IopLogFileEnabled