2009-01-03 21:22:43 +00:00
|
|
|
|
|
|
|
DESTDIR=/usr/local
|
2015-01-27 13:05:16 +00:00
|
|
|
PREFIX=mbedtls_
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2019-09-25 13:10:04 +00:00
|
|
|
PROGRAMS_DIR=./programs
|
|
|
|
TESTS_DIR=./tests
|
|
|
|
|
2019-09-25 14:08:39 +00:00
|
|
|
# Check test environment. If ../library is available then Mbed TLS is used.
|
|
|
|
# Otherwise Mbed OS environment is used.
|
2019-09-25 13:10:04 +00:00
|
|
|
DIR_FOR_MBED_TLS_ENV=./library
|
|
|
|
ifneq "$(wildcard $(DIR_FOR_MBED_TLS_ENV) )" ""
|
|
|
|
LIBRARY_DIR=./library
|
|
|
|
INCLUDE_DIR=./include
|
2019-09-26 07:33:56 +00:00
|
|
|
CONFIG_FILE=./include/mbedtls/config.h
|
2019-09-25 13:10:04 +00:00
|
|
|
else
|
|
|
|
LIBRARY_DIR=./src
|
|
|
|
INCLUDE_DIR=./inc
|
2019-09-26 07:33:56 +00:00
|
|
|
CONFIG_FILE=./inc/mbedtls/test_config.h
|
2019-09-25 13:10:04 +00:00
|
|
|
endif
|
|
|
|
|
2009-01-03 21:22:43 +00:00
|
|
|
.SILENT:
|
|
|
|
|
2015-06-24 11:06:24 +00:00
|
|
|
.PHONY: all no_test programs lib tests install uninstall clean test check covtest lcov apidoc apidoc_clean
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2016-08-25 15:36:16 +00:00
|
|
|
all: programs tests
|
|
|
|
$(MAKE) post_build
|
2015-02-18 15:18:28 +00:00
|
|
|
|
2015-06-24 11:06:24 +00:00
|
|
|
no_test: programs
|
|
|
|
|
2015-07-02 17:47:06 +00:00
|
|
|
programs: lib
|
2019-09-25 13:10:04 +00:00
|
|
|
$(MAKE) -C $(PROGRAMS_DIR)
|
2012-04-05 12:07:50 +00:00
|
|
|
|
|
|
|
lib:
|
2019-09-25 13:10:04 +00:00
|
|
|
$(MAKE) -C $(LIBRARY_DIR)
|
2015-02-18 15:18:28 +00:00
|
|
|
|
2015-07-02 17:47:06 +00:00
|
|
|
tests: lib
|
2019-09-25 13:10:04 +00:00
|
|
|
$(MAKE) -C $(TESTS_DIR)
|
2012-04-05 12:07:50 +00:00
|
|
|
|
2015-06-24 11:06:24 +00:00
|
|
|
ifndef WINDOWS
|
2015-08-03 08:34:09 +00:00
|
|
|
install: no_test
|
2019-09-25 13:10:04 +00:00
|
|
|
mkdir -p $(DESTDIR)/$(INCLUDE_DIR)/mbedtls
|
|
|
|
cp -rp $(INCLUDE_DIR)/mbedtls $(DESTDIR)/$(INCLUDE_DIR)
|
2018-03-13 15:22:58 +00:00
|
|
|
|
2009-01-03 21:22:43 +00:00
|
|
|
mkdir -p $(DESTDIR)/lib
|
2019-09-25 13:10:04 +00:00
|
|
|
cp -RP $(LIBRARY_DIR)/libmbedtls.* $(DESTDIR)/lib
|
|
|
|
cp -RP $(LIBRARY_DIR)/libmbedx509.* $(DESTDIR)/lib
|
|
|
|
cp -RP $(LIBRARY_DIR)/libmbedcrypto.* $(DESTDIR)/lib
|
2018-03-13 15:22:58 +00:00
|
|
|
|
2009-01-03 21:22:43 +00:00
|
|
|
mkdir -p $(DESTDIR)/bin
|
2019-09-25 13:10:04 +00:00
|
|
|
for p in $(PROGRAMS_DIR)/*/* ; do \
|
2009-01-03 21:22:43 +00:00
|
|
|
if [ -x $$p ] && [ ! -d $$p ] ; \
|
|
|
|
then \
|
|
|
|
f=$(PREFIX)`basename $$p` ; \
|
|
|
|
cp $$p $(DESTDIR)/bin/$$f ; \
|
|
|
|
fi \
|
|
|
|
done
|
|
|
|
|
2012-11-14 12:39:52 +00:00
|
|
|
uninstall:
|
2019-09-25 13:10:04 +00:00
|
|
|
rm -rf $(DESTDIR)/$(INCLUDE_DIR)/mbedtls
|
2015-01-27 13:05:16 +00:00
|
|
|
rm -f $(DESTDIR)/lib/libmbedtls.*
|
2015-07-27 08:36:12 +00:00
|
|
|
rm -f $(DESTDIR)/lib/libmbedx509.*
|
|
|
|
rm -f $(DESTDIR)/lib/libmbedcrypto.*
|
2018-03-13 15:22:58 +00:00
|
|
|
|
2019-09-25 13:10:04 +00:00
|
|
|
for p in $(PROGRAMS_DIR)/*/* ; do \
|
2012-11-14 12:39:52 +00:00
|
|
|
if [ -x $$p ] && [ ! -d $$p ] ; \
|
|
|
|
then \
|
|
|
|
f=$(PREFIX)`basename $$p` ; \
|
|
|
|
rm -f $(DESTDIR)/bin/$$f ; \
|
|
|
|
fi \
|
|
|
|
done
|
2015-06-24 11:06:24 +00:00
|
|
|
endif
|
2012-11-14 12:39:52 +00:00
|
|
|
|
2016-06-21 09:14:00 +00:00
|
|
|
WARNING_BORDER =*******************************************************\n
|
|
|
|
NULL_ENTROPY_WARN_L1=**** WARNING! MBEDTLS_TEST_NULL_ENTROPY defined! ****\n
|
|
|
|
NULL_ENTROPY_WARN_L2=**** THIS BUILD HAS NO DEFINED ENTROPY SOURCES ****\n
|
|
|
|
NULL_ENTROPY_WARN_L3=**** AND IS *NOT* SUITABLE FOR PRODUCTION USE ****\n
|
|
|
|
|
|
|
|
NULL_ENTROPY_WARNING=\n$(WARNING_BORDER)$(NULL_ENTROPY_WARN_L1)$(NULL_ENTROPY_WARN_L2)$(NULL_ENTROPY_WARN_L3)$(WARNING_BORDER)
|
|
|
|
|
2018-08-29 07:20:12 +00:00
|
|
|
WARNING_BORDER_LONG =**********************************************************************************\n
|
|
|
|
CTR_DRBG_128_BIT_KEY_WARN_L1=**** WARNING! MBEDTLS_CTR_DRBG_USE_128_BIT_KEY defined! ****\n
|
|
|
|
CTR_DRBG_128_BIT_KEY_WARN_L2=**** Using 128-bit keys for CTR_DRBG limits the security of generated ****\n
|
|
|
|
CTR_DRBG_128_BIT_KEY_WARN_L3=**** keys and operations that use random values generated to 128-bit security ****\n
|
|
|
|
|
|
|
|
CTR_DRBG_128_BIT_KEY_WARNING=\n$(WARNING_BORDER_LONG)$(CTR_DRBG_128_BIT_KEY_WARN_L1)$(CTR_DRBG_128_BIT_KEY_WARN_L2)$(CTR_DRBG_128_BIT_KEY_WARN_L3)$(WARNING_BORDER_LONG)
|
|
|
|
|
2016-06-21 09:14:00 +00:00
|
|
|
# Post build steps
|
|
|
|
post_build:
|
2016-06-27 14:15:11 +00:00
|
|
|
ifndef WINDOWS
|
2018-08-29 07:20:12 +00:00
|
|
|
|
|
|
|
# If 128-bit keys are configured for CTR_DRBG, display an appropriate warning
|
2019-09-26 07:33:56 +00:00
|
|
|
-scripts/config.pl -f $(CONFIG_FILE) get MBEDTLS_CTR_DRBG_USE_128_BIT_KEY && ([ $$? -eq 0 ]) && \
|
2018-08-29 07:20:12 +00:00
|
|
|
echo '$(CTR_DRBG_128_BIT_KEY_WARNING)'
|
|
|
|
|
2016-06-21 09:14:00 +00:00
|
|
|
# If NULL Entropy is configured, display an appropriate warning
|
2019-09-26 07:33:56 +00:00
|
|
|
-scripts/config.pl -f $(CONFIG_FILE) get MBEDTLS_TEST_NULL_ENTROPY && ([ $$? -eq 0 ]) && \
|
2016-06-21 09:14:00 +00:00
|
|
|
echo '$(NULL_ENTROPY_WARNING)'
|
2016-06-27 14:15:11 +00:00
|
|
|
endif
|
2016-06-21 09:14:00 +00:00
|
|
|
|
2009-01-03 21:22:43 +00:00
|
|
|
clean:
|
2019-09-25 13:10:04 +00:00
|
|
|
$(MAKE) -C $(LIBRARY_DIR) clean
|
|
|
|
$(MAKE) -C $(PROGRAMS_DIR) clean
|
|
|
|
$(MAKE) -C $(TESTS_DIR) clean
|
2015-06-24 11:06:24 +00:00
|
|
|
ifndef WINDOWS
|
2016-07-13 15:37:32 +00:00
|
|
|
find . \( -name \*.gcno -o -name \*.gcda -o -name \*.info \) -exec rm {} +
|
2015-06-24 11:06:24 +00:00
|
|
|
endif
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2016-08-31 15:10:45 +00:00
|
|
|
check: lib tests
|
2019-09-25 13:10:04 +00:00
|
|
|
$(MAKE) -C $(TESTS_DIR) check
|
2011-01-06 12:28:03 +00:00
|
|
|
|
2015-06-24 11:06:24 +00:00
|
|
|
test: check
|
2014-01-31 12:41:07 +00:00
|
|
|
|
2015-07-08 20:20:03 +00:00
|
|
|
ifndef WINDOWS
|
2014-02-24 11:39:18 +00:00
|
|
|
# note: for coverage testing, build with:
|
2015-06-24 11:06:24 +00:00
|
|
|
# make CFLAGS='--coverage -g3 -O0'
|
2014-02-26 18:39:01 +00:00
|
|
|
covtest:
|
2015-06-26 14:50:24 +00:00
|
|
|
$(MAKE) check
|
2019-09-25 13:10:04 +00:00
|
|
|
$(PROGRAMS_DIR)/test/selftest
|
|
|
|
$(TESTS_DIR)/compat.sh
|
|
|
|
$(TESTS_DIR)/ssl-opt.sh
|
2014-02-24 10:57:36 +00:00
|
|
|
|
2014-01-31 15:19:43 +00:00
|
|
|
lcov:
|
|
|
|
rm -rf Coverage
|
2019-09-25 13:10:04 +00:00
|
|
|
lcov --capture --initial --directory $(LIBRARY_DIR) -o files.info
|
|
|
|
lcov --capture --directory $(LIBRARY_DIR) -o tests.info
|
2014-06-16 14:24:24 +00:00
|
|
|
lcov --add-tracefile files.info --add-tracefile tests.info -o all.info
|
|
|
|
lcov --remove all.info -o final.info '*.h'
|
2014-02-24 11:39:18 +00:00
|
|
|
gendesc tests/Descriptions.txt -o descriptions
|
2015-01-23 17:40:33 +00:00
|
|
|
genhtml --title "mbed TLS" --description-file descriptions --keep-descriptions --legend --no-branch-coverage -o Coverage final.info
|
2014-06-16 14:24:24 +00:00
|
|
|
rm -f files.info tests.info all.info final.info descriptions
|
2014-01-31 15:19:43 +00:00
|
|
|
|
2011-01-06 12:28:03 +00:00
|
|
|
apidoc:
|
|
|
|
mkdir -p apidoc
|
2018-01-22 12:38:31 +00:00
|
|
|
cd doxygen && doxygen mbedtls.doxyfile
|
2011-01-06 12:28:03 +00:00
|
|
|
|
|
|
|
apidoc_clean:
|
2015-06-24 11:06:24 +00:00
|
|
|
rm -rf apidoc
|
|
|
|
endif
|
2018-01-16 13:04:05 +00:00
|
|
|
|
|
|
|
## Editor navigation files
|
2019-09-25 13:10:04 +00:00
|
|
|
C_SOURCE_FILES = $(wildcard $(INCLUDE_DIR)/*/*.h $(LIBRARY_DIR)/*.[hc] $(PROGRAMS_DIR)/*/*.[hc] $(TESTS_DIR)/suites/*.function)
|
Merge mbedtls 2.16.6 into baremetal
Conflicts:
mbedtls.doxyfile - PROJECT_NAME - mbed TLS v2.16.6 chosen.
doc_mainpage.h - mbed TLS v2.16.6 version chosen.
hmac_drbg.h - line 260, extended description chosen.
- line 313, extended description chosen.
- line 338, extended description chosen.
version.h - 2.16.6 chosen.
CMakeLists.txt - 2.16.6 chosen.
test_suite_version.data - 2.16.6 chosen.
Makefile - 141 - manual correction - baremetal version of C_SOURCE_FILES
with variables for directories plus 2.16.6 CTAGS addition.
pkparse.c - lines 846 onwards - the asn1_get_nonzero_mpi implementation chosen.
ssl_tls.c - line 5269 - edited manually, left the ret=0, because baremetal has
a different behaviour since commit 87b5626, but added a debug
message that's new in 2.16.6.
all.sh:
- component_build_deprecated - chosen the refactored version from 2.16.6,
but with extra flags from baremetal.
- rest of the _no_xxx tests - merged make options to have PTHREAD=1 and
other changes from 2.16.6 (like -O1 instead of -O0).
- component_build_arm_none_eabi_gcc_no_64bit_multiplication - added
TINYCRYPT_BUILD=0 to the 2.16.6 version of make.
x509/req_app.c - left baremetal log but with mbedtls_exit( 0 ) call.
x509/crl_app.c - left baremetal log but with mbedtls_exit( 0 ) call.
x509/cert_app.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl/ssl_mail_client.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl/ssl_pthread_server.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl/ssl_fork_server.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl_client1.c - line 54 - left baremetal log but with mbedtls_exit( 0 ) call.
ssl_client2.c - line 54 - left baremetal log but with mbedtls_exit( 0 ) call.
- line 132 - new options of both branches added.
- skip close notify handled as in 2.16.6, but with `ssl` instead of `&ssl`.
- Merged the 2.16.6 usage split with additional baremetal usages.
- Merged options from baremetal and 2.16.6.
ssl_server.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl_server2.c - Merged the 2.16.6 usage split with additional baremetal usages.
config.pl - fixed missing defines from the documentation, removed duplicates,
and reorganised so that the documentation and excluded list
are ordered in the same way.
test_suite_x509parse.data - only added the two new pathlen tests.
x509_crt.c - change the return code by removing
MBEDTLS_ERR_X509_INVALID_EXTENSIONS, since it's added by
x509_crt_frame_parse_ext not by an "or", but by "+=".
Changelog - Assigned all entries to appropriate sections.
ssl-opt.sh - line 8263 - merged options.
- removed lines 1165 - 1176 - there was a duplicate test, probably
an artifact of previous merges.
check-files.py - sticked to old formatting.
Signed-off-by: Andrzej Kurek <andrzej.kurek@arm.com>
2020-05-18 15:47:25 +00:00
|
|
|
# Exuberant-ctags invocation. Other ctags implementations may require different options.
|
|
|
|
CTAGS = ctags --langmap=c:+.h.function -o
|
2018-01-16 13:04:05 +00:00
|
|
|
tags: $(C_SOURCE_FILES)
|
Merge mbedtls 2.16.6 into baremetal
Conflicts:
mbedtls.doxyfile - PROJECT_NAME - mbed TLS v2.16.6 chosen.
doc_mainpage.h - mbed TLS v2.16.6 version chosen.
hmac_drbg.h - line 260, extended description chosen.
- line 313, extended description chosen.
- line 338, extended description chosen.
version.h - 2.16.6 chosen.
CMakeLists.txt - 2.16.6 chosen.
test_suite_version.data - 2.16.6 chosen.
Makefile - 141 - manual correction - baremetal version of C_SOURCE_FILES
with variables for directories plus 2.16.6 CTAGS addition.
pkparse.c - lines 846 onwards - the asn1_get_nonzero_mpi implementation chosen.
ssl_tls.c - line 5269 - edited manually, left the ret=0, because baremetal has
a different behaviour since commit 87b5626, but added a debug
message that's new in 2.16.6.
all.sh:
- component_build_deprecated - chosen the refactored version from 2.16.6,
but with extra flags from baremetal.
- rest of the _no_xxx tests - merged make options to have PTHREAD=1 and
other changes from 2.16.6 (like -O1 instead of -O0).
- component_build_arm_none_eabi_gcc_no_64bit_multiplication - added
TINYCRYPT_BUILD=0 to the 2.16.6 version of make.
x509/req_app.c - left baremetal log but with mbedtls_exit( 0 ) call.
x509/crl_app.c - left baremetal log but with mbedtls_exit( 0 ) call.
x509/cert_app.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl/ssl_mail_client.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl/ssl_pthread_server.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl/ssl_fork_server.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl_client1.c - line 54 - left baremetal log but with mbedtls_exit( 0 ) call.
ssl_client2.c - line 54 - left baremetal log but with mbedtls_exit( 0 ) call.
- line 132 - new options of both branches added.
- skip close notify handled as in 2.16.6, but with `ssl` instead of `&ssl`.
- Merged the 2.16.6 usage split with additional baremetal usages.
- Merged options from baremetal and 2.16.6.
ssl_server.c - left baremetal log but with mbedtls_exit( 0 ) call.
ssl_server2.c - Merged the 2.16.6 usage split with additional baremetal usages.
config.pl - fixed missing defines from the documentation, removed duplicates,
and reorganised so that the documentation and excluded list
are ordered in the same way.
test_suite_x509parse.data - only added the two new pathlen tests.
x509_crt.c - change the return code by removing
MBEDTLS_ERR_X509_INVALID_EXTENSIONS, since it's added by
x509_crt_frame_parse_ext not by an "or", but by "+=".
Changelog - Assigned all entries to appropriate sections.
ssl-opt.sh - line 8263 - merged options.
- removed lines 1165 - 1176 - there was a duplicate test, probably
an artifact of previous merges.
check-files.py - sticked to old formatting.
Signed-off-by: Andrzej Kurek <andrzej.kurek@arm.com>
2020-05-18 15:47:25 +00:00
|
|
|
$(CTAGS) $@ $(C_SOURCE_FILES)
|
2018-01-16 13:04:05 +00:00
|
|
|
TAGS: $(C_SOURCE_FILES)
|
|
|
|
etags -o $@ $(C_SOURCE_FILES)
|
|
|
|
GPATH GRTAGS GSYMS GTAGS: $(C_SOURCE_FILES)
|
|
|
|
ls $(C_SOURCE_FILES) | gtags -f - --gtagsconf .globalrc
|