From nobody Wed May 8 01:00:05 2024 Delivered-To: importer@patchew.org Received-SPF: pass (zohomail.com: domain of groups.io designates 66.175.222.12 as permitted sender) client-ip=66.175.222.12; envelope-from=bounce+27952+52838+1787277+3901457@groups.io; helo=web01.groups.io; Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of groups.io designates 66.175.222.12 as permitted sender) smtp.mailfrom=bounce+27952+52838+1787277+3901457@groups.io ARC-Seal: i=1; a=rsa-sha256; t=1578071579; cv=none; d=zohomail.com; s=zohoarc; b=IKWG84VuSjr85xJH7WkRk5vtTi1aObVvDfovenGEieEKNOdFMsvGL4kZqX/i0ql4Xl8QCUoJsSDywZz0eEY0O70zgM+/4vqx5TvXmk6/8iqHFLv31qJkWTkPQAuAsQXdrCE/7++r9BjWu1EKBUHaJHTLbYVMi8xCGLaBDGFRmVE= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1578071579; h=Content-Type:Date:From:In-Reply-To:List-Id:List-Unsubscribe:MIME-Version:Message-ID:Reply-To:References:Sender:Subject:To; bh=UIYNTOrOF+8Ih67m2+xW7838294+BpVnQ80b3nKNuss=; b=B9w18HWlcShFwd9Qdp82gEm2HjQ4ow6h2Y3mlWxy8DFRphNdXw221Q311ogCQ6lTyjLQHmULJ1z4h+HbdmhOGMlWESeYIFblfRFq6+Vojr4jkB8Gul4MkY5zB2b0CxvlWG3MmZyN1lPw1SZ3RBDgdQi2mAY0MhUjws83d/iZ9Yw= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of groups.io designates 66.175.222.12 as permitted sender) smtp.mailfrom=bounce+27952+52838+1787277+3901457@groups.io Received: from web01.groups.io (web01.groups.io [66.175.222.12]) by mx.zohomail.com with SMTPS id 1578071579021542.2221765984063; Fri, 3 Jan 2020 09:12:59 -0800 (PST) Return-Path: X-Received: by 127.0.0.2 with SMTP id RNb8YY1788612xFUCsqtg5hU; Fri, 03 Jan 2020 09:12:58 -0800 X-Received: from mail1.protonmail.ch (mail1.protonmail.ch [185.70.40.18]) by mx.groups.io with SMTP id smtpd.web11.6641.1578071577659346985 for ; Fri, 03 Jan 2020 09:12:58 -0800 Date: Fri, 03 Jan 2020 17:12:46 +0000 To: devel@edk2.groups.io From: "Vitaly Cheptsov via Groups.Io" Reply-To: devel@edk2.groups.io,vit9696@protonmail.com Subject: [edk2-devel] [PATCH v3 1/1] MdePkg: Add PCD to disable safe string constraint assertions Message-ID: <20200103171242.63839-2-vit9696@protonmail.com> In-Reply-To: <20200103171242.63839-1-vit9696@protonmail.com> References: <20200103171242.63839-1-vit9696@protonmail.com> Feedback-ID: p9QuX-L1wMgUm6nrSvNrf8juLupNs0VSnzXGVXuYDxlEahFdWtaedWDMB9zpwGDklGt7kzs1-RBc0cqz327Gcg==:Ext:ProtonMail MIME-Version: 1.0 X-Spam-Status: No, score=-0.7 required=7.0 tests=ALL_TRUSTED,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_ENVFROM_END_DIGIT, FREEMAIL_FROM,FREEMAIL_REPLYTO_END_DIGIT shortcircuit=no autolearn=no autolearn_force=no version=3.4.2 X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on mail.protonmail.ch Precedence: Bulk List-Unsubscribe: Sender: devel@edk2.groups.io List-Id: Mailing-List: list devel@edk2.groups.io; contact devel+owner@edk2.groups.io X-Gm-Message-State: UNrNeOdWME2ZhPWpWec9kBVRx1787277AA= Content-Type: multipart/signed; protocol="application/pgp-signature"; micalg=pgp-sha256; boundary="---------------------005debb2e6ddd9795e8e1a9779d7e6ce"; charset=UTF-8 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=groups.io; q=dns/txt; s=20140610; t=1578071578; bh=CObfQgAo2pTig81osLpdTgmdx0cCvHIbIIuhAlFA5Pc=; h=Content-Type:Date:From:Reply-To:Subject:To; b=dweH1H3TBJQU1XZkB6/0Y/VVD4CfzVVo/YT0n2RwS+z4uqHT0AX/P0JCur1b8/Q1l0a +NGLqLukw4Ajqqx2nwMzEuhDw35Sj5F80bDZrJ+sSzFFdDuOmIbZJ8yNA/AzYVn0OheXB QG2eCDIjQM1Tntj7aM1CErzMK9YqijjaMgs= X-Zoho-Virus-Status: 1 X-ZohoMail-DKIM: pass (identity @groups.io) -----------------------005debb2e6ddd9795e8e1a9779d7e6ce Content-Transfer-Encoding: quoted-printable Date: Fri, 3 Jan 2020 20:12:42 +0300 From: Vitaly Cheptsov In-Reply-To: <20200103171242.63839-1-vit9696@protonmail.com> Message-Id: <20200103171242.63839-2-vit9696@protonmail.com> Mime-Version: 1.0 References: <20200103171242.63839-1-vit9696@protonmail.com> Subject: [PATCH v3 1/1] MdePkg: Add PCD to disable safe string constraint assertions To: devel@edk2.groups.io X-Mailer: git-send-email 2.21.0 (Apple Git-122.2) Content-Type: text/plain; charset="utf-8" REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3D2054 Runtime data checks are not meant to cause debug assertions unless explicitly needed by some debug code (thus the PCD) as this breaks debug builds validating data with BaseLib. Signed-off-by: Vitaly Cheptsov --- MdePkg/MdePkg.dec | 6 ++ MdePkg/Library/BaseLib/BaseLib.inf | 11 +-- MdePkg/Include/Library/BaseLib.h | 74 +++++++++++++------- MdePkg/Library/BaseLib/SafeString.c | 4 +- MdePkg/MdePkg.uni | 6 ++ 5 files changed, 71 insertions(+), 30 deletions(-) diff --git a/MdePkg/MdePkg.dec b/MdePkg/MdePkg.dec index d022cc5e3e..0191b7a08b 100644 --- a/MdePkg/MdePkg.dec +++ b/MdePkg/MdePkg.dec @@ -2221,6 +2221,12 @@ [PcdsFixedAtBuild,PcdsPatchableInModule] # @Prompt Memory Address of GuidedExtractHandler Table. gEfiMdePkgTokenSpaceGuid.PcdGuidedExtractHandlerTableAddress|0x1000000|U= INT64|0x30001015 =20 + ## Indicates if safe string constraint violation should assert.

