1
0
Fork 0
forked from len0rd/rockbox

rombox support: building and zip

general makefile: less output


git-svn-id: svn://svn.rockbox.org/rockbox/trunk@5043 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Daniel Stenberg 2004-09-06 07:05:12 +00:00
parent 0dfc2c9dcd
commit 678090a2e7
8 changed files with 142 additions and 54 deletions

View file

@ -44,6 +44,7 @@ ifdef ARCHOS_ROM
endif endif
LDS := $(FIRMWARE)/app.lds LDS := $(FIRMWARE)/app.lds
ROMLDS := $(FIRMWARE)/rom.lds
ifdef DEBUG ifdef DEBUG
DEFINES := -DDEBUG DEFINES := -DDEBUG
@ -54,15 +55,23 @@ SRC := $(wildcard *.c)
ifeq ($(TARGET), -DARCHOS_FMRECORDER) ifeq ($(TARGET), -DARCHOS_FMRECORDER)
TOOL_OPT = -fm TOOL_OPT = -fm
MAXROMSIZE = 180208 # 176KB -16
endif endif
ifeq ($(TARGET), -DARCHOS_RECORDERV2) ifeq ($(TARGET), -DARCHOS_RECORDERV2)
TOOL_OPT = -v2 TOOL_OPT = -v2
MAXROMSIZE = 188400 # 184KB - 16
endif endif
ifeq ($(TARGET), -DARCHOS_RECORDER)
MAXROMSIZE = 192496 # 188KB - 16
endif
ifeq ($(ANYREC), RECORDER) ifeq ($(ANYREC), RECORDER)
SRC += $(wildcard recorder/*.c) SRC += $(wildcard recorder/*.c)
CFLAGS += -Irecorder CFLAGS += -Irecorder
OUTNAME = ajbrec.ajz OUTNAME = ajbrec.ajz
# set the ROMTARGET here to make this get built only on recorders
ROMTARGET := $(OBJDIR)/rombox.ucl
else else
ifeq ($(TARGET), -DARCHOS_PLAYER) ifeq ($(TARGET), -DARCHOS_PLAYER)
SRC += $(wildcard player/*.c) SRC += $(wildcard player/*.c)
@ -80,6 +89,7 @@ endif
OBJS := $(OBJDIR)/lang.o $(SRC:%.c=$(OBJDIR)/%.o) OBJS := $(OBJDIR)/lang.o $(SRC:%.c=$(OBJDIR)/%.o)
LINKFILE = $(OBJDIR)/linkage.lds LINKFILE = $(OBJDIR)/linkage.lds
LINKROM = $(OBJDIR)/linkrom.lds
ifndef OBJDIR ifndef OBJDIR
no_configure: no_configure:
@ -97,7 +107,7 @@ endif
ifdef DEBUG ifdef DEBUG
all : $(OBJDIR)/rockbox.elf rocks all : $(OBJDIR)/rockbox.elf rocks
else else
all : $(OBJDIR)/$(OUTNAME) $(OBJDIR)/rockbox.ucl rocks all : $(OBJDIR)/$(OUTNAME) $(OBJDIR)/rockbox.ucl rocks $(ROMTARGET)
endif endif
rocks: rocks:
@ -112,11 +122,24 @@ $(OBJDIR)/librockbox.a:
$(LINKFILE): $(LDS) $(LINKFILE): $(LDS)
cat $< | $(CC) -DMEMORYSIZE=$(MEM) $(INCLUDES) $(TARGET) $(DEFINES) -E -P $(ROMBUILD) - >$@ cat $< | $(CC) -DMEMORYSIZE=$(MEM) $(INCLUDES) $(TARGET) $(DEFINES) -E -P $(ROMBUILD) - >$@
$(LINKROM): $(ROMLDS)
cat $< | $(CC) -DMEMORYSIZE=$(MEM) $(INCLUDES) $(TARGET) $(DEFINES) -E -P $(ROMBUILD) - >$@
$(OBJDIR)/rombox.elf : $(OBJS) $(LINKROM) $(OBJDIR)/librockbox.a
@echo "LD rombox.elf"
@$(CC) -Os -nostdlib -o $@ $(OBJS) -L$(OBJDIR) -lrockbox -lgcc -L$(FIRMWARE) -T$(LINKROM) -Wl,-Map,$(OBJDIR)/rombox.map
$(OBJDIR)/rockbox.elf : $(OBJS) $(LINKFILE) $(OBJDIR)/librockbox.a $(OBJDIR)/rockbox.elf : $(OBJS) $(LINKFILE) $(OBJDIR)/librockbox.a
$(CC) -Os -nostdlib -o $@ $(OBJS) -L$(OBJDIR) -lrockbox -lgcc -L$(FIRMWARE) -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/rockbox.map @echo "LD rockbox.elf"
@$(CC) -Os -nostdlib -o $@ $(OBJS) -L$(OBJDIR) -lrockbox -lgcc -L$(FIRMWARE) -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/rockbox.map
$(OBJDIR)/rockbox.bin : $(OBJDIR)/rockbox.elf $(OBJDIR)/rockbox.bin : $(OBJDIR)/rockbox.elf
$(OC) -O binary $< $@ @echo "OBJCOPY $<"
@$(OC) -O binary $< $@
$(OBJDIR)/rombox.bin : $(OBJDIR)/rombox.elf
@echo "OBJCOPY $<"
@$(OC) -O binary $< $@
$(OBJDIR)/rockbox.asm: $(OBJDIR)/rockbox.bin $(OBJDIR)/rockbox.asm: $(OBJDIR)/rockbox.bin
$(TOOLSDIR)/sh2d -sh1 $< > $@ $(TOOLSDIR)/sh2d -sh1 $< > $@
@ -127,10 +150,30 @@ $(OBJDIR)/$(OUTNAME) : $(OBJDIR)/rockbox.bin
$(OBJDIR)/rockbox.ucl: $(OBJDIR)/rockbox.bin $(OBJDIR)/rockbox.ucl: $(OBJDIR)/rockbox.bin
@a=`uclpack -h 2>/dev/null`; \ @a=`uclpack -h 2>/dev/null`; \
if test -n "$$a"; then \ if test -n "$$a"; then \
echo uclpack --best --2e $< $@ ; \ echo "UCLPACK rockbox" ; \
uclpack --best --2e $< $@ >/dev/null 2>&1; \ uclpack --best --2e $< $@ >/dev/null 2>&1; \
else \ else \
echo "no uclpack command found, makes a fake UCL file"; \ echo "no uclpack command found, makes a fake rockbox.ucl"; \
echo "fake" > $@; \
fi
$(OBJDIR)/rombox.ucl: $(OBJDIR)/rombox.bin
@a=`uclpack -h 2>/dev/null`; \
if test -n "$$a"; then \
echo "UCLPACK rombox" ; \
uclpack --none $< $@ >/dev/null 2>&1; \
if test -s $@; then \
perl $(TOOLSDIR)/romsizetest.pl $(MAXROMSIZE) $@; \
if test $$? -ne 0; then \
echo "removing UCL file again, making it a fake one"; \
echo "fake" > $@; \
fi \
else \
echo "Your uclpack seems to not support --none, making a fake ucl"; \
echo "fake" > $@; \
fi \
else \
echo "no uclpack command found, makes a fake rombox.ucl"; \
echo "fake" > $@; \ echo "fake" > $@; \
fi fi
@ -139,26 +182,34 @@ $(OBJDIR)/credits.raw: $(DOCSDIR)/CREDITS
$(OBJDIR)/credits.o: credits.c credits.h $(OBJDIR)/credits.raw $(OBJDIR)/credits.o: credits.c credits.h $(OBJDIR)/credits.raw
@mkdir -p `dirname $@` @mkdir -p `dirname $@`
$(CC) $(CFLAGS) -c $< -o $@ @echo "CC $<"
@$(CC) $(CFLAGS) -c $< -o $@
$(OBJDIR)/%.o: %.c $(OBJDIR)/%.o: %.c
@mkdir -p `dirname $@` @mkdir -p `dirname $@`
$(CC) $(CFLAGS) -c $< -o $@ @echo "CC $<"
@$(CC) $(CFLAGS) -c $< -o $@
$(OBJDIR)/build.lang: lang/$(LANGUAGE).lang $(TOOLSDIR)/uplang $(OBJDIR)/build.lang: lang/$(LANGUAGE).lang $(TOOLSDIR)/uplang
perl $(TOOLSDIR)/uplang lang/english.lang $< > $@ @echo "UPLANG"
@perl $(TOOLSDIR)/uplang lang/english.lang $< > $@
$(OBJDIR)/lang.o: $(OBJDIR)/build.lang $(TOOLSDIR)/genlang $(OBJDIR)/lang.o: $(OBJDIR)/build.lang $(TOOLSDIR)/genlang
perl -s $(TOOLSDIR)/genlang -p=$(OBJDIR)/lang $< @echo "GENLANG"
$(CC) $(CFLAGS) -c $(OBJDIR)/lang.c -o $@ @perl -s $(TOOLSDIR)/genlang -p=$(OBJDIR)/lang $<
@echo "CC lang.c"
@$(CC) $(CFLAGS) -c $(OBJDIR)/lang.c -o $@
clean: clean:
-rm -f $(OBJS) $(OBJDIR)/$(OUTNAME) $(OBJDIR)/rockbox.asm \ @echo "cleaning apps"
$(OBJDIR)/rockbox.bin $(OBJDIR)/rockbox.elf $(OBJDIR)/*.map \ @-rm -f $(OBJS) $(OBJDIR)/$(OUTNAME) $(OBJDIR)/rockbox.asm \
$(OBJDIR)/lang.o $(OBJDIR)/build.lang $(OBJDIR)/lang.[ch] \ $(OBJDIR)/rockbox.bin $(OBJDIR)/rockbox.elf $(OBJDIR)/*.map \
$(OBJDIR)/credits.raw $(LINKFILE) $(OBJDIR)/rockbox.ucl $(OBJDIR)/lang.o $(OBJDIR)/build.lang $(OBJDIR)/lang.[ch] \
-$(RM) -r $(OBJDIR)/$(DEPS) $(OBJDIR)/credits.raw $(LINKFILE) $(OBJDIR)/rockbox.ucl \
$(MAKE) -C plugins clean $(LINKROM) $(OBJDIR)/rombox.ucl $(OBJDIR)/rombox.bin \
$(OBJDIR)/rombox.elf
@-$(RM) -r $(OBJDIR)/$(DEPS)
@$(MAKE) -C plugins clean
DEPS:=.deps DEPS:=.deps
DEPDIRS:=$(DEPS) DEPDIRS:=$(DEPS)
@ -180,8 +231,7 @@ tags:
$(OBJDIR)/$(DEPS)/%.d: %.c $(OBJDIR)/$(DEPS)/%.d: %.c
@$(SHELL) -c 'for d in $(DEPDIRS); do { if [ ! -d $(OBJDIR)/$$d ]; then mkdir $(OBJDIR)/$$d; fi; }; done' @$(SHELL) -c 'for d in $(DEPDIRS); do { if [ ! -d $(OBJDIR)/$$d ]; then mkdir $(OBJDIR)/$$d; fi; }; done'
@echo "Updating dependencies for $(OBJDIR)/$<" @$(SHELL) -ec '$(CC) -MM $(CFLAGS) $< 2>/dev/null \
@$(SHELL) -ec '$(CC) -MM $(CFLAGS) $< \
|sed '\''s|\($*\)\.o[ :]*|$(OBJDIR)/\1.o $(<:%.c=%.d) : |g'\'' > $@; \ |sed '\''s|\($*\)\.o[ :]*|$(OBJDIR)/\1.o $(<:%.c=%.d) : |g'\'' > $@; \
[ -s $@ ] || rm -f $@' [ -s $@ ] || rm -f $@'

View file

@ -40,25 +40,31 @@ no_configure:
endif endif
$(OBJDIR)/%.elf: $(OBJDIR)/%.o $(LINKFILE) $(OBJDIR)/libplugin.a $(OBJDIR)/%.elf: $(OBJDIR)/%.o $(LINKFILE) $(OBJDIR)/libplugin.a
$(CC) -O -nostdlib -o $@ $< -L$(OBJDIR) -lplugin -lgcc -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/$*.map @echo "LD $@"
@$(CC) -O -nostdlib -o $@ $< -L$(OBJDIR) -lplugin -lgcc -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/$*.map
$(OBJDIR)/%.rock : $(OBJDIR)/%.elf $(OBJDIR)/%.rock : $(OBJDIR)/%.elf
$(OC) -O binary $< $@ @echo "OBJCOPY $<"
@$(OC) -O binary $< $@
$(OBJDIR)/%.o: %.c ../plugin.h Makefile $(OBJDIR)/%.o: %.c ../plugin.h Makefile
$(CC) $(CFLAGS) -c $< -o $@ @echo "CC $<"
@$(CC) $(CFLAGS) -c $< -o $@
all: $(OBJDIR)/libplugin.a $(ROCKS) all: $(OBJDIR)/libplugin.a $(ROCKS)
echo "done" @echo "plugins done"
$(OBJDIR)/libplugin.a: $(OBJDIR)/libplugin.a:
$(MAKE) -C lib TARGET=$(TARGET) DEBUG=$(DEBUG) OBJDIR=$(OBJDIR) VERSION=$(VERSION) EXTRA_DEFINES="$(EXTRA_DEFINES)" MEM=${MEM} @echo "MAKE in lib"
@$(MAKE) -C lib TARGET=$(TARGET) DEBUG=$(DEBUG) OBJDIR=$(OBJDIR) VERSION=$(VERSION) EXTRA_DEFINES="$(EXTRA_DEFINES)" MEM=${MEM}
# MEM should be passed on to this makefile with the chosen memory size given # MEM should be passed on to this makefile with the chosen memory size given
# in number of MB # in number of MB
$(LINKFILE): $(LDS) $(LINKFILE): $(LDS)
$(CC) -DMEMORYSIZE=$(MEM) $(DEFINES) -x c -E -P $< >$@ @echo "build $@"
@$(CC) -DMEMORYSIZE=$(MEM) $(DEFINES) -x c -E -P $< >$@
clean: clean:
-rm -f $(ROCKS) $(LINKFILE) $(OBJDIR)/*.rock @echo "cleaning plugins"
$(MAKE) -C lib clean @-rm -f $(ROCKS) $(LINKFILE) $(OBJDIR)/*.rock
@$(MAKE) -C lib clean

View file

@ -62,25 +62,28 @@ no_configure:
endif endif
all: $(OUTPUT) all: $(OUTPUT)
@echo "lib done"
$(OUTPUT): $(OBJS) $(OUTPUT): $(OBJS)
$(AR) ruv $@ $+ @echo "AR $@"
@$(AR) ruv $@ $+ >/dev/null
$(OBJDIR)/%.o: %.c $(OBJDIR)/%.o: %.c
@mkdir -p `dirname $@` @mkdir -p `dirname $@`
$(CC) $(CFLAGS) -c $< -o $@ @echo "CC $<"
@$(CC) $(CFLAGS) -c $< -o $@
tags: tags:
@$(SHELL) -c 'for d in $(DIRS); do { etags -o $(OBJDIR)/TAGS -a $$d/*.[ch]; }; done' @$(SHELL) -c 'for d in $(DIRS); do { etags -o $(OBJDIR)/TAGS -a $$d/*.[ch]; }; done'
clean: clean:
rm -f $(OBJS) $(OUTPUT) @echo "cleaning lib"
rm -rf $(OBJDIR)/$(DEPS) @rm -f $(OBJS) $(OUTPUT)
@rm -rf $(OBJDIR)/$(DEPS)
$(OBJDIR)/$(DEPS)/%.d: %.c $(OBJDIR)/$(DEPS)/%.d: %.c
@$(SHELL) -c 'for d in $(DEPDIRS); do { if [ ! -d $(OBJDIR)/$$d ]; then mkdir $(OBJDIR)/$$d; fi; }; done' @$(SHELL) -c 'for d in $(DEPDIRS); do { if [ ! -d $(OBJDIR)/$$d ]; then mkdir $(OBJDIR)/$$d; fi; }; done'
@echo "Updating dependencies for $<" @$(SHELL) -ec '$(CC) -MM $(CFLAGS) $< 2>/dev/null \
@$(SHELL) -ec '$(CC) -MM $(CFLAGS) $< \
|sed '\''s|\($*\)\.o[ :]*|$(OBJDIR)/\1.o $(<:%.c=%.d) : |g'\'' > $@; \ |sed '\''s|\($*\)\.o[ :]*|$(OBJDIR)/\1.o $(<:%.c=%.d) : |g'\'' > $@; \
[ -s $@ ] || rm -f $@' [ -s $@ ] || rm -f $@'

View file

@ -62,35 +62,41 @@ $(TOOLSDIR)/convbdf:
$(MAKE) -C $(TOOLSDIR) $(MAKE) -C $(TOOLSDIR)
$(OUTPUT): $(OBJS) $(OUTPUT): $(OBJS)
$(AR) ruv $@ $+ @echo "AR $@"
@$(AR) ruv $@ $+ >/dev/null
$(OBJDIR)/%.o: %.c $(OBJDIR)/%.o: %.c
@mkdir -p `dirname $@` @mkdir -p `dirname $@`
$(CC) $(CFLAGS) -c $< -o $@ @echo "CC $<"
@$(CC) $(CFLAGS) -c $< -o $@
$(OBJDIR)/%.o: %.S $(OBJDIR)/%.o: %.S
@mkdir -p `dirname $@` @mkdir -p `dirname $@`
$(CC) $(CFLAGS) -c $< -o $@ @echo "CC $<"
@$(CC) $(CFLAGS) -c $< -o $@
tags: tags:
@$(SHELL) -c 'for d in $(DIRS); do { etags -o $(OBJDIR)/TAGS -a $$d/*.[ch]; }; done' @$(SHELL) -c 'for d in $(DIRS); do { etags -o $(OBJDIR)/TAGS -a $$d/*.[ch]; }; done'
clean: clean:
rm -f $(OBJS) $(OUTPUT) $(OBJDIR)/sysfont.c @echo "cleaning firmware"
rm -rf $(OBJDIR)/$(DEPS) @rm -f $(OBJS) $(OUTPUT) $(OBJDIR)/sysfont.c
@rm -rf $(OBJDIR)/$(DEPS)
# Special targets # Special targets
$(OBJDIR)/thread.o: thread.c export/thread.h $(OBJDIR)/thread.o: thread.c export/thread.h
$(CC) -c -O -fomit-frame-pointer $(CFLAGS) $< -o $@ @echo "CC thread.c"
@$(CC) -c -O -fomit-frame-pointer $(CFLAGS) $< -o $@
$(OBJDIR)/sysfont.o: fonts/clR6x8.bdf $(OBJDIR)/sysfont.o: fonts/clR6x8.bdf
$(TOOLSDIR)/convbdf -c -o $(OBJDIR)/sysfont.c $< @echo "CONVBDF"
$(CC) $(CFLAGS) -c $(OBJDIR)/sysfont.c -o $@ @$(TOOLSDIR)/convbdf -c -o $(OBJDIR)/sysfont.c $<
@echo "CC sysfont.c"
@$(CC) $(CFLAGS) -c $(OBJDIR)/sysfont.c -o $@
$(OBJDIR)/$(DEPS)/%.d: %.c $(OBJDIR)/$(DEPS)/%.d: %.c
@$(SHELL) -c 'for d in $(DEPDIRS); do { if [ ! -d $(OBJDIR)/$$d ]; then mkdir $(OBJDIR)/$$d; fi; }; done' @$(SHELL) -c 'for d in $(DEPDIRS); do { if [ ! -d $(OBJDIR)/$$d ]; then mkdir $(OBJDIR)/$$d; fi; }; done'
@echo "Updating dependencies for $<" @$(SHELL) -ec '$(CC) -MM $(CFLAGS) $< 2>/dev/null \
@$(SHELL) -ec '$(CC) -MM $(CFLAGS) $< \
|sed '\''s|\($*\)\.o[ :]*|$(OBJDIR)/\1.o $(<:%.c=%.d) : |g'\'' > $@; \ |sed '\''s|\($*\)\.o[ :]*|$(OBJDIR)/\1.o $(<:%.c=%.d) : |g'\'' > $@; \
[ -s $@ ] || rm -f $@' [ -s $@ ] || rm -f $@'

View file

@ -25,14 +25,13 @@ SECTIONS
*(.data) *(.data)
. = ALIGN(0x4); . = ALIGN(0x4);
_dataend = .; _dataend = .;
. = ALIGN(0x10); /* Maintain proper alignment for .text section */
} > DRAM } > DRAM
.datacopy : /* TRICK ALERT! Newer versions of the linker don't allow output sections
{ to overlap even if one of them is empty, so advance the location pointer
. += SIZEOF(.data); "by hand" */
} > FLASH .text LOADADDR(.data) + SIZEOF(.data) :
.text :
{ {
*(.init.text) *(.init.text)
*(.text) *(.text)
@ -44,10 +43,6 @@ SECTIONS
*(.rodata) *(.rodata)
*(.rodata.str1.4) *(.rodata.str1.4)
. = ALIGN(0x4); . = ALIGN(0x4);
} > FLASH
.iramcopy :
{
_iramcopy = .; _iramcopy = .;
} > FLASH } > FLASH

