Skip to content

Commit

Permalink
Merge branch 'release/202302' into personal/apop5/advancedloggerpeicore
Browse files Browse the repository at this point in the history
  • Loading branch information
apop5 authored Dec 15, 2023
2 parents a9f36f0 + 298478f commit 4cb83c1
Show file tree
Hide file tree
Showing 49 changed files with 10,604 additions and 96 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/codeql.yml
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ jobs:
uses: actions/checkout@v4

- name: Install Python
uses: actions/setup-python@v4
uses: actions/setup-python@v5
with:
python-version: '3.12'

Expand Down Expand Up @@ -92,7 +92,7 @@ jobs:
uses: actions/checkout@v4

- name: Install Python
uses: actions/setup-python@v4
uses: actions/setup-python@v5
with:
python-version: '3.12'
cache: 'pip'
Expand Down
2 changes: 1 addition & 1 deletion AdvLoggerPkg/AdvLoggerPkg.ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
"MdeModulePkg/MdeModulePkg.dec",
"AdvLoggerPkg/AdvLoggerPkg.dec",
"MsWheaPkg/MsWheaPkg.dec",
"UnitTestFrameworkPkg/UnitTestFrameworkPkg.dec",
"PolicyServicePkg/PolicyServicePkg.dec",
"ShellPkg/ShellPkg.dec"
],
"AcceptableDependencies-HOST_APPLICATION":[ # for host based unit tests
Expand Down
3 changes: 3 additions & 0 deletions AdvLoggerPkg/AdvLoggerPkg.dec
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,9 @@
#
gAdvancedFileLoggerWriteLogFiles = { 0xc60e894d, 0x29a4, 0x4e0b, {0xb7, 0x44, 0x77, 0x84, 0x22, 0x6e, 0x81, 0x80 }}

## GUID for Advanced file logger policy data
#
gAdvancedFileLoggerPolicyGuid = { 0x6c3fd4f1, 0xb596, 0x438e, { 0x8a, 0xb8, 0x53, 0xf1, 0xc, 0x9c, 0x27, 0x74 } }

[Ppis]
## Advanced Logger Ppi - Communication from PEIM to PEI_CORE library implementation
Expand Down
3 changes: 3 additions & 0 deletions AdvLoggerPkg/AdvLoggerPkg.dsc
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,9 @@

[LibraryClasses.common.DXE_CORE]

[LibraryClasses.common.DXE_DRIVER]
PolicyLib|PolicyServicePkg/Library/DxePolicyLib/DxePolicyLib.inf

[LibraryClasses.common.DXE_SMM_DRIVER]
AdvancedLoggerLib|AdvLoggerPkg/Library/AdvancedLoggerLib/Smm/AdvancedLoggerLib.inf
SmmServicesTableLib|MdePkg/Library/SmmServicesTableLib/SmmServicesTableLib.inf
Expand Down
55 changes: 35 additions & 20 deletions AdvLoggerPkg/AdvancedFileLogger/AdvancedFileLogger.c
Original file line number Diff line number Diff line change
Expand Up @@ -142,17 +142,17 @@ OnResetNotificationProtocolInstalled (
//
// Register our reset notification request
//
DEBUG ((DEBUG_INFO, "%a: Located Reset notification protocol. Registering handler\n", __FUNCTION__));
DEBUG ((DEBUG_INFO, "%a: Located Reset notification protocol. Registering handler\n", __func__));
Status = ResetNotificationProtocol->RegisterResetNotify (ResetNotificationProtocol, OnResetNotification);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a: failed to register Reset Notification handler (%r)\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a: failed to register Reset Notification handler (%r)\n", __func__, Status));
}

if (Event != NULL) {
gBS->CloseEvent (Event);
}
} else {
DEBUG ((DEBUG_ERROR, "%a: Unable to locate Reset Notification Protocol.\n", __FUNCTION__));
DEBUG ((DEBUG_ERROR, "%a: Unable to locate Reset Notification Protocol.\n", __func__));
}

