summaryrefslogtreecommitdiffstats
path: root/firmware/decompressor/Makefile
blob: 357b855c41046ed103e3f87e706dc4e367755efa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#             __________               __   ___.
#   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
#   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
#   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
#   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
#                     \/            \/     \/    \/            \/
# $Id$
#

ifndef V
SILENT=@
endif

LDS := link.lds
LINKFILE = $(OBJDIR)/linkage.lds
OBJS := $(OBJDIR)/decompressor.o $(OBJDIR)/uclimage.o $(OBJDIR)/startup.o
CFLAGS = $(GCCOPTS)

all: $(OBJDIR)/compressed.bin

$(OBJDIR)/compressed.bin : $(OBJDIR)/compressed.elf
	@echo "OBJCOPY $(notdir $@)"
	$(SILENT)$(OC) -O binary $< $@

$(OBJDIR)/compressed.elf : $(OBJS) $(LINKFILE)
	@echo "LD $(notdir $@)"
	$(SILENT)$(CC) $(GCCOPTS) -Os -nostdlib -o $@ $(OBJS) -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/compressed.map

$(LDS): $(OBJS)
	

$(LINKFILE): $(LDS)
	@echo "Build LDS file"
	$(SILENT)cat $< | $(CC) -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) $(TARGET) $(DEFINES) -E -P $(ROMBUILD) - >$@

$(OBJDIR)/decompressor.o : decompressor.c $(OBJDIR)/uclimage.c
	$(SILENT)mkdir -p $(dir $@)
	@echo "CC $<"
	$(SILENT)$(CC) $(CFLAGS) -I$(OBJDIR) -c $< -o $@

$(OBJDIR)/startup.o : startup.S
	$(SILENT)mkdir -p $(dir $@)
	@echo "AS $<"
	$(SILENT)$(CC) $(CFLAGS) -c $< -o $@

$(OBJDIR)/uclimage.o : $(OBJDIR)/uclimage.c
	$(SILENT)mkdir -p $(dir $@)
	@echo "CC $(notdir $<)"
	$(SILENT)$(CC) $(CFLAGS) -c $< -o $@

$(OBJDIR)/uclimage.c : $(FLASHFILE)  $(TOOLSDIR)/ucl2src.pl
	$(SILENT)mkdir -p $(dir $@)
	@echo "UCL2SRC"
	$(SILENT)perl -s $(TOOLSDIR)/ucl2src.pl -p=$(OBJDIR)/uclimage $<