+ # TRUE - Safe string constraint violation causes assertion.
+ # FALSE - Safe string constraint violation does not cause assertion. + # @Prompt Enable safe string constraint violation assertions. + gEfiMdePkgTokenSpaceGuid.PcdAssertOnSafeStringConstraints|TRUE|BOOLEAN|0= x0000002e + [PcdsFixedAtBuild, PcdsPatchableInModule, PcdsDynamic, PcdsDynamicEx] ## This value is used to set the base address of PCI express hierarchy. # @Prompt PCI Express Base Address. diff --git a/MdePkg/Library/BaseLib/BaseLib.inf b/MdePkg/Library/BaseLib/Ba= seLib.inf index 3586beb0ab..bc98bc6134 100644 --- a/MdePkg/Library/BaseLib/BaseLib.inf +++ b/MdePkg/Library/BaseLib/BaseLib.inf @@ -390,11 +390,12 @@ [LibraryClasses] BaseMemoryLib =20 [Pcd] - gEfiMdePkgTokenSpaceGuid.PcdMaximumLinkedListLength ## SOMETIMES_CO= NSUMES - gEfiMdePkgTokenSpaceGuid.PcdMaximumAsciiStringLength ## SOMETIMES_CO= NSUMES - gEfiMdePkgTokenSpaceGuid.PcdMaximumUnicodeStringLength ## SOMETIMES_CO= NSUMES - gEfiMdePkgTokenSpaceGuid.PcdControlFlowEnforcementPropertyMask ## SOME= TIMES_CONSUMES - gEfiMdePkgTokenSpaceGuid.PcdSpeculationBarrierType ## SOMETIMES_CO= NSUMES + gEfiMdePkgTokenSpaceGuid.PcdAssertOnSafeStringConstraints ## SOMET= IMES_CONSUMES + gEfiMdePkgTokenSpaceGuid.PcdMaximumLinkedListLength ## SOMET= IMES_CONSUMES + gEfiMdePkgTokenSpaceGuid.PcdMaximumAsciiStringLength ## SOMET= IMES_CONSUMES + gEfiMdePkgTokenSpaceGuid.PcdMaximumUnicodeStringLength ## SOMET= IMES_CONSUMES + gEfiMdePkgTokenSpaceGuid.PcdControlFlowEnforcementPropertyMask ## SOMET= IMES_CONSUMES + gEfiMdePkgTokenSpaceGuid.PcdSpeculationBarrierType ## SOMET= IMES_CONSUMES =20 [FeaturePcd] gEfiMdePkgTokenSpaceGuid.PcdVerifyNodeInList ## CONSUMES diff --git a/MdePkg/Include/Library/BaseLib.h b/MdePkg/Include/Library/Base= Lib.h index 2a75bc023f..c413ca5f57 100644 --- a/MdePkg/Include/Library/BaseLib.h +++ b/MdePkg/Include/Library/BaseLib.h @@ -189,6 +189,8 @@ StrnSizeS ( =20 If Destination is not aligned on a 16-bit boundary, then ASSERT(). If Source is not aligned on a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -225,6 +227,8 @@ StrCpyS ( =20 If Length > 0 and Destination is not aligned on a 16-bit boundary, then = ASSERT(). If Length > 0 and Source is not aligned on a 16-bit boundary, then ASSER= T(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -263,6 +267,8 @@ StrnCpyS ( =20 If Destination is not aligned on a 16-bit boundary, then ASSERT(). If Source is not aligned on a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -303,6 +309,8 @@ StrCatS ( =20 If Destination is not aligned on a 16-bit boundary, then ASSERT(). If Source is not aligned on a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -350,9 +358,11 @@ StrnCatS ( be ignored. Then, the function stops at the first character that is a no= t a valid decimal character or a Null-terminator, whichever one comes first. =20 + If String is not aligned in a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Data is NULL, then ASSERT(). - If String is not aligned in a 16-bit boundary, then ASSERT(). If PcdMaximumUnicodeStringLength is not zero, and String contains more t= han PcdMaximumUnicodeStringLength Unicode characters, not including the Null-terminator, then ASSERT(). @@ -406,9 +416,11 @@ StrDecimalToUintnS ( be ignored. Then, the function stops at the first character that is a no= t a valid decimal character or a Null-terminator, whichever one comes first. =20 + If String is not aligned in a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Data is NULL, then ASSERT(). - If String is not aligned in a 16-bit boundary, then ASSERT(). If PcdMaximumUnicodeStringLength is not zero, and String contains more t= han PcdMaximumUnicodeStringLength Unicode characters, not including the Null-terminator, then ASSERT(). @@ -467,9 +479,11 @@ StrDecimalToUint64S ( the first character that is a not a valid hexadecimal character or NULL, whichever one comes first. =20 + If String is not aligned in a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Data is NULL, then ASSERT(). - If String is not aligned in a 16-bit boundary, then ASSERT(). If PcdMaximumUnicodeStringLength is not zero, and String contains more t= han PcdMaximumUnicodeStringLength Unicode characters, not including the Null-terminator, then ASSERT(). @@ -528,9 +542,11 @@ StrHexToUintnS ( the first character that is a not a valid hexadecimal character or NULL, whichever one comes first. =20 + If String is not aligned in a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Data is NULL, then ASSERT(). - If String is not aligned in a 16-bit boundary, then ASSERT(). If PcdMaximumUnicodeStringLength is not zero, and String contains more t= han PcdMaximumUnicodeStringLength Unicode characters, not including the Null-terminator, then ASSERT(). @@ -622,6 +638,7 @@ AsciiStrnSizeS ( =20 This function is similar as strcpy_s defined in C11. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -656,6 +673,7 @@ AsciiStrCpyS ( =20 This function is similar as strncpy_s defined in C11. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -692,6 +710,7 @@ AsciiStrnCpyS ( =20 This function is similar as strcat_s defined in C11. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -730,6 +749,7 @@ AsciiStrCatS ( =20 This function is similar as strncat_s defined in C11. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -777,6 +797,7 @@ AsciiStrnCatS ( be ignored. Then, the function stops at the first character that is a no= t a valid decimal character or a Null-terminator, whichever one comes first. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Data is NULL, then ASSERT(). If PcdMaximumAsciiStringLength is not zero, and String contains more than @@ -832,6 +853,7 @@ AsciiStrDecimalToUintnS ( be ignored. Then, the function stops at the first character that is a no= t a valid decimal character or a Null-terminator, whichever one comes first. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Data is NULL, then ASSERT(). If PcdMaximumAsciiStringLength is not zero, and String contains more than @@ -891,6 +913,7 @@ AsciiStrDecimalToUint64S ( character that is a not a valid hexadecimal character or Null-terminator, whichever on comes first. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Data is NULL, then ASSERT(). If PcdMaximumAsciiStringLength is not zero, and String contains more than @@ -950,6 +973,7 @@ AsciiStrHexToUintnS ( character that is a not a valid hexadecimal character or Null-terminator, whichever on comes first. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Data is NULL, then ASSERT(). If PcdMaximumAsciiStringLength is not zero, and String contains more than @@ -1506,12 +1530,11 @@ StrHexToUint64 ( "::" can be used to compress one or more groups of X when X contains onl= y 0. The "::" can only appear once in the String. =20 + If String is not aligned in a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). - If Address is NULL, then ASSERT(). - - If String is not aligned in a 16-bit boundary, then ASSERT(). - If PcdMaximumUnicodeStringLength is not zero, and String contains more t= han PcdMaximumUnicodeStringLength Unicode characters, not including the Null-terminator, then ASSERT(). @@ -1567,12 +1590,11 @@ StrToIpv6Address ( When /P is in the String, the function stops at the first character that= is not a valid decimal digit character after P is converted. =20 + If String is not aligned in a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). - If Address is NULL, then ASSERT(). - - If String is not aligned in a 16-bit boundary, then ASSERT(). - If PcdMaximumUnicodeStringLength is not zero, and String contains more t= han PcdMaximumUnicodeStringLength Unicode characters, not including the Null-terminator, then ASSERT(). @@ -1640,9 +1662,11 @@ StrToIpv4Address ( oo Data4[48:55] pp Data4[56:63] =20 + If String is not aligned in a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Guid is NULL, then ASSERT(). - If String is not aligned in a 16-bit boundary, then ASSERT(). =20 @param String Pointer to a Null-terminated Unicode st= ring. @param Guid Pointer to the converted GUID. @@ -1676,15 +1700,12 @@ StrToGuid ( =20 If String is not aligned in a 16-bit boundary, then ASSERT(). =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). - If Buffer is NULL, then ASSERT(). - If Length is not multiple of 2, then ASSERT(). - If PcdMaximumUnicodeStringLength is not zero and Length is greater than PcdMaximumUnicodeStringLength, then ASSERT(). - If MaxBufferSize is less than (Length / 2), then ASSERT(). =20 @param String Pointer to a Null-terminated Unicode st= ring. @@ -1775,8 +1796,9 @@ UnicodeStrToAsciiStr ( =20 If any Unicode characters in Source contain non-zero value in the upper 8 bits, then ASSERT(). - If Source is not aligned on a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -1824,6 +1846,8 @@ UnicodeStrToAsciiStrS ( If any Unicode characters in Source contain non-zero value in the upper 8 bits, then ASSERT(). If Source is not aligned on a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -2388,8 +2412,8 @@ AsciiStrHexToUint64 ( "::" can be used to compress one or more groups of X when X contains onl= y 0. The "::" can only appear once in the String. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). - If Address is NULL, then ASSERT(). =20 If EndPointer is not NULL and Address is translated from String, a point= er @@ -2443,8 +2467,8 @@ AsciiStrToIpv6Address ( When /P is in the String, the function stops at the first character that= is not a valid decimal digit character after P is converted. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). - If Address is NULL, then ASSERT(). =20 If EndPointer is not NULL and Address is translated from String, a point= er @@ -2508,6 +2532,7 @@ AsciiStrToIpv4Address ( oo Data4[48:55] pp Data4[56:63] =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). If Guid is NULL, then ASSERT(). =20 @@ -2541,15 +2566,12 @@ AsciiStrToGuid ( decoding stops after Length of characters and outputs Buffer containing (Length / 2) bytes. =20 + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If String is NULL, then ASSERT(). - If Buffer is NULL, then ASSERT(). - If Length is not multiple of 2, then ASSERT(). - If PcdMaximumAsciiStringLength is not zero and Length is greater than PcdMaximumAsciiStringLength, then ASSERT(). - If MaxBufferSize is less than (Length / 2), then ASSERT(). =20 @param String Pointer to a Null-terminated ASCII stri= ng. @@ -2632,6 +2654,8 @@ AsciiStrToUnicodeStr ( equal or greater than ((AsciiStrLen (Source) + 1) * sizeof (CHAR16)) in = bytes. =20 If Destination is not aligned on a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then the Destination is unmodified. @@ -2678,6 +2702,8 @@ AsciiStrToUnicodeStrS ( ((MIN(AsciiStrLen(Source), Length) + 1) * sizeof (CHAR8)) in bytes. =20 If Destination is not aligned on a 16-bit boundary, then ASSERT(). + + Unless PcdAssertOnSafeStringConstraints is set to FALSE: If an error would be returned, then the function will also ASSERT(). =20 If an error is returned, then Destination and DestinationLength are diff --git a/MdePkg/Library/BaseLib/SafeString.c b/MdePkg/Library/BaseLib/S= afeString.c index 7dc03d2caa..56b5e34a8d 100644 --- a/MdePkg/Library/BaseLib/SafeString.c +++ b/MdePkg/Library/BaseLib/SafeString.c @@ -14,7 +14,9 @@ =20 #define SAFE_STRING_CONSTRAINT_CHECK(Expression, Status) \ do { \ - ASSERT (Expression); \ + if (PcdGetBool (PcdAssertOnSafeStringConstraints)) { \ + ASSERT (Expression); \ + } \ if (!(Expression)) { \ return Status; \ } \ diff --git a/MdePkg/MdePkg.uni b/MdePkg/MdePkg.uni index 5c1fa24065..425b66bb43 100644 --- a/MdePkg/MdePkg.uni +++ b/MdePkg/MdePkg.uni @@ -287,6 +287,12 @@ =20 #string STR_gEfiMdePkgTokenSpaceGuid_PcdGuidedExtractHandlerTableAddress_H= ELP #language en-US "This value is used to set the available memory addres= s to store Guided Extract Handlers. The required memory space is decided by= the value of PcdMaximumGuidedExtractHandler." =20 +#string STR_gEfiMdePkgTokenSpaceGuid_PcdAssertOnSafeStringConstraints_PROM= PT #language en-US "Enable safe string constraint violation assertions" + +#string STR_gEfiMdePkgTokenSpaceGuid_PcdAssertOnSafeStringConstraints_HELP= #language en-US "Indicates if safe string constraint violation should ass= ert.

