summaryrefslogtreecommitdiffstats
path: root/CryptoPkg/Library/MbedTlsLib/MbedTlsLib.inf
diff options
context:
space:
mode:
Diffstat (limited to 'CryptoPkg/Library/MbedTlsLib/MbedTlsLib.inf')
-rw-r--r--CryptoPkg/Library/MbedTlsLib/MbedTlsLib.inf171
1 files changed, 171 insertions, 0 deletions
diff --git a/CryptoPkg/Library/MbedTlsLib/MbedTlsLib.inf b/CryptoPkg/Library/MbedTlsLib/MbedTlsLib.inf
new file mode 100644
index 0000000000..adcf770902
--- /dev/null
+++ b/CryptoPkg/Library/MbedTlsLib/MbedTlsLib.inf
@@ -0,0 +1,171 @@
+## @file
+# library for the MbedTls.
+#
+# Copyright (c) 2023, Intel Corporation. All rights reserved.<BR>
+# SPDX-License-Identifier: BSD-2-Clause-Patent
+#
+##
+
+[Defines]
+ INF_VERSION = 0x00010005
+ BASE_NAME = MbedTlsLib
+ FILE_GUID = BB8E7D92-3E14-4907-A890-B28C7A0A1931
+ MODULE_TYPE = BASE
+ VERSION_STRING = 1.0
+ LIBRARY_CLASS = MbedTlsLib
+
+#
+# The following information is for reference only and not required by the build tools.
+#
+# VALID_ARCHITECTURES = IA32 X64 ARM AARCH64
+#
+
+[Sources]
+ Include/mbedtls/mbedtls_config.h
+ mbedtls/library/aes.c
+ mbedtls/library/asn1parse.c
+ mbedtls/library/asn1write.c
+ mbedtls/library/base64.c
+ mbedtls/library/bignum.c
+ mbedtls/library/ccm.c
+ mbedtls/library/chacha20.c
+ mbedtls/library/chachapoly.c
+ mbedtls/library/cipher.c
+ mbedtls/library/cipher_wrap.c
+ mbedtls/library/cmac.c
+ mbedtls/library/ctr_drbg.c
+ mbedtls/library/debug.c
+ mbedtls/library/des.c
+ mbedtls/library/dhm.c
+ EcSm2Null.c
+ mbedtls/library/error.c
+ mbedtls/library/gcm.c
+ mbedtls/library/hkdf.c
+ mbedtls/library/hmac_drbg.c
+ mbedtls/library/md.c
+ mbedtls/library/md5.c
+ mbedtls/library/ssl_msg.c
+ mbedtls/library/ssl_tls12_client.c
+ mbedtls/library/ssl_tls12_server.c
+ mbedtls/library/ssl_client.c
+ mbedtls/library/ssl_debug_helpers_generated.c
+ mbedtls/library/rsa_alt_helpers.c
+ mbedtls/library/hash_info.c
+ mbedtls/library/bignum_core.c
+ mbedtls/library/constant_time.c
+ mbedtls/library/memory_buffer_alloc.c
+ mbedtls/library/nist_kw.c
+ mbedtls/library/oid.c
+ mbedtls/library/padlock.c
+ mbedtls/library/pem.c
+ mbedtls/library/pk.c
+ mbedtls/library/pkcs12.c
+ mbedtls/library/pkcs5.c
+ mbedtls/library/pkparse.c
+ mbedtls/library/pkwrite.c
+ mbedtls/library/pk_wrap.c
+ mbedtls/library/poly1305.c
+ mbedtls/library/ripemd160.c
+ mbedtls/library/rsa.c
+ mbedtls/library/sha1.c
+ mbedtls/library/sha256.c
+ mbedtls/library/sha512.c
+ mbedtls/library/ssl_cache.c
+ mbedtls/library/ssl_ciphersuites.c
+ mbedtls/library/ssl_cookie.c
+ mbedtls/library/ssl_ticket.c
+ mbedtls/library/ssl_tls.c
+ mbedtls/library/threading.c
+ mbedtls/library/version.c
+ mbedtls/library/version_features.c
+ mbedtls/library/x509.c
+ mbedtls/library/x509write_crt.c
+ mbedtls/library/x509write_csr.c
+ mbedtls/library/x509_create.c
+ mbedtls/library/x509_crl.c
+ mbedtls/library/x509_crt.c
+ mbedtls/library/x509_csr.c
+ mbedtls/library/pkcs7.c
+ mbedtls/library/platform_util.c
+ CrtWrapper.c
+
+[Packages]
+ MdePkg/MdePkg.dec
+ CryptoPkg/CryptoPkg.dec
+
+[LibraryClasses]
+ BaseLib
+ BaseMemoryLib
+ DebugLib
+ MemoryAllocationLib
+
+[BuildOptions]
+ #
+ # Disables the following Visual Studio compiler warnings brought by Mbedtls source,
+ # warning C4244: '=': conversion from 'int' to 'unsigned char', possible loss of data
+ # warning C4132: 'S': const object should be initialized
+ # warning C4245: '=': conversion from 'int' to 'mbedtls_mpi_uint', signed/unsigned mismatch
+ # warning C4310: cast truncates constant value
+ # warning C4204: nonstandard extension used
+ #
+ MSFT:*_*_IA32_CC_FLAGS = /DEFI32 /wd4244 /wd4132 /wd4245 /wd4310 /wd4204
+ MSFT:*_*_X64_CC_FLAGS = /DEFI32 /wd4244 /wd4132 /wd4245 /wd4310 /wd4204
+
+ #
+ # Disable following Visual Studio 2015 compiler warnings brought by mbedtls source,
+ # so we do not break the build with /WX option:
+ # C4718: recursive call has no side effects, deleting
+ #
+ MSFT:*_VS2015x86_IA32_CC_FLAGS = /wd4718
+ MSFT:*_VS2015x86_X64_CC_FLAGS = /wd4718
+
+ INTEL:*_*_IA32_CC_FLAGS = -U_WIN32 -U_WIN64 /w
+ INTEL:*_*_X64_CC_FLAGS = -U_WIN32 -U_WIN64 /w
+
+ #
+ # Suppress the following build warnings in mbedtls so we don't break the build with -Werror
+ # -Werror=maybe-uninitialized: there exist some other paths for which the variable is not initialized.
+ # -Werror=format: Check calls to printf and scanf, etc., to make sure that the arguments supplied have
+ # types appropriate to the format string specified.
+ # -Werror=unused-but-set-variable: Warn whenever a local variable is assigned to, but otherwise unused (aside from its declaration).
+ #
+ GCC:*_*_IA32_CC_FLAGS = -U_WIN32 -U_WIN64 -Wno-error=maybe-uninitialized -Wno-error=unused-but-set-variable
+ GCC:*_*_X64_CC_FLAGS = -U_WIN32 -U_WIN64 -Wno-error=maybe-uninitialized -Wno-error=format -Wno-format -Wno-error=unused-but-set-variable -DNO_MSABI_VA_FUNCS
+ GCC:*_*_ARM_CC_FLAGS = -Wno-error=maybe-uninitialized -Wno-error=unused-but-set-variable
+ GCC:*_*_AARCH64_CC_FLAGS = -Wno-error=maybe-uninitialized -Wno-format -Wno-error=unused-but-set-variable -Wno-error=format
+ GCC:*_*_RISCV64_CC_FLAGS = -Wno-error=maybe-uninitialized -Wno-format -Wno-error=unused-but-set-variable
+ GCC:*_*_LOONGARCH64_CC_FLAGS = -Wno-error=maybe-uninitialized -Wno-format -Wno-error=unused-but-set-variable
+ GCC:*_CLANG35_*_CC_FLAGS = -std=c99 -Wno-error=uninitialized
+ GCC:*_CLANG38_*_CC_FLAGS = -std=c99 -Wno-error=uninitialized
+ GCC:*_CLANGPDB_*_CC_FLAGS = -std=c99 -Wno-error=uninitialized -Wno-error=incompatible-pointer-types -Wno-error=pointer-sign -Wno-error=implicit-function-declaration -Wno-error=ignored-pragma-optimize
+
+ # suppress the following warnings in mbedtls so we don't break the build with warnings-as-errors:
+ # 1295: Deprecated declaration <entity> - give arg types
+ # 550: <entity> was set but never used
+ # 1293: assignment in condition
+ # 111: statement is unreachable (invariably "break;" after "return X;" in case statement)
+ # 68: integer conversion resulted in a change of sign ("if (Status == -1)")
+ # 177: <entity> was declared but never referenced
+ # 223: function <entity> declared implicitly
+ # 144: a value of type <type> cannot be used to initialize an entity of type <type>
+ # 513: a value of type <type> cannot be assigned to an entity of type <type>
+ # 188: enumerated type mixed with another type (i.e. passing an integer as an enum without a cast)
+ # 1296: Extended constant initialiser used
+ # 128: loop is not reachable - may be emitted inappropriately if code follows a conditional return
+ # from the function that evaluates to true at compile time
+ # 546: transfer of control bypasses initialization - may be emitted inappropriately if the uninitialized
+ # variable is never referenced after the jump
+ # 1: ignore "#1-D: last line of file ends without a newline"
+ XCODE:*_*_IA32_CC_FLAGS = -mmmx -msse -U_WIN32 -U_WIN64 -w -std=c99 -Wno-error=uninitialized
+ XCODE:*_*_X64_CC_FLAGS = -mmmx -msse -U_WIN32 -U_WIN64 -w -std=c99 -Wno-error=uninitialized
+
+ #
+ # AARCH64 uses strict alignment and avoids SIMD registers for code that may execute
+ # with the MMU off. This involves SEC, PEI_CORE and PEIM modules as well as BASE
+ # libraries, given that they may be included into such modules.
+ # This library, even though of the BASE type, is never used in such cases, and
+ # avoiding the SIMD register file (which is shared with the FPU) prevents the
+ # compiler from successfully building some of the mbedtls source files that
+ # use floating point types, so clear the flags here.
+ #
+ GCC:*_*_AARCH64_CC_XIPFLAGS ==