|
| 1 | +# Copyright (c) The mldsa-native project authors |
| 2 | +# SPDX-License-Identifier: Apache-2.0 OR ISC OR MIT |
| 3 | + |
| 4 | +.PHONY: build run clean size |
| 5 | +.DEFAULT_GOAL := all |
| 6 | + |
| 7 | +# Append cross-prefix for cross compilation |
| 8 | +# Remove or ignore for native builds |
| 9 | +CC ?= gcc |
| 10 | +SIZE ?= size |
| 11 | +# When called from the root Makefile, CROSS_PREFIX has already been added here |
| 12 | +ifeq (,$(findstring $(CROSS_PREFIX),$(CC))) |
| 13 | +CC := $(CROSS_PREFIX)$(CC) |
| 14 | +endif |
| 15 | + |
| 16 | +ifeq (,$(findstring $(CROSS_PREFIX),$(SIZE))) |
| 17 | +SIZE := $(CROSS_PREFIX)$(SIZE) |
| 18 | +endif |
| 19 | + |
| 20 | +# Part A: |
| 21 | +# |
| 22 | +# mldsa-native source and header files |
| 23 | +# Note: We exclude the fips202/ directory since we're providing our own |
| 24 | +MLD_SOURCE=$(wildcard \ |
| 25 | + ../../mldsa/*.c \ |
| 26 | + ../../mldsa/native/**/*.c \ |
| 27 | + ../../mldsa/native/**/**/*.c) |
| 28 | + |
| 29 | +INC=-I../../mldsa/ -Icustom_fips202/ |
| 30 | + |
| 31 | +# Part B: |
| 32 | +# |
| 33 | +# Custom FIPS-202 implementation |
| 34 | +# |
| 35 | +# At present, this must be located in a directory named "fips202". |
| 36 | +# This limitation will be lifted in the future. |
| 37 | +FIPS202_SOURCE=custom_fips202/tiny_sha3/sha3.c |
| 38 | + |
| 39 | +# Part C: |
| 40 | +# |
| 41 | +# Random number generator |
| 42 | +# |
| 43 | +# !!! WARNING !!! |
| 44 | +# |
| 45 | +# The randombytes() implementation used here is for TESTING ONLY. |
| 46 | +# You MUST NOT use this implementation outside of testing. |
| 47 | +# |
| 48 | +# !!! WARNING !!! |
| 49 | +RNG_SOURCE=$(wildcard test_only_rng/*.c) |
| 50 | + |
| 51 | +# Part D: |
| 52 | +# |
| 53 | +# Your application source code |
| 54 | +APP_SOURCE=$(wildcard *.c) |
| 55 | + |
| 56 | +ALL_SOURCE=$(MLD_SOURCE) $(FIPS202_SOURCE) $(RNG_SOURCE) $(APP_SOURCE) |
| 57 | + |
| 58 | +BUILD_DIR=build |
| 59 | +BIN=test_binary |
| 60 | + |
| 61 | +CFLAGS := \ |
| 62 | + -Wall \ |
| 63 | + -Wextra \ |
| 64 | + -Werror \ |
| 65 | + -Wmissing-prototypes \ |
| 66 | + -Wshadow \ |
| 67 | + -Wpointer-arith \ |
| 68 | + -Wredundant-decls \ |
| 69 | + -Wconversion \ |
| 70 | + -Wsign-conversion \ |
| 71 | + -Wno-long-long \ |
| 72 | + -Wno-unknown-pragmas \ |
| 73 | + -Wno-unused-command-line-argument \ |
| 74 | + -fomit-frame-pointer \ |
| 75 | + -std=c99 \ |
| 76 | + -pedantic \ |
| 77 | + -MMD \ |
| 78 | + -O3 \ |
| 79 | + $(CFLAGS) |
| 80 | +CFLAGS += -DMLD_CONFIG_FIPS202_CUSTOM_HEADER="\"fips202.h\"" |
| 81 | +CFLAGS += -DMLD_CONFIG_FIPS202X4_CUSTOM_HEADER="\"fips202x4.h\"" |
| 82 | +CFLAGS += -DMLD_CONFIG_NAMESPACE_PREFIX=mldsa |
| 83 | + |
| 84 | +BINARY_NAME_FULL_44=$(BUILD_DIR)/$(BIN)44 |
| 85 | +BINARY_NAME_FULL_65=$(BUILD_DIR)/$(BIN)65 |
| 86 | +BINARY_NAME_FULL_87=$(BUILD_DIR)/$(BIN)87 |
| 87 | +BINARIES_FULL=$(BINARY_NAME_FULL_44) $(BINARY_NAME_FULL_65) $(BINARY_NAME_FULL_87) |
| 88 | + |
| 89 | +$(BINARY_NAME_FULL_44): CFLAGS += -DMLD_CONFIG_PARAMETER_SET=44 |
| 90 | +$(BINARY_NAME_FULL_65): CFLAGS += -DMLD_CONFIG_PARAMETER_SET=65 |
| 91 | +$(BINARY_NAME_FULL_87): CFLAGS += -DMLD_CONFIG_PARAMETER_SET=87 |
| 92 | + |
| 93 | +$(BINARIES_FULL): $(ALL_SOURCE) |
| 94 | + echo "$@" |
| 95 | + mkdir -p $(BUILD_DIR) |
| 96 | + $(CC) $(CFLAGS) $(INC) $^ -o $@ |
| 97 | + |
| 98 | +all: build size |
| 99 | + |
| 100 | +build: $(BINARIES_FULL) |
| 101 | + |
| 102 | +run: $(BINARIES_FULL) |
| 103 | + $(EXEC_WRAPPER) ./$(BINARY_NAME_FULL_44) |
| 104 | + $(EXEC_WRAPPER) ./$(BINARY_NAME_FULL_65) |
| 105 | + $(EXEC_WRAPPER) ./$(BINARY_NAME_FULL_87) |
| 106 | + |
| 107 | +size: build |
| 108 | + @echo "=== Size info for $(BINARY_NAME_FULL_44) ===" |
| 109 | + @$(SIZE) $(BINARY_NAME_FULL_44) |
| 110 | + @echo "=== Size info for $(BINARY_NAME_FULL_65) ===" |
| 111 | + @$(SIZE) $(BINARY_NAME_FULL_65) |
| 112 | + @echo "=== Size info for $(BINARY_NAME_FULL_87) ===" |
| 113 | + @$(SIZE) $(BINARY_NAME_FULL_87) |
| 114 | + |
| 115 | +clean: |
| 116 | + rm -rf $(BUILD_DIR) |
0 commit comments