* try to import mbedtls and build it * add stubs socket class * some boilterplate, read and write function implemented * more boilterplate / current error in handshake because no CA cert is setup * add something so skip ca verification, can ws curl https://google.com ! * cleanup / close implemented * tweak CMakefiles * typo in include * update readme * disable unittests
		
			
				
	
	
		
			189 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			189 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
 | 
						|
# To compile on SunOS: add "-lsocket -lnsl" to LDFLAGS
 | 
						|
# To compile with PKCS11: add "-lpkcs11-helper" to LDFLAGS
 | 
						|
 | 
						|
CFLAGS	?= -O2
 | 
						|
WARNING_CFLAGS ?= -Wall -W -Wdeclaration-after-statement -Wno-unused-function -Wno-unused-value
 | 
						|
LDFLAGS ?=
 | 
						|
 | 
						|
LOCAL_CFLAGS = $(WARNING_CFLAGS) -I../include -D_FILE_OFFSET_BITS=64
 | 
						|
LOCAL_LDFLAGS = -L../library			\
 | 
						|
		-lmbedtls$(SHARED_SUFFIX)	\
 | 
						|
		-lmbedx509$(SHARED_SUFFIX)	\
 | 
						|
		-lmbedcrypto$(SHARED_SUFFIX)
 | 
						|
 | 
						|
LOCAL_LDFLAGS += -L../crypto/library
 | 
						|
LOCAL_CFLAGS += -I../crypto/include
 | 
						|
CRYPTO := ../crypto/library/
 | 
						|
 | 
						|
# Enable definition of various functions used throughout the testsuite
 | 
						|
# (gethostname, strdup, fileno...) even when compiling with -std=c99. Harmless
 | 
						|
# on non-POSIX platforms.
 | 
						|
LOCAL_CFLAGS += -D_POSIX_C_SOURCE=200809L
 | 
						|
 | 
						|
ifndef SHARED
 | 
						|
DEP=$(CRYPTO)libmbedcrypto.a ../library/libmbedx509.a ../library/libmbedtls.a
 | 
						|
else
 | 
						|
DEP=$(CRYPTO)libmbedcrypto.$(DLEXT) ../library/libmbedx509.$(DLEXT) ../library/libmbedtls.$(DLEXT)
 | 
						|
endif
 | 
						|
 | 
						|
ifdef DEBUG
 | 
						|
LOCAL_CFLAGS += -g3
 | 
						|
endif
 | 
						|
 | 
						|
# if we're running on Windows, build for Windows
 | 
						|
ifdef WINDOWS
 | 
						|
WINDOWS_BUILD=1
 | 
						|
endif
 | 
						|
 | 
						|
ifdef WINDOWS_BUILD
 | 
						|
DLEXT=dll
 | 
						|
EXEXT=.exe
 | 
						|
LOCAL_LDFLAGS += -lws2_32
 | 
						|
ifdef SHARED
 | 
						|
SHARED_SUFFIX=.$(DLEXT)
 | 
						|
endif
 | 
						|
PYTHON ?= python
 | 
						|
else
 | 
						|
DLEXT ?= so
 | 
						|
EXEXT=
 | 
						|
SHARED_SUFFIX=
 | 
						|
# python2 for POSIX since FreeBSD has only python2 as default.
 | 
						|
PYTHON ?= python2
 | 
						|
endif
 | 
						|
 | 
						|
# Zlib shared library extensions:
 | 
						|
ifdef ZLIB
 | 
						|
LOCAL_LDFLAGS += -lz
 | 
						|
endif
 | 
						|
 | 
						|
# A test application is built for each suites/test_suite_*.data file.
 | 
						|
# Application name is same as .data file's base name and can be
 | 
						|
# constructed by stripping path 'suites/' and extension .data.
 | 
						|
APPS = $(basename $(subst suites/,,$(wildcard suites/test_suite_*.data)))
 | 
						|
 | 
						|
APPS := $(filter-out \
 | 
						|
		test_suite_aes.% \
 | 
						|
		test_suite_arc4 \
 | 
						|
		test_suite_aria \
 | 
						|
		test_suite_asn1write \
 | 
						|
		test_suite_base64 \
 | 
						|
		test_suite_blowfish \
 | 
						|
		test_suite_camellia \
 | 
						|
		test_suite_ccm \
 | 
						|
		test_suite_chacha20 \
 | 
						|
		test_suite_chachapoly \
 | 
						|
		test_suite_cipher.% \
 | 
						|
		test_suite_cmac \
 | 
						|
		test_suite_ctr_drbg \
 | 
						|
		test_suite_des \
 | 
						|
		test_suite_dhm \
 | 
						|
		test_suite_ecdh \
 | 
						|
		test_suite_ecdsa \
 | 
						|
		test_suite_ecjpake \
 | 
						|
		test_suite_ecp \
 | 
						|
		test_suite_entropy \
 | 
						|
		test_suite_error \
 | 
						|
		test_suite_gcm.% \
 | 
						|
		test_suite_hkdf \
 | 
						|
		test_suite_hmac_drbg.% \
 | 
						|
		test_suite_md \
 | 
						|
		test_suite_mdx \
 | 
						|
		test_suite_memory_buffer_alloc \
 | 
						|
		test_suite_mpi \
 | 
						|
		test_suite_nist_kw \
 | 
						|
		test_suite_oid \
 | 
						|
		test_suite_pem \
 | 
						|
		test_suite_pk \
 | 
						|
		test_suite_pkcs1_v15 \
 | 
						|
		test_suite_pkcs1_v21 \
 | 
						|
		test_suite_pkcs5 \
 | 
						|
		test_suite_pkparse \
 | 
						|
		test_suite_pkwrite \
 | 
						|
		test_suite_poly1305 \
 | 
						|
		test_suite_rsa \
 | 
						|
		test_suite_shax \
 | 
						|
		test_suite_timing \
 | 
						|
		test_suite_xtea \
 | 
						|
		,$(APPS))
 | 
						|
 | 
						|
