blob: fa94eac9b1deeadf0db0d461fb510a84a8be4f57 [file] [log] [blame]
Björn Stenbergd42d78f2002-04-15 08:35:08 +00001# __________ __ ___.
2# Open \______ \ ____ ____ | | _\_ |__ _______ ___
3# Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
4# Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
5# Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
6# \/ \/ \/ \/ \/
7# $Id$
8#
Linus Nielsen Feltzing1dc42d12003-05-17 00:31:50 +00009
Tomasz Malesinski2aabc872006-01-25 01:43:07 +000010ifeq ($(ARCHOS),ifp7xx)
11
12INCLUDES= -I$(FIRMDIR)/include -I$(FIRMDIR)/export -I. -I$(OBJDIR) \
13 -I$(BUILDDIR)
14
15DEPFILE = $(OBJDIR)/dep-stub
16LDS := linker.cfg
17
18SRC := $(shell cat SOURCES | $(CC) -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) $(TARGET) $(DEFINES) -E -P -include "config.h" - )
19DIRS = .
20
21ifdef APPEXTRA
22 DIRS += $(subst :, ,$(APPEXTRA))
23 INCLUDES += $(patsubst %,-I%,$(subst :, ,$(APPEXTRA)))
24endif
25
26ifndef VERSION
27VERSION=$(shell date +%y%m%d-%H%M)
28endif
29
30CFLAGS = $(GCCOPTS) $(INCLUDES) $(TARGET) $(DEFINES) \
31 -DAPPSVERSION=\"$(VERSION)\" $(EXTRA_DEFINES) -DMEM=${MEMORYSIZE}
32
33OBJS := $(SRC:%.c=$(OBJDIR)/%.o)
34SOURCES = $(SRC)
35LINKFILE = $(OBJDIR)/linkage.lds
36
37LIBROCKBOX = $(BUILDDIR)/librockbox.a
38
39all: $(BUILDDIR)/$(BINARY) $(FLASHFILE)
40
41dep: $(DEPFILE)
42
43$(LINKFILE): $(LDS)
44 @echo "Build LDS file"
45 @cat $< | $(CC) -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) $(TARGET) $(DEFINES) -E -P $(ROMBUILD) - >$@
46
47$(OBJDIR)/stub.elf : $(OBJS) $(LINKFILE) $(DEPFILE) $(LIBROCKBOX)
48 @echo "LD stub.elf"
49 @$(CC) $(GCCOPTS) -Os -nostdlib -o $@ $(OBJS) -L$(BUILDDIR) -L$(BUILDDIR)/firmware -lrockbox -lgcc -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/stub.map
50
51$(OBJDIR)/stub.bin : $(OBJDIR)/stub.elf
52 @echo "OBJCOPY $<"
53 @$(OC) -O binary $< $@
54
55$(BUILDDIR)/$(BINARY) : $(OBJDIR)/stub.bin
56 @echo "Build stub file"
57 $(MKFIRMWARE) $< $@
58
59include $(TOOLSDIR)/make.inc
60
61clean:
62 @echo "cleaning stub"
63 @-rm -f $(OBJS) $(BUILDDIR)/$(BINARY) \
64 $(OBJDIR)/stub.bin $(OBJDIR)/stub.elf $(OBJDIR)/*.map \
65 $(LINKFILE) $(DEPFILE)
66
67-include $(DEPFILE)
68
69else # not ifp7xx
70
Linus Nielsen Feltzing1dc42d12003-05-17 00:31:50 +000071ifdef RECORDER
72EXTRA = -DRECORDER
73EXT = ajz
74else
75EXT = mod
76endif
77
Björn Stenbergd42d78f2002-04-15 08:35:08 +000078TARGET = stub
Linus Nielsen Feltzing1dc42d12003-05-17 00:31:50 +000079OBJS = start.o sh-stub.o setjmp.o
Björn Stenbergd42d78f2002-04-15 08:35:08 +000080LIBS = -lgcc
81
82.s.o:
83 sh-elf-as -o $@ $<
84
85.c.o:
Linus Nielsen Feltzing1dc42d12003-05-17 00:31:50 +000086 sh-elf-gcc -O $(EXTRA) -I../firmware/export -I../firmware/include -m1 -Wall -Wstrict-prototypes -c -o $@ $<
Björn Stenbergd42d78f2002-04-15 08:35:08 +000087
Linus Nielsen Feltzing1dc42d12003-05-17 00:31:50 +000088.S.o:
89 sh-elf-gcc -O -I../firmware/export -I../firmware/include -m1 -Wall -Wstrict-prototypes -c -o $@ $<
90
91$(TARGET).$(EXT): $(TARGET).elf
Björn Stenbergd42d78f2002-04-15 08:35:08 +000092 sh-elf-objcopy -O binary $(TARGET).elf $(TARGET).out
Linus Nielsen Feltzing1dc42d12003-05-17 00:31:50 +000093 ../tools/scramble $(TARGET).out $(TARGET).$(EXT)
Jörg Hohensohn09e42d52003-06-29 21:56:32 +000094 ../tools/sh2d $(TARGET).out -o 09000000 > $(TARGET).asm
Björn Stenbergd42d78f2002-04-15 08:35:08 +000095
96$(TARGET).elf: $(OBJS)
Linus Nielsen Feltzing1dc42d12003-05-17 00:31:50 +000097 sh-elf-gcc -nostartfiles $(OBJS) -nostdlib -Wl,-Map,$(TARGET).map -o $(TARGET).elf -Tlinker.cfg
Björn Stenbergd42d78f2002-04-15 08:35:08 +000098
99clean:
Linus Nielsen Feltzing1dc42d12003-05-17 00:31:50 +0000100 rm $(OBJS) $(TARGET).map $(TARGET).elf $(TARGET).out $(TARGET).mod $(TARGET).ajz
Björn Stenbergd42d78f2002-04-15 08:35:08 +0000101
Tomasz Malesinski2aabc872006-01-25 01:43:07 +0000102start.o: start.s
Linus Nielsen Feltzing7958ea42002-05-11 20:04:48 +0000103sh-stub.o: sh-stub.c
Linus Nielsen Feltzing1dc42d12003-05-17 00:31:50 +0000104setjmp.o: setjmp.S
Tomasz Malesinski2aabc872006-01-25 01:43:07 +0000105
106endif