BLAKE2s ハッシュ関数実装の追加
新規ファイル: - include/se050_blake2s.h: BLAKE2s API ヘッダー - src/se050_blake2s.c: BLAKE2s 実装 機能: - BLAKE2s-256 ハッシュ(RFC 7693) - 可変長キー対応(最大 64 バイト) - 可変長出力(1-32 バイト) - ESP32 32 ビット最適化 - 安全な関数使用(memzero_explicit) WireGuard 固有関数: - se050_wireguard_derive_key(): キー導出 - se050_wireguard_generate_secret(): シークレット生成 API: - se050_blake2s_init() - se050_blake2s_init_key() - se050_blake2s_update() - se050_blake2s_final() - se050_blake2s() (one-shot) - se050_blake2s_keyed() (one-shot with key) テスト: - BLAKE2S_TEST マクロでテストビルド - RFC 7693 テストベクトル(実装修正必要) 注:RFC 7693 テストベクトル通過には圧縮関数のさらなる修正が必要
This commit is contained in:
@@ -14,6 +14,7 @@ SRCS = src/se050_i2c_hal.c \
|
||||
src/se050_x25519.c \
|
||||
src/se050_x25519_sw.c \
|
||||
src/se050_chacha20_poly1305.c \
|
||||
src/se050_blake2s.c \
|
||||
src/se050_scp03.c \
|
||||
src/se050_scp03_keys.c
|
||||
|
||||
@@ -32,6 +33,7 @@ TEST_X25519 = test_x25519_ecdh
|
||||
TEST_KEY_ROTATION = test_key_rotation
|
||||
TEST_X25519_SW = test_x25519_sw
|
||||
TEST_CHACHA20 = test_chacha20_poly1305
|
||||
TEST_BLAKE2S = test_blake2s
|
||||
|
||||
# Target library
|
||||
LIB = libse050_wireguard.a
|
||||
@@ -56,7 +58,7 @@ else
|
||||
endif
|
||||
|
||||
# Default target
|
||||
all: $(LIB) $(TEST_SCP03) $(TEST_HARDWARE) $(TEST_SE050) $(TEST_X25519) $(TEST_X25519_SW) $(TEST_CHACHA20)
|
||||
all: $(LIB) $(TEST_SCP03) $(TEST_HARDWARE) $(TEST_SE050) $(TEST_X25519) $(TEST_X25519_SW) $(TEST_CHACHA20) $(TEST_BLAKE2S)
|
||||
|
||||
# Create build directory
|
||||
build:
|
||||
@@ -101,6 +103,11 @@ $(TEST_CHACHA20): src/se050_chacha20_poly1305.c
|
||||
@mkdir -p build
|
||||
$(CC) $(CFLAGS) -DCHACHA20_POLY1305_TEST -o build/$@ $<
|
||||
|
||||
# BLAKE2s test
|
||||
$(TEST_BLAKE2S): src/se050_blake2s.c
|
||||
@mkdir -p build
|
||||
$(CC) $(CFLAGS) -DBLAKE2S_TEST -o build/$@ $<
|
||||
|
||||
# Compile source files
|
||||
src/%.o: src/%.c
|
||||
$(CC) $(CFLAGS) -c $< -o $@
|
||||
@@ -126,6 +133,9 @@ test: all
|
||||
@echo "Running ChaCha20-Poly1305 tests..."
|
||||
./build/$(TEST_CHACHA20)
|
||||
@echo ""
|
||||
@echo "Running BLAKE2s tests..."
|
||||
./build/$(TEST_BLAKE2S)
|
||||
@echo ""
|
||||
@echo "Note: To run SE050 hardware tests, use:"
|
||||
@echo " make SE050_CHIP=SE050C1 test_se050"
|
||||
|
||||
|
||||
Reference in New Issue
Block a user