mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2025-01-09 23:55:35 +00:00
Merge remote-tracking branch 'public/pr/1465' into mbedtls-2.1
This commit is contained in:
commit
a5fb40d9f9
|
@ -18,6 +18,30 @@ set(CMAKE_BUILD_TYPE ${CMAKE_BUILD_TYPE}
|
||||||
CACHE STRING "Choose the type of build: None Debug Release Coverage ASan ASanDbg MemSan MemSanDbg Check CheckFull"
|
CACHE STRING "Choose the type of build: None Debug Release Coverage ASan ASanDbg MemSan MemSanDbg Check CheckFull"
|
||||||
FORCE)
|
FORCE)
|
||||||
|
|
||||||
|
# Create a symbolic link from ${base_name} in the binary directory
|
||||||
|
# to the corresponding path in the source directory.
|
||||||
|
function(link_to_source base_name)
|
||||||
|
# Get OS dependent path to use in `execute_process`
|
||||||
|
file(TO_NATIVE_PATH "${CMAKE_CURRENT_BINARY_DIR}/${base_name}" link)
|
||||||
|
file(TO_NATIVE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/${base_name}" target)
|
||||||
|
|
||||||
|
if (NOT EXISTS ${link})
|
||||||
|
if (CMAKE_HOST_UNIX)
|
||||||
|
set(command ln -s ${target} ${link})
|
||||||
|
else()
|
||||||
|
set(command cmd.exe /c mklink /j ${link} ${target})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
execute_process(COMMAND ${command}
|
||||||
|
RESULT_VARIABLE result
|
||||||
|
ERROR_VARIABLE output)
|
||||||
|
|
||||||
|
if (NOT ${result} EQUAL 0)
|
||||||
|
message(FATAL_ERROR "Could not create symbolic link for: ${target} --> ${output}")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endfunction(link_to_source)
|
||||||
|
|
||||||
string(REGEX MATCH "Clang" CMAKE_COMPILER_IS_CLANG "${CMAKE_C_COMPILER_ID}")
|
string(REGEX MATCH "Clang" CMAKE_COMPILER_IS_CLANG "${CMAKE_C_COMPILER_ID}")
|
||||||
|
|
||||||
if(CMAKE_COMPILER_IS_GNUCC)
|
if(CMAKE_COMPILER_IS_GNUCC)
|
||||||
|
@ -137,3 +161,12 @@ if(ENABLE_TESTING)
|
||||||
)
|
)
|
||||||
endif(UNIX)
|
endif(UNIX)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# Make scripts needed for testing available in an out-of-source build.
|
||||||
|
if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
|
||||||
|
link_to_source(scripts)
|
||||||
|
# Copy (don't link) DartConfiguration.tcl, needed for memcheck, to
|
||||||
|
# keep things simple with the sed commands in the memcheck target.
|
||||||
|
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/DartConfiguration.tcl
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/DartConfiguration.tcl COPYONLY)
|
||||||
|
endif()
|
||||||
|
|
|
@ -11,6 +11,9 @@ Bugfix
|
||||||
* Fix redundant declaration of mbedtls_ssl_list_ciphersuites. Raised by
|
* Fix redundant declaration of mbedtls_ssl_list_ciphersuites. Raised by
|
||||||
TrinityTonic. #1359.
|
TrinityTonic. #1359.
|
||||||
|
|
||||||
|
Changes
|
||||||
|
* Support TLS testing in out-of-source builds using cmake.
|
||||||
|
|
||||||
= mbed TLS 2.1.12 branch released 2018-04-30
|
= mbed TLS 2.1.12 branch released 2018-04-30
|
||||||
|
|
||||||
Security
|
Security
|
||||||
|
|
|
@ -9,3 +9,8 @@ if(INSTALL_MBEDTLS_HEADERS)
|
||||||
PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ)
|
PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ)
|
||||||
|
|
||||||
endif(INSTALL_MBEDTLS_HEADERS)
|
endif(INSTALL_MBEDTLS_HEADERS)
|
||||||
|
|
||||||
|
# Make config.h available in an out-of-source build. ssl-opt.sh requires it.
|
||||||
|
if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
|
||||||
|
link_to_source(mbedtls)
|
||||||
|
endif()
|
||||||
|
|
|
@ -102,26 +102,11 @@ add_test_suite(xtea)
|
||||||
add_test_suite(x509parse)
|
add_test_suite(x509parse)
|
||||||
add_test_suite(x509write)
|
add_test_suite(x509write)
|
||||||
|
|
||||||
# Make data_files available in an out-of-source build
|
# Make scripts and data files needed for testing available in an
|
||||||
|
# out-of-source build.
|
||||||
if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
|
if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
|
||||||
# Get OS dependent path to use in `execute_process`
|
link_to_source(compat.sh)
|
||||||
file(TO_NATIVE_PATH "${CMAKE_CURRENT_BINARY_DIR}/data_files" link)
|
link_to_source(data_files)
|
||||||
file(TO_NATIVE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/data_files" target)
|
link_to_source(scripts)
|
||||||
|
link_to_source(ssl-opt.sh)
|
||||||
if (NOT EXISTS ${link})
|
|
||||||
if (CMAKE_HOST_UNIX)
|
|
||||||
set(command ln -s ${target} ${link})
|
|
||||||
else()
|
|
||||||
set(command cmd.exe /c mklink /j ${link} ${target})
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
execute_process(COMMAND ${command}
|
|
||||||
RESULT_VARIABLE result
|
|
||||||
ERROR_VARIABLE output)
|
|
||||||
|
|
||||||
if (NOT ${result} EQUAL 0)
|
|
||||||
message(FATAL_ERROR "Could not create symbolic link for: ${target} --> ${output}")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
|
|
|
@ -137,9 +137,19 @@ EOF
|
||||||
# remove built files as well as the cmake cache/config
|
# remove built files as well as the cmake cache/config
|
||||||
cleanup()
|
cleanup()
|
||||||
{
|
{
|
||||||
|
if [ -n "${MBEDTLS_ROOT_DIR+set}" ]; then
|
||||||
|
cd "$MBEDTLS_ROOT_DIR"
|
||||||
|
fi
|
||||||
|
|
||||||
command make clean
|
command make clean
|
||||||
|
|
||||||
find . -name yotta -prune -o -iname '*cmake*' -not -name CMakeLists.txt -exec rm -rf {} \+
|
# Remove CMake artefacts
|
||||||
|
find . -name .git -prune -o -name yotta -prune -o \
|
||||||
|
-iname CMakeFiles -exec rm -rf {} \+ -o \
|
||||||
|
\( -iname cmake_install.cmake -o \
|
||||||
|
-iname CTestTestfile.cmake -o \
|
||||||
|
-iname CMakeCache.txt \) -exec rm {} \+
|
||||||
|
# Recover files overwritten by in-tree CMake builds
|
||||||
rm -f include/Makefile include/mbedtls/Makefile programs/*/Makefile
|
rm -f include/Makefile include/mbedtls/Makefile programs/*/Makefile
|
||||||
git update-index --no-skip-worktree Makefile library/Makefile programs/Makefile tests/Makefile
|
git update-index --no-skip-worktree Makefile library/Makefile programs/Makefile tests/Makefile
|
||||||
git checkout -- Makefile library/Makefile programs/Makefile tests/Makefile
|
git checkout -- Makefile library/Makefile programs/Makefile tests/Makefile
|
||||||
|
@ -694,8 +704,20 @@ make
|
||||||
|
|
||||||
msg "test: cmake 'out-of-source' build"
|
msg "test: cmake 'out-of-source' build"
|
||||||
make test
|
make test
|
||||||
|
# Test an SSL option that requires an auxiliary script in test/scripts/.
|
||||||
|
# Also ensure that there are no error messages such as
|
||||||
|
# "No such file or directory", which would indicate that some required
|
||||||
|
# file is missing (ssl-opt.sh tolerates the absence of some files so
|
||||||
|
# may exit with status 0 but emit errors).
|
||||||
|
if_build_succeeded ./tests/ssl-opt.sh -f 'Fallback SCSV: beginning of list' 2>ssl-opt.err
|
||||||
|
if [ -s ssl-opt.err ]; then
|
||||||
|
cat ssl-opt.err >&2
|
||||||
|
record_status [ ! -s ssl-opt.err ]
|
||||||
|
rm ssl-opt.err
|
||||||
|
fi
|
||||||
cd "$MBEDTLS_ROOT_DIR"
|
cd "$MBEDTLS_ROOT_DIR"
|
||||||
rm -rf "$OUT_OF_SOURCE_DIR"
|
rm -rf "$OUT_OF_SOURCE_DIR"
|
||||||
|
unset MBEDTLS_ROOT_DIR
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue