Merge pull request #22 from pbatard/master

Fix exception on ARM32 with VS2022 when Print() is invoked
This commit is contained in:
Nigel Croxon 2024-05-14 16:20:26 -04:00 committed by GitHub
commit e1024aba22
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 36 additions and 22 deletions

View File

@ -1,6 +1,6 @@
/*++
Copyright (c) 2016 Pete Batard <pete@akeo.ie>
Copyright (c) 2016-2024 Pete Batard <pete@akeo.ie>
Module Name:
@ -12,49 +12,58 @@ Abstract:
--*/
#ifdef _MSC_EXTENSIONS
#define EFI_UNUSED
#else
#if defined(__GNUC__)
#define EFI_UNUSED __attribute__((__unused__))
#else
#define EFI_UNUSED
#endif
#ifdef _MSC_EXTENSIONS
#define EFI_NO_TAIL_CALL
#else
#ifdef __clang__
#if defined(__clang__)
#define EFI_NO_TAIL_CALL __attribute__((disable_tail_calls))
#else
#elif defined(__GNUC__)
#define EFI_NO_TAIL_CALL __attribute__((optimize("no-optimize-sibling-calls")))
#endif
#else
#define EFI_NO_TAIL_CALL
#endif
#ifdef _MSC_EXTENSIONS
#define EFI_OPTNONE
#else
#ifdef __clang__
#if defined(__clang__)
#define EFI_OPTNONE __attribute__((optnone))
#else
#elif defined(__GNUC__)
#define EFI_OPTNONE __attribute__((__optimize__("0")))
#endif
#else
#define EFI_OPTNONE
#endif
#ifdef _MSC_EXTENSIONS
#if defined(__GNUC__)
#define EFI_ALIGN(x) __attribute__((__aligned__(x)))
#elif defined(_MSC_VER)
#define EFI_ALIGN(x) __declspec(align(x))
#else
#define EFI_ALIGN(x) __attribute__((__aligned__(x)))
// Not being able to align is likely to break executables, so report it
#error "No alignement directive is defined for this platform"
#endif
#ifndef ALIGN
#if !defined(ALIGN)
#define ALIGN(x) EFI_ALIGN(x)
#endif
#ifdef _MSC_EXTENSIONS
#if defined(__GNUC__)
#define EFI_NORETURN __attribute__((noreturn))
#elif defined(_MSC_VER)
#define EFI_NORETURN __declspec(noreturn)
#else
#define EFI_NORETURN __attribute__((noreturn))
#define EFI_NORETURN
#endif
#if defined(__GNUC__)
#define EFI_NOINLINE __attribute__((noinline))
#elif defined(_MSC_VER)
#define EFI_NOINLINE __declspec(noinline)
#else
#define EFI_NOINLINE
#endif
/* Also add a catch-all on __attribute__() for MS compilers */
#ifdef _MSC_EXTENSIONS
#if defined(_MSC_VER)
#define __attribute__(x)
#endif

View File

@ -1403,6 +1403,11 @@ ValueToString (
*p2 = 0;
}
// Having this call inlined by VS2022 on Release builds produces an
// "Undefined OpCode Exception" on ARM32 whenever Print() is invoked,
// even when no part of the code below is actually being executed...
// For safety, add an explicit clause to prevent inlining on all platforms.
EFI_NOINLINE
VOID
FloatToString (
IN CHAR16 *Buffer,