mirror of
https://github.com/apache/nuttx.git
synced 2026-05-25 18:27:56 +08:00
b843d9192e
This commit modularizes the curve25519 and idgen implementations in the crypto subsystem. Previously, curve25519.c and idgen.c were only compiled when CONFIG_CRYPTO_RANDOM_POOL was enabled. However, cryptosoft.c (used by software cipher support) has a direct dependency on curve25519 functions. This caused linker errors (undefined reference to curve25519) when software crypto was enabled but the random pool was disabled. Changes: - Introduce hidden Kconfig options CRYPTO_CURVE25519 and CRYPTO_IDGEN. - Make CRYPTO_RANDOM_POOL select both CRYPTO_IDGEN and CRYPTO_CURVE25519. - Make CRYPTO_CRYPTODEV_SOFTWARE_CRYPTO/KEYMGMT select CRYPTO_CURVE25519. - Update CMakeLists.txt and Makefile to use the new config flags. This ensures that required algorithms are automatically included in the build regardless of whether the entropy pool is enabled. Signed-off-by: karaketir16 <osmankaraketir@gmail.com>
81 lines
2.3 KiB
CMake
81 lines
2.3 KiB
CMake
# ##############################################################################
|
|
# crypto/CMakeLists.txt
|
|
#
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
#
|
|
# 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.
|
|
#
|
|
# ##############################################################################
|
|
if(CONFIG_CRYPTO)
|
|
nuttx_add_kernel_library(crypto)
|
|
|
|
set(SRCS crypto.c testmngr.c)
|
|
|
|
# cryptodev support
|
|
|
|
if(CONFIG_CRYPTO_CRYPTODEV)
|
|
list(APPEND SRCS cryptodev.c)
|
|
if(CONFIG_CRYPTO_CRYPTODEV_SOFTWARE_CRYPTO
|
|
OR CONFIG_CRYPTO_CRYPTODEV_SOFTWARE_KEYMGMT)
|
|
list(APPEND SRCS cryptosoft.c)
|
|
list(APPEND SRCS xform.c)
|
|
endif()
|
|
endif()
|
|
|
|
# Software crypto library
|
|
|
|
if(CONFIG_CRYPTO_SW_AES)
|
|
list(APPEND SRCS aes.c)
|
|
endif()
|
|
list(APPEND SRCS blake2s.c)
|
|
list(APPEND SRCS blf.c)
|
|
list(APPEND SRCS cast.c)
|
|
list(APPEND SRCS chachapoly.c)
|
|
list(APPEND SRCS ecb_enc.c)
|
|
list(APPEND SRCS ecb3_enc.c)
|
|
list(APPEND SRCS ecc.c)
|
|
list(APPEND SRCS set_key.c)
|
|
list(APPEND SRCS md5.c)
|
|
list(APPEND SRCS poly1305.c)
|
|
list(APPEND SRCS rijndael.c)
|
|
list(APPEND SRCS rmd160.c)
|
|
list(APPEND SRCS sha1.c)
|
|
list(APPEND SRCS sha2.c)
|
|
list(APPEND SRCS gmac.c)
|
|
list(APPEND SRCS cmac.c)
|
|
list(APPEND SRCS hmac.c)
|
|
if(CONFIG_CRYPTO_IDGEN)
|
|
list(APPEND SRCS idgen.c)
|
|
endif()
|
|
|
|
if(CONFIG_CRYPTO_CURVE25519)
|
|
list(APPEND SRCS curve25519.c)
|
|
endif()
|
|
|
|
list(APPEND SRCS key_wrap.c)
|
|
list(APPEND SRCS siphash.c)
|
|
list(APPEND SRCS hmac_buff.c)
|
|
list(APPEND SRCS bn.c)
|
|
|
|
# Entropy pool random number generator
|
|
|
|
if(CONFIG_CRYPTO_RANDOM_POOL)
|
|
list(APPEND SRCS random_pool.c)
|
|
endif()
|
|
|
|
target_sources(crypto PRIVATE ${SRCS})
|
|
endif()
|