2018-05-07 00:14:52 +00:00
|
|
|
#define uECC_arch_other 0
|
|
|
|
#define uECC_x86 1
|
|
|
|
#define uECC_x86_64 2
|
|
|
|
#define uECC_arm 3
|
|
|
|
#define uECC_arm_thumb 4
|
|
|
|
#define uECC_arm_thumb2 5
|
|
|
|
#define uECC_arm64 6
|
|
|
|
#define uECC_avr 7
|
|
|
|
|
|
|
|
platform=2
|
|
|
|
|
2018-08-09 23:39:50 +00:00
|
|
|
EFM32_DEBUGGER= -s 440083537 --device EFM32JG1B200F128GM32
|
|
|
|
#EFM32_DEBUGGER= -s 440121060 #dev board
|
|
|
|
|
2018-07-10 03:50:21 +00:00
|
|
|
src = $(wildcard pc/*.c) $(wildcard fido2/*.c) $(wildcard crypto/sha256/*.c) crypto/tiny-AES-c/aes.c
|
2018-05-07 00:14:52 +00:00
|
|
|
obj = $(src:.c=.o) uECC.o
|
2018-04-28 17:40:28 +00:00
|
|
|
|
2018-09-15 21:40:33 +00:00
|
|
|
LIBCBOR = tinycbor/lib/libtinycbor.a
|
|
|
|
LDFLAGS = -Wl,--gc-sections $(LIBCBOR)
|
2018-07-10 03:50:21 +00:00
|
|
|
CFLAGS = -O2 -fdata-sections -ffunction-sections
|
|
|
|
|
2018-09-13 02:32:58 +00:00
|
|
|
INCLUDES = -I./tinycbor/src -I./crypto/sha256 -I./crypto/micro-ecc/ -Icrypto/tiny-AES-c/ -I./fido2/ -I./pc -I./fido2/extensions
|
2018-07-10 03:50:21 +00:00
|
|
|
|
|
|
|
CFLAGS += $(INCLUDES)
|
2018-04-28 17:40:28 +00:00
|
|
|
|
|
|
|
name = main
|
|
|
|
|
2018-09-15 21:40:33 +00:00
|
|
|
.PHONY: all
|
2018-05-26 15:36:55 +00:00
|
|
|
all: main
|
|
|
|
|
2018-09-15 21:40:33 +00:00
|
|
|
|
|
|
|
tinycbor/Makefile crypto/tiny-AES-c/aes.h:
|
|
|
|
git submodule update --init
|
|
|
|
|
|
|
|
.PHONY: cbor
|
|
|
|
cbor: $(LIBCBOR)
|
|
|
|
|
|
|
|
$(LIBCBOR): tinycbor/Makefile
|
2018-07-10 03:50:21 +00:00
|
|
|
cd tinycbor/ && $(MAKE) clean && $(MAKE) -j8
|
|
|
|
|
2018-09-15 21:40:33 +00:00
|
|
|
.PHONY: test
|
2018-05-26 15:36:55 +00:00
|
|
|
test: testgcm
|
|
|
|
|
2018-07-03 03:10:23 +00:00
|
|
|
efm8prog:
|
2018-09-13 01:25:40 +00:00
|
|
|
cd './targets/efm8\Keil 8051 v9.53 - Debug' && $(MAKE) all
|
2018-07-04 16:48:18 +00:00
|
|
|
flashefm8.exe -part EFM8UB10F8G -sn 440105518 -erase
|
2018-09-13 01:25:40 +00:00
|
|
|
flashefm8.exe -part EFM8UB10F8G -sn 440105518 -upload './targets/efm8/Keil 8051 v9.53 - Debug/efm8.hex'
|
2018-07-03 03:10:23 +00:00
|
|
|
|
2018-07-14 00:29:14 +00:00
|
|
|
efm32com:
|
2018-09-13 01:25:40 +00:00
|
|
|
cd './targets/efm32/GNU ARM v7.2.1 - Debug' && $(MAKE) all
|
2018-07-03 03:10:23 +00:00
|
|
|
efm32prog:
|
2018-09-13 01:25:40 +00:00
|
|
|
cd './targets/efm32/GNU ARM v7.2.1 - Debug' && $(MAKE) all
|
|
|
|
commander flash './targets/efm32/GNU ARM v7.2.1 - Debug/EFM32.hex' $(EFM32_DEBUGGER) -p "0x1E7FC:0x00000000:4"
|
2018-08-09 23:39:50 +00:00
|
|
|
efm32read:
|
2018-09-13 01:25:40 +00:00
|
|
|
cd './targets/efm32/GNU ARM v7.2.1 - Debug' && $(MAKE) all
|
2018-08-09 23:39:50 +00:00
|
|
|
commander swo read $(EFM32_DEBUGGER)
|
|
|
|
|
|
|
|
|
2018-07-03 03:10:23 +00:00
|
|
|
|
2018-07-15 03:03:25 +00:00
|
|
|
efm32bootprog:
|
2018-09-13 01:25:40 +00:00
|
|
|
cd './targets/efm32boot/GNU ARM v7.2.1 - Debug' && $(MAKE) all
|
|
|
|
commander flash './efm32boot/GNU ARM v7.2.1 - Debug/efm32boot.hex' $(EFM32_DEBUGGER) --masserase
|
2018-07-15 03:03:25 +00:00
|
|
|
|
2018-09-15 21:40:33 +00:00
|
|
|
|
|
|
|
crypto/tiny-AES-c/aes.o:
|
|
|
|
if ! grep "^#define AES256" crypto/tiny-AES-c/aes.h ; then \
|
|
|
|
echo "Fixing crypto/tiny-AES-c/aes.h" ;\
|
|
|
|
sed -i 's/^#define AES1\/\/#define AES1; s/^\/*#define AES256/#define AES256/' crypto/tiny-AES-c/aes.h ;\
|
|
|
|
fi
|
|
|
|
$(CC) $(CFLAGS) -c -o crypto/tiny-AES-c/aes.o crypto/tiny-AES-c/aes.c
|
|
|
|
|
|
|
|
|
|
|
|
$(name): $(obj) $(LIBCBOR)
|
2018-04-28 17:40:28 +00:00
|
|
|
$(CC) $(LDFLAGS) -o $@ $(obj) $(LDFLAGS)
|
2018-05-03 02:52:41 +00:00
|
|
|
|
2018-09-15 21:40:33 +00:00
|
|
|
testgcm: $(obj) $(LIBCBOR)
|
2018-05-26 15:36:55 +00:00
|
|
|
$(CC) -c main.c $(CFLAGS) -DTEST -o main.o
|
|
|
|
$(CC) -c crypto/aes_gcm.c $(CFLAGS) -DTEST -o crypto/aes_gcm.o
|
|
|
|
$(CC) $(LDFLAGS) -o $@ $^ $(LDFLAGS)
|
|
|
|
|
2018-05-07 00:14:52 +00:00
|
|
|
uECC.o: ./crypto/micro-ecc/uECC.c
|
|
|
|
$(CC) -c -o $@ $^ -O2 -fdata-sections -ffunction-sections -DuECC_PLATFORM=$(platform) -I./crypto/micro-ecc/
|
|
|
|
|
2018-05-03 02:52:41 +00:00
|
|
|
clean:
|
2018-09-03 04:47:38 +00:00
|
|
|
rm -f *.o main.exe main $(obj)
|
2018-09-15 21:40:33 +00:00
|
|
|
for f in crypto/tiny-AES-c/Makefile tinycbor/Makefile ; do \
|
|
|
|
if [ -f "$$f" ]; then \
|
|
|
|
(cd `dirname $$f` ; git co -- .) ;\
|
|
|
|
fi ;\
|
|
|
|
done
|
|
|
|
|