summaryrefslogtreecommitdiff
path: root/apps
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2005-02-18 13:47:17 +0000
committerDaniel Stenberg <daniel@haxx.se>2005-02-18 13:47:17 +0000
commitcdde25b597eb4047e9db27bb8bbcf938e4a43cfe (patch)
treed25f47817cc8515228c8ea0eb33ab71bfc2159d4 /apps
parentf436476f9f0eeae4640197866ea5b5fa068df7e9 (diff)
downloadrockbox-cdde25b597eb4047e9db27bb8bbcf938e4a43cfe.tar.gz
rockbox-cdde25b597eb4047e9db27bb8bbcf938e4a43cfe.zip
Unified build system to use SOURCES for sim builds too, a single Makefile-look
made by configure and various related adjustments. This has not yet been tested on cygwin. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@6001 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'apps')
-rw-r--r--apps/Makefile31
-rw-r--r--apps/SOURCES2
-rw-r--r--apps/codecs/libFLAC/Makefile15
-rw-r--r--apps/main_menu.c7
-rw-r--r--apps/plugin.c2
-rw-r--r--apps/plugin.h2
-rw-r--r--apps/plugins/Makefile41
-rw-r--r--apps/plugins/lib/Makefile7
8 files changed, 79 insertions, 28 deletions
diff --git a/apps/Makefile b/apps/Makefile
index 75b9fbafb3..bcdc1ef265 100644
--- a/apps/Makefile
+++ b/apps/Makefile
@@ -13,11 +13,6 @@ DEPFILE = $(OBJDIR)/dep-apps
13LDS := $(FIRMDIR)/app.lds 13LDS := $(FIRMDIR)/app.lds
14ROMLDS := $(FIRMDIR)/rom.lds 14ROMLDS := $(FIRMDIR)/rom.lds
15 15
16ifdef DEBUG
17 DEFINES := -DDEBUG
18 CFLAGS += -g
19endif
20
21ifdef ENABLEDPLUGINS 16ifdef ENABLEDPLUGINS
22ROCKS=rocks 17ROCKS=rocks
23endif 18endif
@@ -26,7 +21,8 @@ ifdef SOFTWARECODECS
26CODECS=build-codecs 21CODECS=build-codecs
27endif 22endif
28 23
29SRC := $(shell cat SOURCES | $(CC) -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) $(TARGET) $(DEFINES) -E -P -include "config.h" - ) 24SRC := $(shell cat SOURCES | gcc -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) \
25$(TARGET) $(DEFINES) $(EXTRA_DEFINES) -E -P -include "config.h" - )
30DIRS = . 26DIRS = .
31 27
32ifdef APPEXTRA 28ifdef APPEXTRA
@@ -44,9 +40,11 @@ LINKROM = $(OBJDIR)/linkrom.lds
44MAXINFILE = $(OBJDIR)/romstart.temp 40MAXINFILE = $(OBJDIR)/romstart.temp
45MAXOUTFILE = $(OBJDIR)/romstart 41MAXOUTFILE = $(OBJDIR)/romstart
46 42
47ifdef DEBUG 43ifdef SIMVER
48all: $(OBJDIR)/rockbox.elf $(CODECS) $(ROCKS) 44# this is a sim build
45all: $(OBJDIR)/$(BINARY) $(CODECS) $(ROCKS)
49else 46else
47# regular target build
50all: $(OBJDIR)/$(BINARY) $(FLASHFILE) $(CODECS) $(ROCKS) $(ARCHOSROM) 48all: $(OBJDIR)/$(BINARY) $(FLASHFILE) $(CODECS) $(ROCKS) $(ARCHOSROM)
51endif 49endif
52 50
@@ -80,9 +78,11 @@ $(OBJDIR)/rombox.elf : $(OBJS) $(LINKROM) $(OBJDIR)/librockbox.a $(DEPFILE)
80 @echo "LD rombox.elf" 78 @echo "LD rombox.elf"
81 @$(CC) $(GCCOPTS) -Os -nostdlib -o $@ $(OBJS) -L$(OBJDIR) -lrockbox -lgcc -L$(FIRMDIR) -T$(LINKROM) -Wl,-Map,$(OBJDIR)/rombox.map 79 @$(CC) $(GCCOPTS) -Os -nostdlib -o $@ $(OBJS) -L$(OBJDIR) -lrockbox -lgcc -L$(FIRMDIR) -T$(LINKROM) -Wl,-Map,$(OBJDIR)/rombox.map
82 80
81ifndef SIMVER
82
83$(OBJDIR)/rockbox.elf : $(OBJS) $(LINKFILE) $(OBJDIR)/librockbox.a $(DEPFILE) 83$(OBJDIR)/rockbox.elf : $(OBJS) $(LINKFILE) $(OBJDIR)/librockbox.a $(DEPFILE)
84 @echo "LD rockbox.elf" 84 @echo "LD rockbox.elf"
85 $(CC) $(GCCOPTS) -Os -nostdlib -o $@ $(OBJS) -L$(OBJDIR) -lrockbox -lgcc -L$(FIRMDIR) -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/rockbox.map 85 $(CC) $(GCCOPTS) -Os -nostdlib -o $@ $(OBJS) -L$(OBJDIR) -lrockbox -lgcc -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/rockbox.map
86 86
87$(OBJDIR)/rockbox.bin : $(OBJDIR)/rockbox.elf 87$(OBJDIR)/rockbox.bin : $(OBJDIR)/rockbox.elf
88 @echo "OBJCOPY $<" 88 @echo "OBJCOPY $<"
@@ -99,6 +99,16 @@ $(OBJDIR)/$(BINARY) : $(OBJDIR)/rockbox.bin
99 @echo "Build firmware file" 99 @echo "Build firmware file"
100 @$(MKFIRMWARE) $< $@ 100 @$(MKFIRMWARE) $< $@
101 101
102else
103# this is a simulator build
104$(OBJDIR)/$(BINARY) : $(OBJS) $(OBJDIR)/librockbox.a $(DEPFILE) $(OBJDIR)/libsim.a
105 @echo "LD $(BINARY)"
106 $(CC) $(GCCOPTS) -o $@ $(OBJS) $(LDOPTS) -L$(OBJDIR) -lrockbox -lsim -Wl,-Map,$(OBJDIR)/rockbox.map
107
108$(OBJDIR)/libsim.a:
109 @$(MAKE) -C $(SIMDIR)
110endif
111
102$(OBJDIR)/rockbox.ucl: $(OBJDIR)/rockbox.bin 112$(OBJDIR)/rockbox.ucl: $(OBJDIR)/rockbox.bin
103 @a=`uclpack -h 2>/dev/null`; \ 113 @a=`uclpack -h 2>/dev/null`; \
104 if test -n "$$a"; then \ 114 if test -n "$$a"; then \
@@ -160,5 +170,8 @@ clean:
160 @$(MAKE) -C plugins clean 170 @$(MAKE) -C plugins clean
161 @$(MAKE) -C codecs clean 171 @$(MAKE) -C codecs clean
162 @rm -rf $(OBJDIR)/recorder $(OBJDIR)/player 172 @rm -rf $(OBJDIR)/recorder $(OBJDIR)/player
173ifdef SIMVER
174 @$(MAKE) -C $(SIMDIR) clean
175endif
163 176
164-include $(DEPFILE) 177-include $(DEPFILE)
diff --git a/apps/SOURCES b/apps/SOURCES
index 43cd3ddfb2..33a6ded691 100644
--- a/apps/SOURCES
+++ b/apps/SOURCES
@@ -19,7 +19,9 @@ settings_menu.c
19sleeptimer.c 19sleeptimer.c
20sound_menu.c 20sound_menu.c
21status.c 21status.c
22#ifndef SIMULATOR
22talk.c 23talk.c
24#endif
23tree.c 25tree.c
24dbtree.c 26dbtree.c
25filetree.c 27filetree.c
diff --git a/apps/codecs/libFLAC/Makefile b/apps/codecs/libFLAC/Makefile
index 329de9c3fd..ee4feab769 100644
--- a/apps/codecs/libFLAC/Makefile
+++ b/apps/codecs/libFLAC/Makefile
@@ -14,11 +14,22 @@ ifdef APPEXTRA
14INCLUDES += -I$(APPSDIR)/$(APPEXTRA) 14INCLUDES += -I$(APPSDIR)/$(APPEXTRA)
15endif 15endif
16 16
17FLACOPTS = -DFLAC__NO_ASM -DFLAC__ALIGN_MALLOC_DATA -DFLAC__INTEGER_ONLY_LIBRARY -DVERSION=\"1.1.2\" -fomit-frame-pointer -funroll-loops -finline-functions -Wall -W -Winline -DFLaC__INLINE=__inline__ --param large-function-insns=10000 17NEWGCC=$(shell expr $(GCCNUM) ">" 303)
18
19FLACOPTS = -DFLAC__NO_ASM -DFLAC__ALIGN_MALLOC_DATA \
20-DFLAC__INTEGER_ONLY_LIBRARY -DVERSION=\"1.1.2\" -fomit-frame-pointer \
21-funroll-loops -finline-functions -Wall -W -Winline -DFLaC__INLINE=__inline__
22
23ifeq ($(NEWGCC), 1)
24 # this is 3.4.X options:
25 FLACOPTS += --param large-function-insns=10000
26endif
27
18CFLAGS = $(GCCOPTS) $(FLACOPTS)\ 28CFLAGS = $(GCCOPTS) $(FLACOPTS)\
19$(INCLUDES) $(TARGET) $(EXTRA_DEFINES) -DMEM=${MEMORYSIZE} 29$(INCLUDES) $(TARGET) $(EXTRA_DEFINES) -DMEM=${MEMORYSIZE}
20 30
21SRC := $(shell cat SOURCES | $(CC) -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) $(TARGET) $(DEFINES) -E -P -include "config.h" - ) 31SRC := $(shell cat SOURCES | $(CC) -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) \
32$(TARGET) $(DEFINES) -E -P -include "config.h" - )
22SOURCES = $(SRC) 33SOURCES = $(SRC)
23OBJS := $(SRC:%.c=$(OBJDIR)/libFLAC/%.o) 34OBJS := $(SRC:%.c=$(OBJDIR)/libFLAC/%.o)
24DEPFILE = $(OBJDIR)/dep-libFLAC 35DEPFILE = $(OBJDIR)/dep-libFLAC
diff --git a/apps/main_menu.c b/apps/main_menu.c
index 3eb1d69fb5..c7cfb0ea70 100644
--- a/apps/main_menu.c
+++ b/apps/main_menu.c
@@ -274,13 +274,6 @@ static bool plugin_browse(void)
274} 274}
275 275
276#ifdef HAVE_RECORDING 276#ifdef HAVE_RECORDING
277#ifdef SIMULATOR
278bool recording_screen(void)
279{
280 /* a dummy */
281 return false;
282}
283#endif
284 277
285static bool recording_settings(void) 278static bool recording_settings(void)
286{ 279{
diff --git a/apps/plugin.c b/apps/plugin.c
index 93717ccd06..10daeaf325 100644
--- a/apps/plugin.c
+++ b/apps/plugin.c
@@ -187,9 +187,7 @@ static const struct plugin_api rockbox_api = {
187 strncasecmp, 187 strncasecmp,
188 memset, 188 memset,
189 memcpy, 189 memcpy,
190#ifndef SIMULATOR
191 _ctype_, 190 _ctype_,
192#endif
193 atoi, 191 atoi,
194 192
195 /* sound */ 193 /* sound */
diff --git a/apps/plugin.h b/apps/plugin.h
index 590d02a4d1..96a9aabe1d 100644
--- a/apps/plugin.h
+++ b/apps/plugin.h
@@ -211,9 +211,7 @@ struct plugin_api {
211 int (*strncasecmp)(const char *s1, const char *s2, size_t n); 211 int (*strncasecmp)(const char *s1, const char *s2, size_t n);
212 void* (*memset)(void *dst, int c, size_t length); 212 void* (*memset)(void *dst, int c, size_t length);
213 void* (*memcpy)(void *out, const void *in, size_t n); 213 void* (*memcpy)(void *out, const void *in, size_t n);
214#ifndef SIMULATOR
215 const char *_ctype_; 214 const char *_ctype_;
216#endif
217 int (*atoi)(const char *str); 215 int (*atoi)(const char *str);
218 216
219 /* sound */ 217 /* sound */
diff --git a/apps/plugins/Makefile b/apps/plugins/Makefile
index 0c90bde9b1..6af39327bc 100644
--- a/apps/plugins/Makefile
+++ b/apps/plugins/Makefile
@@ -24,16 +24,19 @@ LDS := plugin.lds
24LINKFILE := $(OBJDIR)/pluginlink.lds 24LINKFILE := $(OBJDIR)/pluginlink.lds
25DEPFILE = $(OBJDIR)/dep-plugins 25DEPFILE = $(OBJDIR)/dep-plugins
26 26
27SRC := $(shell cat SOURCES | $(CC) -DMEMORYSIZE=$(MEMORYSIZE) \ 27SRC := $(shell cat SOURCES | gcc -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) \
28 $(INCLUDES) $(TARGET) $(DEFINES) -E -P -include "config.h" - ) 28 $(TARGET) $(DEFINES) $(EXTRA_DEFINES) -E -P -include "config.h" - )
29ROCKS := $(SRC:%.c=$(OBJDIR)/%.rock) 29ROCKS := $(SRC:%.c=$(OBJDIR)/%.rock)
30SOURCES = $(SRC) 30SOURCES = $(SRC)
31ELFS := $(SRC:%.c=$(OBJDIR)/%.elf) 31ELFS := $(SRC:%.c=$(OBJDIR)/%.elf)
32OBJS := $(SRC:%.c=$(OBJDIR)/%.o) 32OBJS := $(SRC:%.c=$(OBJDIR)/%.o)
33# as created by the cross-compiler for win32:
34DEFS := $(SRC:%.c=$(OBJDIR)/%.def)
33DIRS = . 35DIRS = .
34 36
35all: $(OBJDIR)/libplugin.a $(ROCKS) $(DEPFILE) 37all: $(OBJDIR)/libplugin.a $(ROCKS) $(DEPFILE)
36 38
39ifndef SIMVER
37$(OBJDIR)/%.elf: $(OBJDIR)/%.o $(LINKFILE) $(OBJDIR)/libplugin.a 40$(OBJDIR)/%.elf: $(OBJDIR)/%.o $(LINKFILE) $(OBJDIR)/libplugin.a
38 @echo "LD $@" 41 @echo "LD $@"
39 @$(CC) $(GCCOPTS) -O -nostdlib -o $@ $< -L$(OBJDIR) $(CODECLIBS) -lplugin -lgcc -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/$*.map 42 @$(CC) $(GCCOPTS) -O -nostdlib -o $@ $< -L$(OBJDIR) $(CODECLIBS) -lplugin -lgcc -T$(LINKFILE) -Wl,-Map,$(OBJDIR)/$*.map
@@ -41,6 +44,37 @@ $(OBJDIR)/%.elf: $(OBJDIR)/%.o $(LINKFILE) $(OBJDIR)/libplugin.a
41$(OBJDIR)/%.rock : $(OBJDIR)/%.elf 44$(OBJDIR)/%.rock : $(OBJDIR)/%.elf
42 @echo "OBJCOPY $<" 45 @echo "OBJCOPY $<"
43 @$(OC) -O binary $< $@ 46 @$(OC) -O binary $< $@
47else
48
49ifeq ($(SIMVER), x11)
50###################################################
51# This is the X11 simulator version
52
53$(OBJDIR)/%.rock : $(OBJDIR)/%.o $(APPSDIR)/plugin.h
54 @echo "LD $@"
55 @$(CC) $(APPCFLAGS) -DPLUGIN -shared $< -L$(OBJDIR) -lplugin -o $@
56ifeq ($(UNAME),CYGWIN)
57# 'x' must be kept or you'll have "Win32 error 5"
58# $ fgrep 5 /usr/include/w32api/winerror.h | head -1
59# #define ERROR_ACCESS_DENIED 5L
60else
61 @chmod -x $@
62endif
63
64else # end of x11-simulator
65###################################################
66# This is the win32 simulator version
67DLLTOOLFLAGS = --export-all
68DLLWRAPFLAGS = -s --entry _DllMain@12 --target=i386-mingw32 -mno-cygwin
69
70$(OBJDIR)/%.rock : $(OBJDIR)/%.o $(APPSDIR)/plugin.h
71 @echo "DLL $@"
72 @$(DLLTOOL) $(DLLTOOLFLAGS) -z $(OBJDIR)/$*.def $<
73 @$(DLLWRAP) $(DLLWRAPFLAGS) --def $(OBJDIR)/$*.def $< $(OBJDIR)/libplugin.a -o $@
74 @chmod -x $@
75endif # end of win32-simulator
76
77endif # end of simulator section
44 78
45include $(TOOLSDIR)/make.inc 79include $(TOOLSDIR)/make.inc
46 80
@@ -56,7 +90,8 @@ $(LINKFILE): $(LDS)
56 90
57clean: 91clean:
58 @echo "cleaning plugins" 92 @echo "cleaning plugins"
59 @rm -f $(ROCKS) $(LINKFILE) $(OBJDIR)/*.rock $(DEPFILE) $(ELFS) $(OBJS) 93 @rm -f $(ROCKS) $(LINKFILE) $(OBJDIR)/*.rock $(DEPFILE) $(ELFS) \
94 $(OBJS) $(DEFS)
60 @$(MAKE) -C lib clean 95 @$(MAKE) -C lib clean
61 96
62-include $(DEPFILE) 97-include $(DEPFILE)
diff --git a/apps/plugins/lib/Makefile b/apps/plugins/lib/Makefile
index b9daf737c4..b492bb578f 100644
--- a/apps/plugins/lib/Makefile
+++ b/apps/plugins/lib/Makefile
@@ -18,9 +18,9 @@ INCLUDES += -I$(APPSDIR)/$(APPEXTRA)
18endif 18endif
19 19
20CFLAGS = $(GCCOPTS) \ 20CFLAGS = $(GCCOPTS) \
21$(INCLUDES) $(TARGET) $(EXTRA_DEFINES) -DMEM=${MEMORYSIZE} 21$(INCLUDES) $(TARGET) $(EXTRA_DEFINES) -DMEM=${MEMORYSIZE} -DPLUGIN
22 22
23SRC := $(shell cat SOURCES | $(CC) -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) $(TARGET) $(DEFINES) -E -P -include "config.h" - ) 23SRC := $(shell cat SOURCES | gcc -DMEMORYSIZE=$(MEMORYSIZE) $(INCLUDES) $(TARGET) $(DEFINES) $(EXTRA_DEFINES) -E -P -include "config.h" - )
24SOURCES = $(SRC) 24SOURCES = $(SRC)
25OBJS := $(SRC:%.c=$(OBJDIR)/%.o) 25OBJS := $(SRC:%.c=$(OBJDIR)/%.o)
26DEPFILE = $(OBJDIR)/dep-pluginlib 26DEPFILE = $(OBJDIR)/dep-pluginlib
@@ -31,8 +31,9 @@ OUTPUT = $(OBJDIR)/libplugin.a
31all: $(OUTPUT) 31all: $(OUTPUT)
32 32
33$(OUTPUT): $(OBJS) 33$(OUTPUT): $(OBJS)
34 @echo "AR $@" 34 @echo "AR+RANLIB $@"
35 @$(AR) ruv $@ $+ >/dev/null 2>&1 35 @$(AR) ruv $@ $+ >/dev/null 2>&1
36 @$(RANLIB) $@
36 37
37include $(TOOLSDIR)/make.inc 38include $(TOOLSDIR)/make.inc
38 39