return;
Expand Down Expand Up @@ -183,7 +183,7 @@ RegisterLogDevice (
LogDevice = (LOG_DEVICE *)AllocateZeroPool (sizeof (LOG_DEVICE));
ASSERT (LogDevice);
if (NULL == LogDevice) {
DEBUG ((DEBUG_ERROR, "%a: Out of memory:\n", __FUNCTION__));
DEBUG ((DEBUG_ERROR, "%a: Out of memory:\n", __func__));
return;
}

Expand Down Expand Up @@ -233,7 +233,7 @@ OnFileSystemNotification (
EFI_HANDLE *HandleBuffer;
EFI_STATUS Status;

DEBUG ((DEBUG_INFO, "%a: Entry...\n", __FUNCTION__));
DEBUG ((DEBUG_INFO, "%a: Entry...\n", __func__));

for ( ; ;) {
//
Expand All @@ -256,7 +256,7 @@ OnFileSystemNotification (
// Spec says we only get one at a time using ByRegisterNotify
ASSERT (HandleCount == 1);

DEBUG ((DEBUG_INFO, "%a: processing a potential log device on handle %p\n", __FUNCTION__, HandleBuffer[0]));
DEBUG ((DEBUG_INFO, "%a: processing a potential log device on handle %p\n", __func__, HandleBuffer[0]));

RegisterLogDevice (HandleBuffer[0]);

Expand Down Expand Up @@ -363,7 +363,7 @@ ProcessFileSystemRegistration (
);

if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a: failed to create callback event (%r)\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a: failed to create callback event (%r)\n", __func__, Status));
goto Cleanup;
}

Expand All @@ -374,7 +374,7 @@ ProcessFileSystemRegistration (
);

if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a: failed to register for file system notifications (%r)\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a: failed to register for file system notifications (%r)\n", __func__, Status));
gBS->CloseEvent (FileSystemCallBackEvent);
goto Cleanup;
}
Expand Down Expand Up @@ -424,13 +424,13 @@ ProcessResetEventRegistration (
//
// Register our reset notification request
//
DEBUG ((DEBUG_INFO, "%a: Located Reset notification protocol. Registering handler\n", __FUNCTION__));
DEBUG ((DEBUG_INFO, "%a: Located Reset notification protocol. Registering handler\n", __func__));
Status = ResetNotificationProtocol->RegisterResetNotify (ResetNotificationProtocol, OnResetNotification);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a: failed to register Reset Notification handler (%r)\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a: failed to register Reset Notification handler (%r)\n", __func__, Status));
}
} else {
DEBUG ((DEBUG_INFO, "%a: Reset Notification protocol not installed. Registering for notification\n", __FUNCTION__));
DEBUG ((DEBUG_INFO, "%a: Reset Notification protocol not installed. Registering for notification\n", __func__));
Status = gBS->CreateEvent (
EVT_NOTIFY_SIGNAL,
TPL_CALLBACK,
Expand All @@ -440,7 +440,7 @@ ProcessResetEventRegistration (
);

if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a: failed to create Reset Protocol protocol callback event (%r)\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a: failed to create Reset Protocol protocol callback event (%r)\n", __func__, Status));
} else {
Status = gBS->RegisterProtocolNotify (
&gEdkiiPlatformSpecificResetFilterProtocolGuid,
Expand All @@ -449,7 +449,7 @@ ProcessResetEventRegistration (
);

if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a: failed to register for Reset Protocol notification (%r)\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a: failed to register for Reset Protocol notification (%r)\n", __func__, Status));
gBS->CloseEvent (ResetNotificationEvent);
}
}
Expand Down Expand Up @@ -491,7 +491,7 @@ ProcessSyncRequestRegistration (
);

if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a - Create Event Ex for file logger write. Code = %r\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a - Create Event Ex for file logger write. Code = %r\n", __func__, Status));
}

return Status;
Expand Down Expand Up @@ -534,7 +534,7 @@ ProcessReadyToBootRegistration (
);

if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a - Create Event Ex for ReadyToBoot. Code = %r\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a - Create Event Ex for ReadyToBoot. Code = %r\n", __func__, Status));
}
}

Expand Down Expand Up @@ -577,7 +577,7 @@ ProcessPreExitBootServicesRegistration (
);

if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a - Create Event Ex for ExitBootServices. Code = %r\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a - Create Event Ex for ExitBootServices. Code = %r\n", __func__, Status));
}
}

