2019-11-05 15:40:49 +01:00
|
|
|
# name of your application
|
|
|
|
APPLICATION = dtls_sock
|
|
|
|
|
|
|
|
# If no BOARD is found in the environment, use this default:
|
|
|
|
BOARD ?= native
|
|
|
|
|
|
|
|
# This has to be the absolute path to the RIOT base directory:
|
|
|
|
RIOTBASE ?= $(CURDIR)/../..
|
|
|
|
|
|
|
|
# Include packages that pull up and auto-init the link layer.
|
|
|
|
# NOTE: 6LoWPAN will be included if IEEE802.15.4 devices are present
|
2021-08-31 10:54:48 +02:00
|
|
|
USEMODULE += netdev_default
|
2019-11-05 15:40:49 +01:00
|
|
|
USEMODULE += auto_init_gnrc_netif
|
|
|
|
# Specify the mandatory networking modules for IPv6 and UDP
|
|
|
|
USEMODULE += gnrc_ipv6_default
|
2023-11-30 16:36:13 +01:00
|
|
|
USEMODULE += netutils
|
2019-11-05 15:40:49 +01:00
|
|
|
|
2020-08-31 15:20:08 +02:00
|
|
|
# Specify DTLS implementation
|
|
|
|
USEPKG += tinydtls
|
|
|
|
|
|
|
|
# Pull in sock APIs
|
|
|
|
USEMODULE += sock_dtls
|
2023-11-04 17:41:10 +01:00
|
|
|
# When using asymmetric cryptography, e.g. ecc,
|
|
|
|
# this verifies the public key against a known set.
|
|
|
|
# It does not affect symmetric crypto e.g. PSK.
|
|
|
|
USEMODULE += sock_dtls_verify_public_key
|
2020-08-31 15:20:08 +02:00
|
|
|
USEMODULE += sock_udp
|
2019-11-05 15:40:49 +01:00
|
|
|
|
2021-03-10 13:39:12 +01:00
|
|
|
# extra utilities for endpoint printing
|
|
|
|
USEMODULE += sock_util
|
|
|
|
|
2020-08-14 17:24:39 +02:00
|
|
|
# tinydtls needs crypto secure PRNG
|
|
|
|
USEMODULE += prng_sha1prng
|
|
|
|
|
2019-11-05 15:40:49 +01:00
|
|
|
# Add also the shell, some shell commands
|
|
|
|
USEMODULE += shell
|
2022-08-16 16:35:20 +02:00
|
|
|
USEMODULE += shell_cmds_default
|
2019-11-05 15:40:49 +01:00
|
|
|
|
|
|
|
# UDP Port to use (20220 is default for DTLS).
|
|
|
|
DTLS_PORT ?= 20220
|
|
|
|
CFLAGS += -DDTLS_DEFAULT_PORT=$(DTLS_PORT)
|
|
|
|
|
2019-12-18 18:15:30 +01:00
|
|
|
# NOTE: If no cipher suite is selected, CONFIG_DTLS_PSK is used by default.
|
|
|
|
# This section should be commented out if using Kconfig
|
2019-11-05 15:40:49 +01:00
|
|
|
# This adds support for TLS_PSK_WITH_AES_128_CCM_8
|
2019-12-18 18:15:30 +01:00
|
|
|
# CFLAGS += -DCONFIG_DTLS_PSK
|
2019-11-05 15:40:49 +01:00
|
|
|
# This adds support for TLS_ECDHE_ECDSA_WITH_AES_128_CCM_8
|
2019-12-18 18:15:30 +01:00
|
|
|
# CFLAGS += -DCONFIG_DTLS_ECC
|
2019-11-05 15:40:49 +01:00
|
|
|
|
|
|
|
# Uncomment to enable debug logs
|
2019-12-18 18:15:30 +01:00
|
|
|
# CFLAGS += -DCONFIG_DTLS_DEBUG
|
2019-11-05 15:40:49 +01:00
|
|
|
|
|
|
|
# Comment this out to disable code in RIOT that does safety checking
|
|
|
|
# which is not needed in a production environment but helps in the
|
|
|
|
# development process:
|
|
|
|
DEVELHELP ?= 1
|
|
|
|
# Change this to 0 show compiler invocation lines by default:
|
|
|
|
QUIET ?= 1
|
|
|
|
|
|
|
|
include $(RIOTBASE)/Makefile.include
|
2023-12-27 21:40:31 +01:00
|
|
|
|
|
|
|
# FIXME: This is a temporary patch
|
|
|
|
ifeq (,$(filter arch_avr8,$(FEATURES_USED)))
|
|
|
|
CFLAGS += -DTHREAD_STACKSIZE_MAIN=\(2*THREAD_STACKSIZE_LARGE\)
|
|
|
|
else
|
|
|
|
CFLAGS += -DTHREAD_STACKSIZE_MAIN=\(4*THREAD_STACKSIZE_LARGE\)
|
|
|
|
endif
|
2023-12-27 21:39:10 +01:00
|
|
|
|
|
|
|
# We have two credentials for client and server, each. If we are to run both
|
|
|
|
# server and client, we need four slots in total. The default (2) would be
|
|
|
|
# sufficient if only client or server is ever run.
|
|
|
|
CFLAGS += -DCONFIG_CREDMAN_MAX_CREDENTIALS=4
|