View file

@ -11,6 +11,7 @@ CFLAGS := -O -ansi
TARGETS := scramble descramble sh2d bmp2rb convbdf generate_rocklatin TARGETS := scramble descramble sh2d bmp2rb convbdf generate_rocklatin
all: $(TARGETS) all: $(TARGETS)
@echo "tools done"
scramble: scramble.c scramble: scramble.c

View file

@ -106,7 +106,12 @@ sub buildzip {
if($image) { if($image) {
# image is blank when this is a simulator # image is blank when this is a simulator
`cp rockbox.ucl .rockbox/`; # UCL for flashing if( filesize("rockbox.ucl") > 1000 ) {
`cp rockbox.ucl .rockbox/`; # UCL for flashing
}
if( filesize("rombox.ucl") > 1000) {
`cp rombox.ucl .rockbox/`; # UCL for flashing
}
} }
} }

22
tools/romsizetest.pl Executable file
View file

@ -0,0 +1,22 @@
#!/usr/bin/perl
#
# Check that the given file is smaller than the given size and if not, return
# an error code. Used to verify that the rombox.ucl file fits on the particular
# model you build for.
sub filesize {
my ($filename)=@_;
my ($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size,
$atime,$mtime,$ctime,$blksize,$blocks)
= stat($filename);
return $size;
}
my $max = $ARGV[0];
my $file = filesize($ARGV[1]);
if($file > $max ) {
print "Output is larger than max ($max)\n";
exit 1;
}