]>
Commit | Line | Data |
---|---|---|
717b5aad | 1 | # |
f9328639 | 2 | # (C) Copyright 2000-2006 |
717b5aad WD |
3 | # Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
4 | # | |
5 | # See file CREDITS for list of people who contributed to this | |
6 | # project. | |
7 | # | |
8 | # This program is free software; you can redistribute it and/or | |
9 | # modify it under the terms of the GNU General Public License as | |
10 | # published by the Free Software Foundation; either version 2 of | |
11 | # the License, or (at your option) any later version. | |
12 | # | |
13 | # This program is distributed in the hope that it will be useful, | |
14 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
16 | # GNU General Public License for more details. | |
17 | # | |
18 | # You should have received a copy of the GNU General Public License | |
19 | # along with this program; if not, write to the Free Software | |
20 | # Foundation, Inc., 59 Temple Place, Suite 330, Boston, | |
21 | # MA 02111-1307 USA | |
22 | # | |
23 | ||
27b207fd | 24 | ifeq ($(ARCH),ppc) |
717b5aad | 25 | LOAD_ADDR = 0x40000 |
27b207fd WD |
26 | endif |
27 | ||
28 | ifeq ($(ARCH),i386) | |
29 | LOAD_ADDR = 0x40000 | |
30 | endif | |
31 | ||
32 | ifeq ($(ARCH),arm) | |
33 | LOAD_ADDR = 0xc100000 | |
34 | endif | |
35 | ||
36 | ifeq ($(ARCH),mips) | |
37 | LOAD_ADDR = 0x80200000 -T mips.lds | |
38 | endif | |
717b5aad | 39 | |
4a551709 | 40 | ifeq ($(ARCH),nios) |
e4cc71aa | 41 | LOAD_ADDR = 0x00800000 -L $(gcclibdir)/m32 -T nios.lds |
4a551709 WD |
42 | endif |
43 | ||
5c952cf0 | 44 | ifeq ($(ARCH),nios2) |
c2ced000 | 45 | LOAD_ADDR = 0x02000000 -L $(gcclibdir) -T nios2.lds |
5c952cf0 WD |
46 | endif |
47 | ||
bf9e3b38 WD |
48 | ifeq ($(ARCH),m68k) |
49 | LOAD_ADDR = 0x20000 -L $(clibdir) | |
50 | endif | |
51 | ||
507bbe3e WD |
52 | ifeq ($(ARCH),microblaze) |
53 | LOAD_ADDR = 0x80F00000 | |
54 | endif | |
55 | ||
0afe519a WD |
56 | ifeq ($(ARCH),blackfin) |
57 | LOAD_ADDR = 0x1000 | |
58 | endif | |
59 | ||
717b5aad WD |
60 | include $(TOPDIR)/config.mk |
61 | ||
62 | SREC = hello_world.srec | |
3a473b2a | 63 | BIN = hello_world.bin hello_world |
717b5aad | 64 | |
c0176630 | 65 | ifeq ($(CPU),mpc8xx) |
931da93e WD |
66 | SREC = test_burst.srec |
67 | BIN = test_burst.bin test_burst | |
68 | endif | |
69 | ||
7a8e9bed WD |
70 | ifeq ($(ARCH),i386) |
71 | SREC += 82559_eeprom.srec | |
3a473b2a | 72 | BIN += 82559_eeprom.bin 82559_eeprom |
7a8e9bed WD |
73 | endif |
74 | ||
85ec0bcc WD |
75 | ifeq ($(ARCH),ppc) |
76 | SREC += sched.srec | |
3a473b2a | 77 | BIN += sched.bin sched |
85ec0bcc WD |
78 | endif |
79 | ||
0afe519a WD |
80 | ifeq ($(ARCH),blackfin) |
81 | SREC += smc91111_eeprom.srec | |
82 | BIN += smc91111_eeprom.bin smc91111_eeprom | |
83 | endif | |
84 | ||
717b5aad WD |
85 | # The following example is pretty 8xx specific... |
86 | ifeq ($(CPU),mpc8xx) | |
87 | SREC += timer.srec | |
3a473b2a | 88 | BIN += timer.bin timer |
717b5aad WD |
89 | endif |
90 | ||
3e38691e WD |
91 | # The following example is 8260 specific... |
92 | ifeq ($(CPU),mpc8260) | |
93 | SREC += mem_to_mem_idma2intr.srec | |
3a473b2a | 94 | BIN += mem_to_mem_idma2intr.bin mem_to_mem_idma2intr |
3e38691e WD |
95 | endif |
96 | ||
717b5aad WD |
97 | # Utility for resetting i82559 EEPROM |
98 | ifeq ($(BOARD),oxc) | |
99 | SREC += eepro100_eeprom.srec | |
3a473b2a | 100 | BIN += eepro100_eeprom.bin eepro100_eeprom |
717b5aad WD |
101 | endif |
102 | ||
2d5b561e WD |
103 | ifeq ($(BIG_ENDIAN),y) |
104 | EX_LDFLAGS += -EB | |
105 | endif | |
106 | ||
f9328639 | 107 | COBJS := $(SREC:.srec=.o) |
717b5aad | 108 | |
f9328639 | 109 | LIB = $(obj)libstubs.a |
27b207fd | 110 | LIBAOBJS= |
85ec0bcc WD |
111 | ifeq ($(ARCH),ppc) |
112 | LIBAOBJS+= $(ARCH)_longjmp.o $(ARCH)_setjmp.o | |
c0176630 WD |
113 | endif |
114 | ifeq ($(CPU),mpc8xx) | |
931da93e | 115 | LIBAOBJS+= test_burst_lib.o |
85ec0bcc | 116 | endif |
27b207fd | 117 | LIBCOBJS= stubs.o |
f9328639 MB |
118 | |
119 | LIBOBJS = $(addprefix $(obj),$(LIBAOBJS) $(LIBCOBJS)) | |
120 | ||
121 | SRCS := $(COBJS:.o=.c) $(LIBCOBJS:.o=.c) $(if $(LIBAOBJS),$(LIBAOBJS:.o=.S)) | |
122 | OBJS := $(addprefix $(obj),$(COBJS)) | |
123 | BIN := $(addprefix $(obj),$(BIN)) | |
124 | SREC := $(addprefix $(obj),$(SREC)) | |
717b5aad | 125 | |
c29fdfc1 | 126 | gcclibdir := $(shell dirname `$(CC) -print-libgcc-file-name`) |
bf9e3b38 | 127 | clibdir := $(shell dirname `$(CC) $(CFLAGS) -print-file-name=libc.a`) |
c29fdfc1 | 128 | |
717b5aad WD |
129 | CPPFLAGS += -I.. |
130 | ||
f9328639 | 131 | all: $(obj).depend $(OBJS) $(LIB) $(SREC) $(BIN) |
717b5aad WD |
132 | |
133 | ######################################################################### | |
f9328639 MB |
134 | $(LIB): $(obj).depend $(LIBOBJS) |
135 | $(AR) crv $@ $(LIBOBJS) | |
717b5aad | 136 | |
f9328639 MB |
137 | $(obj)%: $(obj)%.o $(LIB) |
138 | $(LD) -g $(EX_LDFLAGS) -Ttext $(LOAD_ADDR) \ | |
139 | -o $@ -e $(notdir $(<:.o=)) $< $(LIB) \ | |
140 | -L$(gcclibdir) -lgcc | |
141 | $(obj)%.srec: $(obj)% | |
142 | $(OBJCOPY) -O srec $< $@ 2>/dev/null | |
717b5aad | 143 | |
f9328639 MB |
144 | $(obj)%.bin: $(obj)% |
145 | $(OBJCOPY) -O binary $< $@ 2>/dev/null | |
dc7c9a1a | 146 | |
717b5aad WD |
147 | ######################################################################### |
148 | ||
f9328639 MB |
149 | # defines $(obj).depend target |
150 | include $(SRCTREE)/rules.mk | |
717b5aad | 151 | |
f9328639 | 152 | sinclude $(obj).depend |
717b5aad WD |
153 | |
154 | ######################################################################### |