Expand All @@ -601,9 +601,24 @@ AdvancedFileLoggerEntry (
IN EFI_SYSTEM_TABLE *SystemTable
)
{
EFI_STATUS Status;
EFI_STATUS Status;
ADVANCED_FILE_LOGGER_POLICY AdvFileLoggerPolicy;
UINT16 PolicySize = ADVANCED_FILE_LOGGER_POLICY_SIZE;

DEBUG ((DEBUG_INFO, "%a: enter...\n", __func__));

// Step 0. Check advanced file logger policy, default to enabled.

DEBUG ((DEBUG_INFO, "%a: enter...\n", __FUNCTION__));
Status = GetPolicy (&gAdvancedFileLoggerPolicyGuid, NULL, (VOID *)&AdvFileLoggerPolicy, &PolicySize);
if (EFI_ERROR (Status)) {
// If we fail to get policy, default to enabled.
DEBUG ((DEBUG_WARN, "%a: Unable to get file logger - %r defaulting to enabled!\n", __func__, Status));
} else if (AdvFileLoggerPolicy.FileLoggerEnable == FALSE) {
DEBUG ((DEBUG_INFO, "%a: File logger disabled in policy, exiting.\n", __func__));
return EFI_SUCCESS;
} else {
DEBUG ((DEBUG_INFO, "%a: File logger enabled in policy.\n", __func__));
}

//
// Step 1. Register for file system notifications
Expand Down Expand Up @@ -645,9 +660,9 @@ AdvancedFileLoggerEntry (
Exit:

if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "%a: Leaving, code = %r\n", __FUNCTION__, Status));
DEBUG ((DEBUG_ERROR, "%a: Leaving, code = %r\n", __func__, Status));
} else {
DEBUG ((DEBUG_INFO, "%a: Leaving, code = %r\n", __FUNCTION__, Status));
DEBUG ((DEBUG_INFO, "%a: Leaving, code = %r\n", __func__, Status));
}

// Always return EFI_SUCCESS. This means any partial registration of functions
Expand Down
2 changes: 2 additions & 0 deletions AdvLoggerPkg/AdvancedFileLogger/AdvancedFileLogger.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
#include <AdvancedLoggerInternal.h>

#include <Guid/EventGroup.h>
#include <Guid/AdvancedFileLoggerPolicy.h>

#include <Protocol/AdvancedLogger.h>
#include <Protocol/DevicePath.h>
Expand All @@ -34,6 +35,7 @@
#include <Library/TimerLib.h>
#include <Library/UefiBootServicesTableLib.h>
#include <Library/UefiRuntimeServicesTableLib.h>
#include <Library/PolicyLib.h>

#define LOG_DEVICE_SIGNATURE SIGNATURE_32('D','L','o','g')

Expand Down
3 changes: 3 additions & 0 deletions AdvLoggerPkg/AdvancedFileLogger/AdvancedFileLogger.inf
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
MdePkg/MdePkg.dec
MdeModulePkg/MdeModulePkg.dec
AdvLoggerPkg/AdvLoggerPkg.dec
PolicyServicePkg/PolicyServicePkg.dec

[LibraryClasses]
AdvancedLoggerAccessLib
Expand All @@ -46,11 +47,13 @@
TimerLib
UefiDriverEntryPoint
UefiRuntimeServicesTableLib
PolicyLib

[Guids]
gAdvancedFileLoggerWriteLogFiles
gEfiEventReadyToBootGuid
gMuEventPreExitBootServicesGuid
gAdvancedFileLoggerPolicyGuid

[Protocols]
gEdkiiPlatformSpecificResetFilterProtocolGuid ## CONSUMES
Expand Down
59 changes: 58 additions & 1 deletion AdvLoggerPkg/AdvancedFileLogger/ReadMe.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ The Advanced File Logger monitors for file systems mounted during boot.
When an eligible file system is detected, the log is flushed to the file system.
The log is flushed if the system is reset during POST, and at Exit Boot Services.

