audk/MdePkg/Library/StackCheckLib/StackCheckLibCommonMsvc.c
Oliver Smith-Denny e63cdeebb8 MdePkg: Add StackCheckLib Library Class
StackCheckLib defines the interface between a compiler
and the stack checking code. It is being converted from
a NULL library class to an actual library class to make
it easier to use for a platform and be easier to define
the expected interface with a compiler, so if there is
a compiler change it can be tracked and caught.

Signed-off-by: Oliver Smith-Denny <osde@microsoft.com>
2025-02-07 02:23:11 +00:00

42 lines
1.1 KiB
C

/** @file
Provides the required functionality for handling stack
cookie check failures for MSVC.
Copyright (c) Microsoft Corporation.
SPDX-License-Identifier: BSD-2-Clause-Patent
**/
#include <Base.h>
#include <Library/DebugLib.h>
#include <Library/BaseLib.h>
#include <Library/StackCheckLib.h>
#include <Library/StackCheckFailureHookLib.h>
/**
Triggers an interrupt using the vector specified by PcdStackCookieExceptionVector
**/
VOID
TriggerStackCookieInterrupt (
VOID
);
VOID *__security_cookie = (VOID *)(UINTN)STACK_COOKIE_VALUE;
/**
This function gets called when an MSVC generated stack cookie fails. This implementation calls into a platform
failure hook lib and then triggers the stack cookie interrupt.
@param[in] ActualCookieValue The value that was written onto the stack, corrupting the stack cookie.
**/
VOID
StackCheckFailure (
VOID *ActualCookieValue
)
{
DEBUG ((DEBUG_ERROR, "Stack cookie check failed at address 0x%llx!\n", RETURN_ADDRESS (0)));
StackCheckFailureHook (RETURN_ADDRESS (0));
TriggerStackCookieInterrupt ();
}