2023-08-29 18:43:32 +02:00
|
|
|
# include the PSA headers
|
|
|
|
INCLUDES += -I$(RIOTBASE)/sys/psa_crypto/include
|
|
|
|
|
|
|
|
# Workaround for mbedtls namespacing issue
|
|
|
|
# sys/include will include the conflicting header files in psa but requires a psa/*.h structure.
|
|
|
|
INCLUDES += -I$(RIOTBASE)/sys/include/psa_crypto
|
|
|
|
|
|
|
|
backends = $(words $(filter $1_backend_%,$(USEMODULE)))
|
|
|
|
|
|
|
|
# Pseudomodules
|
|
|
|
## Asymmetric
|
|
|
|
PSEUDOMODULES += psa_asymmetric
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_p192r1
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_p192r1_backend_microecc
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_p192r1_backend_periph
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_p192r1_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_asymmetric_ecc_p192r1,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends, psa_asymmetric_ecc_p192r1))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_asymmetric_ecc_p192r1")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_p256r1
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_p256r1_backend_microecc
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_p256r1_backend_periph
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_p256r1_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_asymmetric_ecc_p256r1,$(USEMODULE)))
|
2023-09-25 17:19:32 +02:00
|
|
|
ifneq (1,$(call backends, psa_asymmetric_ecc_p256r1))
|
2023-08-29 18:43:32 +02:00
|
|
|
$(error "One (and only one) backend should be selected for psa_asymmetric_ecc_p256r1")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2023-09-25 17:19:32 +02:00
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_ed25519
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_ed25519_backend_periph
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_ed25519_backend_c25519
|
|
|
|
PSEUDOMODULES += psa_asymmetric_ecc_ed25519_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_asymmetric_ecc_ed25519,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends, psa_asymmetric_ecc_ed25519))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_asymmetric_ecc_ed25519")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2023-08-29 18:43:32 +02:00
|
|
|
## Cipher
|
|
|
|
PSEUDOMODULES += psa_cipher
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_128_ecb
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_128_ecb_backend_riot
|
|
|
|
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_128_cbc
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_128_cbc_backend_periph
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_128_cbc_backend_riot
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_128_cbc_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_cipher_aes_128_cbc,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends,psa_cipher_aes_128_cbc))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_cipher_aes_128_cbc")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_192_cbc
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_192_cbc_backend_riot
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_192_cbc_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_cipher_aes_192_cbc,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends,psa_cipher_aes_192_cbc))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_cipher_aes_192_cbc")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_256_cbc
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_256_cbc_backend_riot
|
|
|
|
PSEUDOMODULES += psa_cipher_aes_256_cbc_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_cipher_aes_256_cbc,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends,psa_cipher_aes_256_cbc))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_cipher_aes_256_cbc")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Hash
|
|
|
|
PSEUDOMODULES += psa_hash
|
|
|
|
PSEUDOMODULES += psa_hash_md5
|
|
|
|
PSEUDOMODULES += psa_hash_md5_backend_riot
|
|
|
|
PSEUDOMODULES += psa_hash_md5_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_hash_md5,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends,psa_hash_md5))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_hash_md5")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
PSEUDOMODULES += psa_hash_sha_1
|
|
|
|
PSEUDOMODULES += psa_hash_sha_1_backend_periph
|
|
|
|
PSEUDOMODULES += psa_hash_sha_1_backend_riot
|
|
|
|
PSEUDOMODULES += psa_hash_sha_1_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_hash_sha_1,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends,psa_hash_sha_1))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_hash_sha_1")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
PSEUDOMODULES += psa_hash_sha_224
|
|
|
|
PSEUDOMODULES += psa_hash_sha_224_backend_periph
|
|
|
|
PSEUDOMODULES += psa_hash_sha_224_backend_riot
|
|
|
|
PSEUDOMODULES += psa_hash_sha_224_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_hash_sha_224,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends,psa_hash_sha_224))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_hash_sha_224")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
PSEUDOMODULES += psa_hash_sha_256
|
|
|
|
PSEUDOMODULES += psa_hash_sha_256_backend_periph
|
|
|
|
PSEUDOMODULES += psa_hash_sha_256_backend_riot
|
|
|
|
PSEUDOMODULES += psa_hash_sha_256_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_hash_sha_256,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends,psa_hash_sha_256))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_hash_sha_256")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
PSEUDOMODULES += psa_hash_sha_512
|
|
|
|
PSEUDOMODULES += psa_hash_sha_512_backend_periph
|
|
|
|
PSEUDOMODULES += psa_hash_sha_512_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_hash_sha_512,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends,psa_hash_sha_512))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_hash_sha_512")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
## MAC
|
|
|
|
PSEUDOMODULES += psa_mac
|
|
|
|
PSEUDOMODULES += psa_mac_hmac_sha_256
|
|
|
|
PSEUDOMODULES += psa_mac_hmac_sha_256_backend_periph
|
|
|
|
PSEUDOMODULES += psa_mac_hmac_sha_256_backend_riot
|
|
|
|
PSEUDOMODULES += psa_mac_hmac_sha_256_custom_backend
|
|
|
|
|
|
|
|
# check that one and only one backend has been selected
|
|
|
|
ifneq (,$(filter psa_mac_hmac_sha_256,$(USEMODULE)))
|
|
|
|
ifneq (1,$(call backends,psa_mac_hmac_sha_256))
|
|
|
|
$(error "One (and only one) backend should be selected for psa_mac_hmac_sha_256")
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Secure Elements
|
|
|
|
PSEUDOMODULES += psa_secure_element
|
|
|
|
PSEUDOMODULES += psa_secure_element_asymmetric
|
|
|
|
PSEUDOMODULES += psa_secure_element_config
|
|
|
|
PSEUDOMODULES += psa_secure_element_multiple
|