# Construct executable name by adding OS specific suffix $(EXEXT).
 | 
						|
BINARIES := $(addsuffix $(EXEXT),$(APPS))
 | 
						|
 | 
						|
.SILENT:
 | 
						|
 | 
						|
.PHONY: all check test clean
 | 
						|
 | 
						|
all: $(BINARIES)
 | 
						|
 | 
						|
$(DEP):
 | 
						|
	$(MAKE) -C ../library
 | 
						|
 | 
						|
C_FILES := $(addsuffix .c,$(APPS))
 | 
						|
 | 
						|
# Wildcard target for test code generation:
 | 
						|
# A .c file is generated for each .data file in the suites/ directory. Each .c
 | 
						|
# file depends on a .data and .function file from suites/ directory. Following
 | 
						|
# nameing convention is followed:
 | 
						|
#
 | 
						|
#     C file        |        Depends on
 | 
						|
#-----------------------------------------------------------------------------
 | 
						|
#  foo.c            | suites/foo.function suites/foo.data
 | 
						|
#  foo.bar.c        | suites/foo.function suites/foo.bar.data
 | 
						|
#
 | 
						|
# Note above that .c and .data files have same base name.
 | 
						|
# However, corresponding .function file's base name is the word before first
 | 
						|
# dot in .c file's base name.
 | 
						|
#
 | 
						|
.SECONDEXPANSION:
 | 
						|
%.c: suites/$$(firstword $$(subst ., ,$$*)).function suites/%.data scripts/generate_test_code.py suites/helpers.function suites/main_test.function suites/host_test.function
 | 
						|
	echo "  Gen   $@"
 | 
						|
	$(PYTHON) scripts/generate_test_code.py -f suites/$(firstword $(subst ., ,$*)).function \
 | 
						|
		-d suites/$*.data \
 | 
						|
		-t suites/main_test.function \
 | 
						|
		-p suites/host_test.function \
 | 
						|
		-s suites  \
 | 
						|
		--helpers-file suites/helpers.function \
 | 
						|
		-o .
 | 
						|
 | 
						|
 | 
						|
$(BINARIES): %$(EXEXT): %.c $(DEP)
 | 
						|
	echo "  CC    $<"
 | 
						|
	$(CC) $(LOCAL_CFLAGS) $(CFLAGS) $<	$(LOCAL_LDFLAGS) $(LDFLAGS) -o $@
 | 
						|
 | 
						|
 | 
						|
clean:
 | 
						|
ifndef WINDOWS
 | 
						|
	rm -rf $(BINARIES) *.c *.datax TESTS
 | 
						|
else
 | 
						|
	del /Q /F *.c *.exe *.datax
 | 
						|
ifneq ($(wildcard TESTS/.*),)
 | 
						|
	rmdir /Q /S TESTS
 | 
						|
endif
 | 
						|
endif
 | 
						|
 | 
						|
# Test suites caught by SKIP_TEST_SUITES are built but not executed.
 | 
						|
check: $(BINARIES)
 | 
						|
	perl scripts/run-test-suites.pl --skip=$(SKIP_TEST_SUITES)
 | 
						|
 | 
						|
test: check
 | 
						|
 | 
						|
# Create separate targets for generating embedded tests.
 | 
						|
EMBEDDED_TESTS := $(addprefix embedded_,$(APPS))
 | 
						|
 | 
						|
# Generate test code for target.
 | 
						|
 | 
						|
.SECONDEXPANSION:
 | 
						|
$(EMBEDDED_TESTS): embedded_%: suites/$$(firstword $$(subst ., ,$$*)).function suites/%.data scripts/generate_test_code.py suites/helpers.function suites/main_test.function suites/target_test.function
 | 
						|
	echo "  Gen  ./TESTS/mbedtls/$*/$*.c"
 | 
						|
	$(PYTHON) scripts/generate_test_code.py -f suites/$(firstword $(subst ., ,$*)).function \
 | 
						|
		-d suites/$*.data \
 | 
						|
		-t suites/main_test.function \
 | 
						|
		-p suites/target_test.function \
 | 
						|
		-s suites  \
 | 
						|
		--helpers-file suites/helpers.function \
 | 
						|
		-o ./TESTS/mbedtls/$*
 | 
						|
 | 
						|
generate-target-tests: $(EMBEDDED_TESTS)
 | 
						|
 |