2021-01-18 09:57:33 +01:00
|
|
|
############################################################################
|
|
|
|
# apps/crypto/mbedtls/Makefile
|
|
|
|
#
|
|
|
|
# Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
# contributor license agreements. See the NOTICE file distributed with
|
|
|
|
# this work for additional information regarding copyright ownership. The
|
|
|
|
# ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
# "License"); you may not use this file except in compliance with the
|
|
|
|
# License. You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
# License for the specific language governing permissions and limitations
|
|
|
|
# under the License.
|
|
|
|
#
|
|
|
|
############################################################################
|
|
|
|
|
|
|
|
include $(APPDIR)/Make.defs
|
|
|
|
|
|
|
|
# Mbed TLS crypto library
|
|
|
|
|
|
|
|
# Set up build configuration and environment
|
|
|
|
|
|
|
|
MBEDTLS_URL ?= "https://github.com/ARMmbed/mbedtls/archive"
|
|
|
|
|
|
|
|
MBEDTLS_VERSION = $(patsubst "%",%,$(strip $(CONFIG_MBEDTLS_VERSION)))
|
|
|
|
MBEDTLS_ZIP = v$(MBEDTLS_VERSION).zip
|
|
|
|
|
|
|
|
MBEDTLS_UNPACKNAME = mbedtls
|
|
|
|
UNPACK ?= unzip -q -o
|
|
|
|
|
|
|
|
MBEDTLS_UNPACKLIBDIR = $(MBEDTLS_UNPACKNAME)$(DELIM)library
|
|
|
|
MBEDTLS_UNPACKPROGDIR = $(MBEDTLS_UNPACKNAME)$(DELIM)programs
|
|
|
|
|
|
|
|
# This lets Mbed TLS better use some of the POSIX features we have
|
2023-10-31 12:06:50 +01:00
|
|
|
CFLAGS += ${DEFINE_PREFIX}unix
|
2021-01-18 09:57:33 +01:00
|
|
|
|
2023-04-19 11:26:10 +02:00
|
|
|
mbedtls/library/bignum.c_CFLAGS += -fno-lto
|
|
|
|
|
|
|
|
# Build break on Assemble compiler if -fno-omit-frame-pointer and -O3 enabled at same time
|
|
|
|
# {standard input}: Assembler messages:
|
|
|
|
# {standard input}:2560: Error: branch out of range
|
|
|
|
# make[2]: *** [apps/Application.mk:170: mbedtls/library/sha256.o] Error 1
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_FRAME_POINTER),y)
|
|
|
|
ifeq ($(CONFIG_DEBUG_OPTLEVEL),"-O3")
|
|
|
|
mbedtls/library/sha256.c_CFLAGS += -O2
|
2024-01-24 10:22:55 +01:00
|
|
|
mbedtls/library/cmac.c_CFLAGS += -O2
|
2023-04-19 11:26:10 +02:00
|
|
|
endif
|
|
|
|
endif
|
2023-02-22 10:28:35 +01:00
|
|
|
|
|
|
|
ifeq ($(CONFIG_ARCH_SIM),y)
|
|
|
|
CFLAGS += -O0
|
|
|
|
endif
|
|
|
|
|
2021-01-18 09:57:33 +01:00
|
|
|
CSRCS = $(wildcard $(MBEDTLS_UNPACKLIBDIR)$(DELIM)*.c)
|
|
|
|
|
|
|
|
$(MBEDTLS_ZIP):
|
|
|
|
@echo "Downloading: $(MBEDTLS_URL)/$(MBEDTLS_ZIP)"
|
|
|
|
$(Q) curl -O -L $(MBEDTLS_URL)/$(MBEDTLS_ZIP)
|
|
|
|
|
|
|
|
$(MBEDTLS_UNPACKNAME): $(MBEDTLS_ZIP)
|
|
|
|
@echo "Unpacking: $(MBEDTLS_ZIP) -> $(MBEDTLS_UNPACKNAME)"
|
|
|
|
$(Q) $(UNPACK) $(MBEDTLS_ZIP)
|
|
|
|
$(Q) mv mbedtls-$(MBEDTLS_VERSION) $(MBEDTLS_UNPACKNAME)
|
2023-09-11 13:48:49 +02:00
|
|
|
$(Q) patch -p1 -d $(MBEDTLS_UNPACKNAME) < 0001-mbedtls-entropy_poll-use-getrandom-to-get-the-system.patch
|
2023-09-24 12:01:22 +02:00
|
|
|
$(Q) patch -p1 -d $(MBEDTLS_UNPACKNAME) < 0002-mbedtls-add-mbedtls-x509-crt-pool.patch
|
2021-01-18 09:57:33 +01:00
|
|
|
$(Q) touch $(MBEDTLS_UNPACKNAME)
|
|
|
|
|
2022-08-27 08:15:16 +02:00
|
|
|
# Download and unpack tarball if no git repo found
|
|
|
|
ifeq ($(wildcard $(MBEDTLS_UNPACKNAME)/.git),)
|
2021-01-18 09:57:33 +01:00
|
|
|
context:: $(MBEDTLS_UNPACKNAME)
|
|
|
|
|
|
|
|
distclean::
|
|
|
|
$(call DELDIR, $(MBEDTLS_UNPACKNAME))
|
|
|
|
$(call DELFILE, $(MBEDTLS_ZIP))
|
2022-08-27 08:15:16 +02:00
|
|
|
endif
|
2021-01-18 09:57:33 +01:00
|
|
|
|
|
|
|
# Configuration Applications
|
|
|
|
|
|
|
|
ifneq ($(CONFIG_MBEDTLS_APPS),)
|
|
|
|
|
|
|
|
MODULE = $(CONFIG_MBEDTLS_APPS)
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_MBEDTLS_APP_BENCHMARK),y)
|
|
|
|
|
|
|
|
PROGNAME += $(CONFIG_MBEDTLS_APP_BENCHMARK_PROGNAME)
|
|
|
|
PRIORITY += $(CONFIG_MBEDTLS_APP_BENCHMARK_PRIORITY)
|
|
|
|
STACKSIZE += $(CONFIG_MBEDTLS_APP_BENCHMARK_STACKSIZE)
|
|
|
|
|
|
|
|
MAINSRC += $(MBEDTLS_UNPACKPROGDIR)/test/benchmark.c
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_MBEDTLS_APP_SELFTEST),y)
|
|
|
|
|
|
|
|
PROGNAME += $(CONFIG_MBEDTLS_APP_SELFTEST_PROGNAME)
|
|
|
|
PRIORITY += $(CONFIG_MBEDTLS_APP_SELFTEST_PRIORITY)
|
|
|
|
STACKSIZE += $(CONFIG_MBEDTLS_APP_SELFTEST_STACKSIZE)
|
|
|
|
|
|
|
|
MAINSRC += $(MBEDTLS_UNPACKPROGDIR)/test/selftest.c
|
|
|
|
endif
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
2023-07-18 15:44:38 +02:00
|
|
|
# Configuration alternative implementation
|
|
|
|
|
2024-08-28 14:41:54 +02:00
|
|
|
ifneq ($(CONFIG_MBEDTLS_ENTROPY_HARDWARE_ALT)$(CONFIG_MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG),)
|
2023-08-04 14:47:16 +02:00
|
|
|
CSRCS += $(APPDIR)/crypto/mbedtls/source/entropy_alt.c
|
|
|
|
endif
|
|
|
|
|
2023-07-18 15:44:38 +02:00
|
|
|
ifeq ($(CONFIG_MBEDTLS_ALT),y)
|
|
|
|
|
|
|
|
CSRCS += $(APPDIR)/crypto/mbedtls/source/dev_alt.c
|
|
|
|
|
2023-08-09 13:48:42 +02:00
|
|
|
ifeq ($(CONFIG_MBEDTLS_AES_ALT),y)
|
|
|
|
CSRCS += $(APPDIR)/crypto/mbedtls/source/aes_alt.c
|
|
|
|
endif
|
|
|
|
|
2024-07-09 15:08:55 +02:00
|
|
|
ifeq ($(CONFIG_MBEDTLS_CMAC_ALT),y)
|
|
|
|
CSRCS += $(APPDIR)/crypto/mbedtls/source/cmac_alt.c
|
|
|
|
endif
|
|
|
|
|
2023-09-09 10:44:08 +02:00
|
|
|
ifeq ($(CONFIG_MBEDTLS_MD5_ALT),y)
|
|
|
|
CSRCS += $(APPDIR)/crypto/mbedtls/source/md5_alt.c
|
|
|
|
endif
|
|
|
|
|
2023-07-18 15:44:38 +02:00
|
|
|
ifeq ($(CONFIG_MBEDTLS_SHA1_ALT),y)
|
|
|
|
CSRCS += $(APPDIR)/crypto/mbedtls/source/sha1_alt.c
|
|
|
|
endif
|
|
|
|
|
2023-08-08 08:32:21 +02:00
|
|
|
ifeq ($(CONFIG_MBEDTLS_SHA256_ALT),y)
|
|
|
|
CSRCS += $(APPDIR)/crypto/mbedtls/source/sha256_alt.c
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_MBEDTLS_SHA512_ALT),y)
|
|
|
|
CSRCS += $(APPDIR)/crypto/mbedtls/source/sha512_alt.c
|
|
|
|
endif
|
|
|
|
|
2023-07-18 15:44:38 +02:00
|
|
|
endif
|
|
|
|
|
2021-01-18 09:57:33 +01:00
|
|
|
include $(APPDIR)/Application.mk
|