\n" + = "TRUE - Safe string constraint violation causes assertion.
\n" + = "FALSE - Safe string constraint violation does not cause assertion= .
" + #string STR_gEfiMdePkgTokenSpaceGuid_PcdPciExpressBaseAddress_PROMPT #lan= guage en-US "PCI Express Base Address" =20 #string STR_gEfiMdePkgTokenSpaceGuid_PcdPciExpressBaseAddress_HELP #langu= age en-US "This value is used to set the base address of PCI express hierar= chy." --=20 2.21.0 (Apple Git-122.2) -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D- Groups.io Links: You receive all messages sent to this group. View/Reply Online (#52838): https://edk2.groups.io/g/devel/message/52838 Mute This Topic: https://groups.io/mt/69401949/1787277 Group Owner: devel+owner@edk2.groups.io Unsubscribe: https://edk2.groups.io/g/devel/unsub [importer@patchew.org] -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D- -----------------------005debb2e6ddd9795e8e1a9779d7e6ce Content-Type: application/pgp-signature; name="signature.asc" Content-Description: OpenPGP digital signature Content-Disposition: attachment; filename="signature.asc" -----BEGIN PGP SIGNATURE----- Version: ProtonMail wsBmBAEBCAAQBQJeD3YOCRBPsoxt7Hy0xQAKCRBPsoxt7Hy0xZSdB/wITiAl u1UHAgv+ax87slT9SDrlDcRnajWw6CaM4NkMZZaFaqwmhlEOFf7u5ocEKU+l 2hbhGf+hsr7Jw1e8TVMXaLBNzRZZp5npopNQtYb4yxTPRfCn77MYlaNM8tFa XrECCthXzz4GgP03JjbenPqazOALo9qc9qMOFqvk0A07julxBo9feCvhubO9 lvHWoR/kOt2t0K/gpkAjksyzFwMNkokuJGVHQE3iFBPFEU8RLiMaKMpbkA2F vCprZ1PM1JBaRR1uhWPbrl2A0qjdJOZ6p3EPEczOXJUhD+/o9V8ayYS8+O90 vTy/QzGRDXdb7I/hsXYNvnJLiQcfx7vtvcSU =XVGJ -----END PGP SIGNATURE----- -----------------------005debb2e6ddd9795e8e1a9779d7e6ce--