2012-03-28 02:25:11 +00:00
|
|
|
# Makefile for the AVR-Crypto-Lib project
|
|
|
|
#
|
|
|
|
# This file is part of the AVR-Crypto-Lib.
|
|
|
|
# Copyright (C) 2010 Daniel Otte (daniel.otte@rub.de)
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
BLOCK_CIPHERS :=
|
|
|
|
STREAM_CIPHERS :=
|
|
|
|
HASHES :=
|
|
|
|
MACS :=
|
|
|
|
PRNGS :=
|
|
|
|
ENCODINGS :=
|
|
|
|
SIGNATURE :=
|
|
|
|
PK_CIPHERS :=
|
|
|
|
AUX :=
|
|
|
|
|
|
|
|
|
|
|
|
# we use the gnu make standard library
|
|
|
|
include gmsl
|
|
|
|
|
|
|
|
GLOBAL_INCDIR := ./ $(TESTSRC_DIR)
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
# inclusion of make stubs
|
2012-04-18 01:05:24 +00:00
|
|
|
include $(sort $(wildcard mkfiles/*.mk))
|
2012-03-28 02:25:11 +00:00
|
|
|
|
2012-04-25 22:36:52 +00:00
|
|
|
default: info
|
|
|
|
|
2012-03-28 02:25:11 +00:00
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
ALGORITHMS = $(BLOCK_CIPHERS) $(STREAM_CIPHERS) $(HASHES) $(PRNGS) $(MACS) \
|
|
|
|
$(ENCODINGS) $(SIGNATURE) $(PK_CIPHERS) $(AUX)
|
|
|
|
ALGORITHMS_OBJ = $(patsubst %,%_OBJ, $(ALGORITHMS))
|
|
|
|
ALGORITHMS_TESTBIN = $(patsubst %,%_TESTBIN, $(ALGORITHMS))
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
# define binary object in $(BIN_DIR)$(ALGO)/<obj>
|
|
|
|
define Assert_Template
|
|
|
|
$(1) = $(2)
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach a, $(ALGORITHMS), $(eval $(call Assert_Template, \
|
|
|
|
$(a)_BINOBJ, \
|
|
|
|
$(addprefix $(BIN_DIR)$(call lc,$(a))/,$($(a)_OBJ)) \
|
|
|
|
)))
|
|
|
|
|
|
|
|
$(foreach a, $(ALGORITHMS), $(eval $(call Assert_Template, \
|
|
|
|
$(a)_TESTBINOBJ, \
|
|
|
|
$(addprefix $(BIN_DIR)$(call lc,$(a))/$(TEST_DIR),$($(a)_TESTBIN)) \
|
|
|
|
)))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
2012-04-25 22:36:52 +00:00
|
|
|
define GenericTarget_Template
|
|
|
|
$(1): $(2)
|
|
|
|
endef
|
2012-03-28 02:25:11 +00:00
|
|
|
|
|
|
|
define TargetSource_Template
|
|
|
|
$(1): $(2)
|
|
|
|
@mkdir -p $(dir $(1)) $(DEP_DIR)
|
|
|
|
@echo "[cc]: $(1) <-- $(2)"
|
|
|
|
@$(CC) $(CFLAGS_A) $(addprefix -I./,$(3)) $(addprefix -D, $(4)) -c -o $(1) $(2)
|
|
|
|
endef
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
define TargetSourceList_Template
|
|
|
|
$(1): $(2)
|
|
|
|
@mkdir -p $(dir $(1)) $(DEP_DIR)
|
|
|
|
@echo "[cc]: $(1) <-- $(2)"
|
|
|
|
@$(CC) $(CFLAGS_A) $(addprefix -I./,$(3)) $(addprefix -D, $(4)) $(LIST_OPT) -c -o /dev/null $(2) > $(1)
|
|
|
|
endef
|
|
|
|
|
|
|
|
# ----------------------------------------------------------------------------
|
|
|
|
# Function: find_source_file
|
|
|
|
# Arguments: 1: name of the binary file (.o extension) to search
|
|
|
|
# 2: list of directorys to search for file
|
|
|
|
# Returns: Returns paths to source file (mathing the pattern in
|
|
|
|
# $(SOURCE_PATTERN)
|
|
|
|
# ----------------------------------------------------------------------------
|
|
|
|
SOURCE_PATTERN := %.S %.c
|
|
|
|
find_source_file = $(firstword $(foreach d, $(2), \
|
|
|
|
$(filter $(SOURCE_PATTERN), \
|
|
|
|
$(wildcard $(d)$(notdir $(patsubst %.o,%,$1)).*) \
|
|
|
|
) \
|
|
|
|
) )
|
|
|
|
|
|
|
|
|
|
|
|
$(foreach a, $(ALGORITHMS), \
|
|
|
|
$(foreach b, $($(a)_OBJ), \
|
|
|
|
$(eval $(call TargetSource_Template, \
|
|
|
|
$(BIN_DIR)$(call lc, $(a))/$(b), \
|
|
|
|
$(call find_source_file, $(b), $($(a)_DIR) $($(a)_INCDIR) $(GLOBAL_INCDIR) ),\
|
|
|
|
$($(a)_DIR) $($(a)_INCDIR) $(GLOBAL_INCDIR), \
|
|
|
|
$($(a)_DEF), \
|
|
|
|
)) \
|
|
|
|
) \
|
|
|
|
)
|
|
|
|
|
|
|
|
$(foreach a, $(ALGORITHMS), \
|
|
|
|
$(foreach b, $($(a)_TESTBIN), \
|
|
|
|
$(eval $(call TargetSource_Template, \
|
|
|
|
$(BIN_DIR)$(call lc, $(a))/$(TEST_DIR)$(b), \
|
|
|
|
$(call find_source_file, $(b), $($(a)_DIR) $($(a)_INCDIR) $(GLOBAL_INCDIR) ),\
|
|
|
|
$($(a)_DIR) $($(a)_INCDIR) $(GLOBAL_INCDIR), \
|
|
|
|
$($(a)_DEF) \
|
|
|
|
)) \
|
|
|
|
) \
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
$(foreach a, $(ALGORITHMS), \
|
|
|
|
$(foreach b, $($(a)_OBJ), \
|
|
|
|
$(eval $(call TargetSourceList_Template, \
|
|
|
|
$(LIST_DIR)$(call lc, $(a))/$(patsubst %.o,%.s,$(b)), \
|
|
|
|
$(call find_source_file, $(b), $($(a)_DIR) $($(a)_INCDIR) $(GLOBAL_INCDIR) ),\
|
|
|
|
$($(a)_DIR) $($(a)_INCDIR) $(GLOBAL_INCDIR), \
|
|
|
|
$($(a)_DEF), \
|
|
|
|
)) \
|
|
|
|
) \
|
|
|
|
)
|
|
|
|
|
|
|
|
EXTRALINK_BINOBJ = $(patsubst %, $(BIN_DIR)%, $(EXTRALINK))
|
|
|
|
|
|
|
|
$(foreach a, $(EXTRALINK), \
|
|
|
|
$(eval $(call TargetSource_Template, \
|
|
|
|
$(BIN_DIR)$(a), \
|
|
|
|
$(call find_source_file, $(a), $(GLOBAL_INCDIR) ),\
|
|
|
|
$($(a)_DIR) $($(a)_INCDIR) $(GLOBAL_INCDIR), \
|
|
|
|
$($(a)_DEF), \
|
|
|
|
)) \
|
|
|
|
)
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
define MainTestElf_Template
|
|
|
|
$(1): $(2) $(3) $(4)
|
|
|
|
@mkdir -p $(dir $(1))
|
|
|
|
@echo "[ld]: $(1)"
|
|
|
|
@$(CC) $(CFLAGS_A) $(LDFLAGS)$(patsubst %.elf,%.map,$(1)) -o \
|
|
|
|
$(1) \
|
|
|
|
$(2) $(3) $(EXTRALINK_BINOBJ)\
|
|
|
|
$(LIBS)
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach a, $(ALGORITHMS), \
|
|
|
|
$(eval $(call MainTestElf_Template, \
|
|
|
|
$(BIN_DIR)$(call lc, $(a))/$(TEST_DIR)main-$(call lc, $(a))-test.elf, \
|
|
|
|
$($(a)_BINOBJ), \
|
|
|
|
$($(a)_TESTBINOBJ), \
|
|
|
|
$(EXTRALINK_BINOBJ) \
|
|
|
|
)) \
|
|
|
|
)
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
all: $(foreach algo, $(ALGORITHMS), $($(algo)_BINOBJ))
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
define MakeDir_TEMPLATE
|
|
|
|
$(1):
|
|
|
|
@echo [mkdir] $(1)
|
|
|
|
@mkdir -p $(1)
|
|
|
|
endef
|
|
|
|
|
2012-04-25 22:36:52 +00:00
|
|
|
$(foreach d, DEP_DIR BIN_DIR TESTSRC_DIR TESTLOG_DIR SPEEDLOG_DIR SIZE_DIR LIST_DIR STAT_DIR, $(eval $(call MakeDir_TEMPLATE, \
|
2012-03-28 02:25:11 +00:00
|
|
|
$($(d)) \
|
|
|
|
)))
|
|
|
|
|
|
|
|
$(foreach algo, $(ALGORITHMS), $(eval $(call MakeDir__TEMPLATE, \
|
|
|
|
$(BIN_DIR)$(call lc, $(algo))/$(TEST_DIR) \
|
|
|
|
)))
|
|
|
|
|
|
|
|
define TestBin_TEMPLATE
|
|
|
|
$(1)_TESTBIN: $(2)
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach algo, $(ALGORITHMS), $(eval $(call TestBin_TEMPLATE, \
|
|
|
|
$(algo), \
|
2012-11-14 19:35:46 +00:00
|
|
|
$(BIN_DIR)$(call lc, $(algo))/$(TEST_DIR)main-$(call lc, $(algo))-test.hex \
|
2012-03-28 02:25:11 +00:00
|
|
|
)))
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
define Listing_TEMPLATE
|
|
|
|
$(1)_LIST: $(2)
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach algo, $(ALGORITHMS), $(eval $(call Listing_TEMPLATE, \
|
|
|
|
$(algo), \
|
|
|
|
$(foreach obj,$($(algo)_OBJ), $(LIST_DIR)$(call lc, $(algo))/$(obj:.o=.s)) \
|
|
|
|
)))
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
%.hex: %.elf
|
|
|
|
@echo "[objcopy]: $@"
|
|
|
|
@$(OBJCOPY) -j .text -j .data -O ihex $< $@
|
2012-11-14 19:35:46 +00:00
|
|
|
ifdef HASH_TOOL
|
|
|
|
ifneq ($(HASH_TOOL),)
|
|
|
|
@echo -n "[$(HASH_TOOL)]: "
|
2012-12-27 00:25:20 +00:00
|
|
|
@$(HASH_TOOL) $@
|
2012-11-14 19:35:46 +00:00
|
|
|
endif
|
|
|
|
endif
|
2012-03-28 02:25:11 +00:00
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
define Flash_Template
|
|
|
|
$(1)_FLASH: $(2)
|
|
|
|
@echo "[flash]: $(2)"
|
|
|
|
@$(FLASHCMD)$(call first,$(2))
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach algo, $(ALGORITHMS), $(eval $(call Flash_Template, \
|
|
|
|
$(algo), \
|
|
|
|
$(BIN_DIR)$(call lc, $(algo))/$(TEST_DIR)main-$(call lc, $(algo))-test.hex \
|
|
|
|
)))
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
define Speed_Template
|
|
|
|
$(1)_SPEED: $(1)_FLASH
|
|
|
|
@$(RUBY) $(SPEEDTOOL) -c $(SPEEDCMD) -t $(SPEEDLOG_DIR) -a $(call lc, $(1))
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach algo, $(ALGORITHMS), $(eval $(call Speed_Template, \
|
|
|
|
$(algo), $(algo) \
|
|
|
|
)))
|
|
|
|
|
|
|
|
.PHONY: hash_speed
|
|
|
|
hash_speed: $(foreach algo, $(HASHES), $(algo)_SPEED)
|
|
|
|
|
|
|
|
.PHONY: blockcipher_speed
|
|
|
|
blockcipher_speed: $(foreach algo, $(BLOCK_CIPHERS), $(algo)_SPEED)
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
2012-04-25 22:36:52 +00:00
|
|
|
define Size_Template
|
|
|
|
$(1): $(2)
|
|
|
|
@echo "[size] $(3)"
|
|
|
|
@mkdir -p $(dir $(1))
|
|
|
|
@$(SIZE) $(2) > $(1)
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach algo, $(ALGORITHMS), $(eval $(call Size_Template, \
|
|
|
|
$(strip $(SIZE_DIR))$(strip $(call lc, $(algo))).size,$($(algo)_BINOBJ),$(algo) \
|
|
|
|
)))
|
2012-03-28 02:25:11 +00:00
|
|
|
|
|
|
|
define Size_Template
|
|
|
|
$(1)_SIZE: $(2)
|
|
|
|
@echo "[size] $(1)"
|
2012-04-25 22:36:52 +00:00
|
|
|
@mkdir -p $(dir $(strip $(SIZE_DIR))$(strip $(call lc, $(1))).size)
|
|
|
|
@$(SIZE) $(2) > $(strip $(SIZE_DIR))$(strip $(call lc, $(1))).size
|
2012-03-28 02:25:11 +00:00
|
|
|
endef
|
|
|
|
|
2012-04-25 22:36:52 +00:00
|
|
|
$(foreach algo, $(ALGORITHMS), $(eval $(call GenericTarget_Template, \
|
|
|
|
$(strip $(algo))_SIZE,$(strip $(SIZE_DIR))$(strip $(call lc, $(algo))).size \
|
2012-03-28 02:25:11 +00:00
|
|
|
)))
|
|
|
|
|
|
|
|
.PHONY: hash_size
|
|
|
|
hash_size: $(foreach algo, $(HASHES), $(algo)_SIZE)
|
|
|
|
|
|
|
|
.PHONY: blockcipher_size
|
|
|
|
blockcipher_size: $(foreach algo, $(BLOCK_CIPHERS), $(algo)_SIZE)
|
|
|
|
|
2012-04-25 22:36:52 +00:00
|
|
|
.PHONY: size
|
|
|
|
size: $(foreach algo, $(ALGORITHMS), $(algo)_SIZE)
|
|
|
|
|
|
|
|
.PHONY: size_clean
|
|
|
|
size_clean:
|
|
|
|
rm -vf $(strip $(SIZE_DIR))*.size
|
|
|
|
|
2012-03-28 02:25:11 +00:00
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
.PHONY: tests
|
|
|
|
tests: $(foreach a, $(ALGORITHMS), $(a)_TESTBIN)
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
define TestRun_Template
|
|
|
|
$(1)_TESTRUN: $(1)_FLASH
|
|
|
|
@echo "[reset]"
|
|
|
|
@sleep 3
|
|
|
|
@$(RESETCMD)
|
|
|
|
@sleep 1
|
|
|
|
@echo "[test]: $(1)"
|
|
|
|
$(RUBY) $(GET_TEST) $(TESTPORT) $(TESTPORTBAUDR) 8 1 nessie $(TESTLOG_DIR)$(TESTPREFIX) $(2)
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach algo, $(ALGORITHMS),$(eval $(call TestRun_Template, $(algo), $(call lc,$(algo)) )))
|
|
|
|
|
|
|
|
all_testrun: $(foreach algo, $(ALGORITHMS), $(algo)_TESTRUN)
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
define Obj_Template
|
|
|
|
$(1)_OBJ: $(2)
|
|
|
|
endef
|
|
|
|
|
|
|
|
$(foreach algo, $(ALGORITHMS), \
|
|
|
|
$(eval $(call Obj_Template, \
|
|
|
|
$(algo), \
|
|
|
|
$($(algo)_BINOBJ)\
|
|
|
|
))\
|
|
|
|
)
|
|
|
|
|
|
|
|
.PHONY: all
|
|
|
|
all: cores
|
|
|
|
|
|
|
|
.PHONY: reset
|
|
|
|
reset:
|
|
|
|
$(RESETCMD)
|
|
|
|
|
|
|
|
.PHONY: cores
|
|
|
|
cores: $(foreach algo, $(ALGORITHMS), $(algo)_OBJ)
|
|
|
|
|
|
|
|
.PHONY: blockchiphers
|
|
|
|
blockciphers: $(foreach algo, $(BLOCK_CIPHERS), $(algo)_OBJ)
|
|
|
|
|
|
|
|
.PHONY: streamchiphers
|
|
|
|
streamciphers: $(foreach algo, $(STREAM_CIPHERS), $(algo)_OBJ)
|
|
|
|
|
|
|
|
.PHONY: hashes
|
|
|
|
hashes: $(foreach algo, $(HASHES), $(algo)_OBJ)
|
|
|
|
|
|
|
|
.PHONY: macs
|
|
|
|
macs: $(foreach algo, $(MACS), $(algo)_OBJ)
|
|
|
|
|
|
|
|
.PHONY: prngs
|
|
|
|
prngs: $(foreach algo, $(PRNGS), $(algo)_OBJ)
|
|
|
|
|
|
|
|
.PHONY: encodings
|
|
|
|
encodings: $(foreach algo, $(ENCODINGS), $(algo)_OBJ)
|
|
|
|
|
|
|
|
.PHONY: aux
|
|
|
|
aux: $(foreach algo, $(AUX), $(algo)_OBJ)
|
|
|
|
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
.PHONY: help
|
|
|
|
help: info
|
|
|
|
.PHONY: info
|
|
|
|
info:
|
|
|
|
@echo "infos on AVR-Crypto-lib:"
|
|
|
|
@echo " block ciphers:"
|
|
|
|
@echo " $(BLOCK_CIPHERS)"
|
|
|
|
@echo " stream ciphers:"
|
|
|
|
@echo " $(STREAM_CIPHERS)"
|
|
|
|
@echo " hash functions:"
|
|
|
|
@echo " $(HASHES)"
|
|
|
|
@echo " MAC functions:"
|
|
|
|
@echo " $(MACS)"
|
|
|
|
@echo " PRNG functions:"
|
|
|
|
@echo " $(PRNGS)"
|
|
|
|
@echo " signature functions:"
|
|
|
|
@echo " $(SIGNATURE)"
|
|
|
|
@echo " public key ciphers:"
|
|
|
|
@echo " $(PK_CIPHERS)"
|
|
|
|
@echo " encodings:"
|
|
|
|
@echo " $(ENCODINGS)"
|
|
|
|
@echo " auxiliary functions:"
|
|
|
|
@echo " $(AUX)"
|
|
|
|
@echo " targets:"
|
|
|
|
@echo " all - all algorithm cores"
|
|
|
|
@echo " cores - all algorithm cores"
|
|
|
|
@echo " listings - all algorithm core listings"
|
|
|
|
@echo " tests - all algorithm test programs"
|
2012-04-25 22:36:52 +00:00
|
|
|
@echo " size - all algorithm size statistics"
|
2012-03-28 02:25:11 +00:00
|
|
|
@echo " blockciphers - all blockcipher cores"
|
|
|
|
@echo " streamciphers - all streamcipher cores"
|
|
|
|
@echo " hashes - all hash cores"
|
|
|
|
@echo " macs - all MAC cores"
|
|
|
|
@echo " prngs - all PRNG cores"
|
|
|
|
@echo " all_testrun - testrun all algorithms"
|
|
|
|
@echo " hash_size - measure size of all hash functions"
|
|
|
|
@echo " hash_speed - measure performance of all hash functions"
|
|
|
|
@echo " blockcipher_size - measure size of all blockciphers"
|
|
|
|
@echo " blockcipher_speed - measure performance of all blockciphers"
|
|
|
|
@echo " docu - build doxygen documentation"
|
|
|
|
@echo " clean - remove a lot of builded files"
|
|
|
|
@echo " depclean - also remove dependency files"
|
|
|
|
@echo " *_TESTBIN - build test program"
|
|
|
|
@echo " *_TESTRUN - run nessie test"
|
|
|
|
@echo " *_OBJ - build algorithm core"
|
|
|
|
@echo " *_FLASH - flash test program"
|
|
|
|
@echo " *_LIST - build assembler listing"
|
|
|
|
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
|
|
|
rm -rf $(BIN_DIR)*
|
|
|
|
|
|
|
|
.PHONY: depclean
|
|
|
|
depclean: clean
|
|
|
|
rm -f $(DEP_DIR)*.d
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
# dependency inclusion
|
|
|
|
#
|
|
|
|
|
|
|
|
DEPS := $(wildcard $(DEP_DIR)*.d)
|
|
|
|
|
|
|
|
ifneq ($(DEPS),)
|
|
|
|
include $(DEPS)
|
|
|
|
endif
|
|
|
|
|