2009-04-22 01:24:42 +08:00
|
|
|
# This makefile needs to be edited to reflect the location
|
2009-06-29 05:31:35 +08:00
|
|
|
# of your own arm-elf-gcc toolchain (ARMLIB variable)
|
2009-04-22 01:24:42 +08:00
|
|
|
|
|
|
|
CC = arm-elf-gcc
|
|
|
|
AS = arm-elf-as
|
|
|
|
LD = arm-elf-ld
|
|
|
|
OBJCOPY = arm-elf-objcopy
|
|
|
|
|
2009-06-29 05:31:35 +08:00
|
|
|
# Indicate where your gnuarm toolchain libgcc.a interworking library is located
|
|
|
|
# or set $ARMLIB in your environment:
|
|
|
|
#ARMLIB = /usr/local/lib/gcc/arm-elf/4.3.3/interwork
|
|
|
|
|
2009-04-22 01:24:42 +08:00
|
|
|
|
2009-04-26 05:19:59 +08:00
|
|
|
# Add -DWITH_LCD to EXTRA_CFLAGS if you want support for LCD
|
|
|
|
# in your firmware (add OBJLCD to OBJ too!)
|
|
|
|
#EXTRA_CFLAGS = -DWITH_LCD
|
|
|
|
EXTRA_CFLAGS =
|
|
|
|
|
|
|
|
### You should not need to edit below this line
|
|
|
|
|
|
|
|
INCLUDE = -I../include
|
|
|
|
INCLUDES = ../include/proxmark3.h ../include/at91sam7s128.h ../include/config_gpio.h ../include/usb_cmd.h apps.h
|
2009-04-22 01:24:42 +08:00
|
|
|
CFLAGS_COMMON = -O6 -c $(INCLUDE) -Wall -mthumb-interwork
|
2009-04-26 05:19:59 +08:00
|
|
|
CFLAGS = $(CFLAGS_COMMON) $(EXTRA_CFLAGS) -mthumb
|
2009-04-22 01:24:42 +08:00
|
|
|
|
|
|
|
|
|
|
|
OBJDIR = obj
|
|
|
|
|
2009-04-26 05:19:59 +08:00
|
|
|
OBJLCD = $(OBJDIR)/LCD.o\
|
|
|
|
$(OBJDIR)/fonts.o
|
|
|
|
|
|
|
|
OBJ = $(OBJDIR)/start.o \
|
|
|
|
$(OBJDIR)/appmain.o \
|
|
|
|
$(OBJDIR)/fpga.o \
|
2009-07-25 19:47:43 +08:00
|
|
|
$(OBJDIR)/lfops.o \
|
2009-04-26 05:19:59 +08:00
|
|
|
$(OBJDIR)/iso15693.o \
|
|
|
|
$(OBJDIR)/util.o
|
2009-04-22 01:24:42 +08:00
|
|
|
|
2009-04-26 22:26:06 +08:00
|
|
|
# To be compiled in ARM mode, not thumb mode: larger but faster
|
|
|
|
# Alleviates the 'blew circular buffer' issues somehow...
|
|
|
|
OBJFAST = $(OBJDIR)/iso14443.o \
|
|
|
|
$(OBJDIR)/iso14443a.o
|
2009-04-22 01:24:42 +08:00
|
|
|
|
2009-04-26 05:19:59 +08:00
|
|
|
OBJFPGA = $(OBJDIR)/fpgaimg.o
|
|
|
|
|
|
|
|
OBJCOMMON = $(OBJDIR)/usb.o
|
2009-04-22 01:24:42 +08:00
|
|
|
|
|
|
|
all: osimage.s19 fpgaimage.s19 fullimage.s19
|
|
|
|
|
|
|
|
fpgaimage.s19: $(OBJFPGA)
|
|
|
|
@echo fpgaimage.s19
|
2009-04-26 05:19:59 +08:00
|
|
|
$(LD) -g -Tldscript-fpga -o $(OBJDIR)/fpgaimage.elf $^
|
|
|
|
$(OBJCOPY) -Osrec --srec-forceS3 $(OBJDIR)/fpgaimage.elf fpgaimage.s19
|
2009-04-22 01:24:42 +08:00
|
|
|
|
|
|
|
osimage.s19: $(OBJ) $(OBJFAST) $(OBJCOMMON)
|
|
|
|
@echo osimage.s19
|
2009-07-30 00:03:16 +08:00
|
|
|
$(LD) -g -Tldscript -o $(OBJDIR)/osimage.elf -Map=osimage.map $^ $(ARMLIB)/libgcc.a
|
2009-04-26 05:19:59 +08:00
|
|
|
$(OBJCOPY) -Osrec --srec-forceS3 $(OBJDIR)/osimage.elf osimage.s19
|
2009-04-22 01:24:42 +08:00
|
|
|
|
|
|
|
fullimage.s19: $(OBJ) $(OBJFAST) $(OBJCOMMON) $(OBJFAST) $(OBJFPGA)
|
|
|
|
@echo fullimage.s19
|
2009-06-29 05:31:35 +08:00
|
|
|
$(LD) -g -Tldscript-full -o $(OBJDIR)/fullimage.elf $^ $(ARMLIB)/libgcc.a
|
2009-04-26 05:19:59 +08:00
|
|
|
$(OBJCOPY) -Osrec --srec-forceS3 $(OBJDIR)/fullimage.elf fullimage.s19
|
2009-04-22 01:24:42 +08:00
|
|
|
|
2009-04-26 05:19:59 +08:00
|
|
|
# Directives to put the *.o in the OBJDIR directory:
|
|
|
|
$(OBJ): $(OBJDIR)/%.o : %.c
|
|
|
|
$(CC) $(CFLAGS) $< -o $@
|
2009-04-22 01:24:42 +08:00
|
|
|
|
2009-04-26 05:19:59 +08:00
|
|
|
$(OBJFPGA): $(OBJDIR)/%.o : %.c
|
|
|
|
$(CC) $(CFLAGS) $< -o $@
|
2009-04-22 01:24:42 +08:00
|
|
|
|
2009-04-26 05:19:59 +08:00
|
|
|
$(OBJFAST): $(OBJDIR)/%.o : %.c
|
|
|
|
$(CC) $(CFLAGS_COMMON) $< -o $@
|
2009-04-22 01:24:42 +08:00
|
|
|
|
2009-04-26 05:19:59 +08:00
|
|
|
$(OBJCOMMON): $(OBJDIR)/%.o : ../common/%.c
|
|
|
|
$(CC) $(CFLAGS) $< -o $@
|
2009-04-22 01:24:42 +08:00
|
|
|
|
2009-07-12 18:02:57 +08:00
|
|
|
flash-both: flash flash-fpga
|
|
|
|
|
2009-04-22 01:24:42 +08:00
|
|
|
flash-fpga: fpgaimage.s19
|
|
|
|
../linux/flasher fpga fpgaimage.s19
|
|
|
|
|
|
|
|
flash: osimage.s19
|
|
|
|
../linux/flasher os osimage.s19
|
|
|
|
|
2009-07-12 18:02:57 +08:00
|
|
|
# Those do not work on the current firmware !
|
2009-04-22 01:24:42 +08:00
|
|
|
jtag-flash-full: fullimage.s19
|
|
|
|
../../OpenOCD/openocd -c "halt; flash write_image fullimage.s19 0x00100000; halt; reset; resume; poll; exit"
|
|
|
|
|
|
|
|
jtag-flash-fpga: fpgaimage.s19
|
|
|
|
../../OpenOCD/openocd -c "halt; flash write_image fpgaimage.s19 0x00100000; halt; reset; resume; poll; exit"
|
|
|
|
|
|
|
|
jtag-flash: osimage.s19
|
|
|
|
../../OpenOCD/openocd -c "halt; flash write_image osimage.s19 0x00100000; halt; reset; resume; poll; exit"
|
|
|
|
|
|
|
|
clean:
|
2009-07-30 00:03:16 +08:00
|
|
|
rm -f $(OBJDIR)/*.o $(OBJDIR)/*.elf *.s19 osimage.map
|
2009-04-22 01:24:42 +08:00
|
|
|
|
|
|
|
.PHONY: all clean
|