An eligible file system is one with a Logs directory in the root of the file system.
An eligible file system is one with a `UefiLogs` directory in the root of the file system.
If no log files are present, the Advanced File Logger will create a log index file which
contains the index of the last log file written, and nine log files each PcdAdvancedLoggerPages in size.
These files are pre allocated at one time to reduce interference with other users of the filesystem.
Expand All @@ -25,6 +25,63 @@ and the follow change is needed in the .fdf:
INF AdvLoggerPkg/AdvancedFileLogger/AdvancedFileLogger.inf
```

## Driver Usage Configuration

This section describes the configuration options of the Advanced File Logger driver.

### Advanced file logger enforcement

The Advanced File Logger can be configured to enforce the storing of memory logs when setting
`PcdAdvancedFileLoggerForceEnable` to `TRUE`.

### Advanced file logger enlightenment

The Advanced File Logger can be set to store memory logs with a `UefiLogs` directory in the ESP partition.
Without such a directory **AND** the enforcement is not enabled, the Advanced File Logger will not store
memory logs.

### Advanced file logger enablement through Policy

The Advanced File Logger can be configured to be enabled through policy service by producing a policy under[`gAdvancedFileLoggerPolicyGuid`](../Include/Guid/AdvancedFileLoggerPolicy.h)
and setting the `FileLoggerEnable` field to `TRUE`. For the sake of backwards compatibility, if a platform does not
produce such policy or not support policy services at all, the Advanced File Logger will default to be enabled.

Note: The above enablement, enforcement and enlightenment are in serial, the general pseudo code is as follows:

```c
if (PolicyNotFound) {
Enabled = TRUE;
} else {
Enabled = Policy.FileLoggerEnable;
}

if (Enable) {
if (PcdGet (PcdAdvancedFileLoggerForceEnable)) {
StoreLogs = TRUE;
} else if (DirectoryExists (L"UefiLogs")) {
StoreLogs = TRUE;
} else {
StoreLogs = FALSE;
}
}

if (StoreLogs) {
// Store logs
// The UEFI_Index.txt file will indicate the last log file written
StoreLogs ("UefiLogs/Log#.txt");
}
```
### Advanced file logger Flush events
The advanced file logger can be flushed or configured to flush on the following events:
| Event | Description |
| --- | --- |
| `gEfiEventReadyToBootGuid` | By setting `BIT0` of `PcdAdvancedFileLoggerFlush`, logger will flushed to ESP at "Ready To Boot" event |
| `gEfiEventExitBootServicesGuid` | By setting `BIT1` of `PcdAdvancedFileLoggerFlush`, logger will flushed to ESP at "Exit Boot Services" event |
| System Reset | This will always be enabled as long as the system supports `gEdkiiPlatformSpecificResetFilterProtocolGuid` |
---
## Copyright
Expand Down
6 changes: 2 additions & 4 deletions AdvLoggerPkg/Crates/RustAdvancedLoggerDxe/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@
//!
#![no_std]

#[cfg(doc)]
#[cfg(any(doc, feature = "std"))]
extern crate std; //allow rustdoc links to reference std (e.g. println docs below).

use core::{
Expand Down Expand Up @@ -173,8 +173,6 @@ mod no_std_debug {

#[cfg(feature = "std")]
mod std_debug {
extern crate std;

/// Prints to the console log.
///
/// This macro uses the same syntax as rust std [`std::println!`] macro, with the addition of a level argument that
Expand Down Expand Up @@ -203,7 +201,7 @@ mod std_debug {
macro_rules! debug {
($level:expr, $($arg:tt)*) => {
let _ = $level;
print!($($arg)*)
std::print!($($arg)*)
}
}
}
Expand Down
29 changes: 29 additions & 0 deletions AdvLoggerPkg/Include/Guid/AdvancedFileLoggerPolicy.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
/** @file
This file defines GUIDs and data structure used for Advanced file logger policy.
Copyright (C) Microsoft Corporation.
SPDX-License-Identifier: BSD-2-Clause-Patent
**/

#ifndef ADVANCED_FILE_LOGGER_POLICY_H_
#define ADVANCED_FILE_LOGGER_POLICY_H_

#define ADVANCED_FILE_LOGGER_POLICY_GUID \
{ \
0x6c3fd4f1, 0xb596, 0x438e, { 0x8a, 0xb8, 0x53, 0xf1, 0xc, 0x9c, 0x27, 0x74 } \
}

#define ADVANCED_FILE_LOGGER_POLICY_SIZE sizeof(ADVANCED_FILE_LOGGER_POLICY)

#pragma pack(1)

typedef struct {
BOOLEAN FileLoggerEnable;
} ADVANCED_FILE_LOGGER_POLICY;

#pragma pack()

extern EFI_GUID gAdvancedFileLoggerPolicyGuid;

#endif //ADVANCED_FILE_LOGGER_POLICY_H_
Loading

0 comments on commit 4cb83c1

Please sign in to comment.