1 #-----------------------------------------------------------------------------
 
   2 # This code is licensed to you under the terms of the GNU GPL, version 2 or,
 
   3 # at your option, any later version. See the LICENSE.txt file for the text of
 
   5 #-----------------------------------------------------------------------------
 
   6 # Makefile for armsrc, see ../common/Makefile.common for common settings
 
   7 #-----------------------------------------------------------------------------
 
  11 #remove one of the following defines and comment out the relevant line
 
  12 #in the next section to remove that particular feature from compilation  
 
  13 APP_CFLAGS      = -O6 -DWITH_LF -DWITH_ISO15693 -DWITH_ISO14443a -DWITH_ISO14443b
 
  16 #SRC_LCD = fonts.c LCD.c
 
  17 SRC_LF = lfops.c hitag2.c
 
  18 SRC_ISO15693 = iso15693.c
 
  19 SRC_ISO14443a = iso14443a.c
 
  20 SRC_ISO14443b = iso14443.c
 
  31 # These are to be compiled in ARM mode
 
  32 ARMSRC = fpgaloader.c \
 
  41 # stdint.h provided locally until GCC 4.5 becomes C99 compliant
 
  44 # Do not move this inclusion before the definition of {THUMB,ASM,ARM}SRC
 
  45 include ../common/Makefile.common
 
  47 all: $(OBJDIR)/osimage.s19 $(OBJDIR)/fpgaimage.s19
 
  49 $(OBJDIR)/fpga.o: fpga.bit
 
  50         $(OBJCOPY) -O elf32-littlearm -I binary -B arm --redefine-sym _binary____fpga_fpga_bit_start=_binary_fpga_bit_start --redefine-sym _binary____fpga_fpga_bit_end=_binary_fpga_bit_end --prefix-sections=fpga_bit  $^ $@
 
  52 $(OBJDIR)/fullimage.elf: $(VERSIONOBJ) $(OBJDIR)/fpga.o $(THUMBOBJ) $(ARMOBJ) $(LIBGCC)
 
  53         $(LD) -g -Tldscript -Map=$(patsubst %.elf,%.map,$@) -o $@ $^
 
  55 $(OBJDIR)/fpgaimage.elf: $(OBJDIR)/fullimage.elf
 
  56         $(OBJCOPY) -F elf32-littlearm --only-section .fpgaimage $^ $@  
 
  58 $(OBJDIR)/osimage.elf: $(OBJDIR)/fullimage.elf
 
  59         $(OBJCOPY) -F elf32-littlearm --remove-section .fpgaimage $^ $@
 
  62         $(DELETE) $(OBJDIR)$(PATHSEP)*.o
 
  63         $(DELETE) $(OBJDIR)$(PATHSEP)*.elf
 
  64         $(DELETE) $(OBJDIR)$(PATHSEP)*.s19
 
  65         $(DELETE) $(OBJDIR)$(PATHSEP)*.map
 
  66         $(DELETE) $(OBJDIR)$(PATHSEP)*.d
 
  69 .PHONY: all clean help
 
  71         @echo Multi-OS Makefile, you are running on $(DETECTED_OS)
 
  72         @echo Possible targets:
 
  73         @echo + all               - Make both:
 
  74         @echo + $(OBJDIR)/osimage.s19   - The OS image
 
  75         @echo + $(OBJDIR)/fpgaimage.s19 - The FPGA image
 
  76         @echo + clean             - Clean $(OBJDIR)