wdenk | 717b5aa | 2002-04-27 11:09:31 +0000 | [diff] [blame] | 1 | # |
| 2 | # (C) Copyright 2000 |
| 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 | |
| 24 | LOAD_ADDR = 0x40000 |
| 25 | |
| 26 | include $(TOPDIR)/config.mk |
| 27 | |
| 28 | SREC = hello_world.srec |
wdenk | dc7c9a1 | 2003-03-26 06:55:25 +0000 | [diff] [blame] | 29 | BIN = hello_world.bin |
wdenk | 717b5aa | 2002-04-27 11:09:31 +0000 | [diff] [blame] | 30 | |
wdenk | 85ec0bc | 2003-03-31 16:34:49 +0000 | [diff] [blame^] | 31 | ifeq ($(ARCH),ppc) |
| 32 | SREC += sched.srec |
| 33 | BIN += sched.bin |
| 34 | endif |
| 35 | |
wdenk | 6069ff2 | 2003-02-28 00:49:47 +0000 | [diff] [blame] | 36 | ifeq ($(CPU),mips) |
| 37 | SREC = |
wdenk | cdd8a0f | 2003-03-27 18:00:16 +0000 | [diff] [blame] | 38 | BIN = |
wdenk | 6069ff2 | 2003-02-28 00:49:47 +0000 | [diff] [blame] | 39 | endif |
| 40 | |
wdenk | 717b5aa | 2002-04-27 11:09:31 +0000 | [diff] [blame] | 41 | # The following example is pretty 8xx specific... |
| 42 | ifeq ($(CPU),mpc8xx) |
| 43 | SREC += timer.srec |
wdenk | 85ec0bc | 2003-03-31 16:34:49 +0000 | [diff] [blame^] | 44 | BIN += timer.bin |
wdenk | 717b5aa | 2002-04-27 11:09:31 +0000 | [diff] [blame] | 45 | endif |
| 46 | |
| 47 | # Utility for resetting i82559 EEPROM |
| 48 | ifeq ($(BOARD),oxc) |
| 49 | SREC += eepro100_eeprom.srec |
| 50 | endif |
| 51 | |
| 52 | OBJS = $(SREC:.srec=.o) |
| 53 | |
wdenk | 85ec0bc | 2003-03-31 16:34:49 +0000 | [diff] [blame^] | 54 | LIB = libsyscall.a |
wdenk | 717b5aa | 2002-04-27 11:09:31 +0000 | [diff] [blame] | 55 | LIBAOBJS= syscall.o |
wdenk | 85ec0bc | 2003-03-31 16:34:49 +0000 | [diff] [blame^] | 56 | ifeq ($(ARCH),ppc) |
| 57 | LIBAOBJS+= $(ARCH)_longjmp.o $(ARCH)_setjmp.o |
| 58 | endif |
wdenk | 717b5aa | 2002-04-27 11:09:31 +0000 | [diff] [blame] | 59 | LIBCOBJS= |
| 60 | LIBOBJS = $(LIBAOBJS) $(LIBCOBJS) |
| 61 | |
| 62 | CPPFLAGS += -I.. |
| 63 | |
wdenk | dc7c9a1 | 2003-03-26 06:55:25 +0000 | [diff] [blame] | 64 | all: .depend $(LIB) $(SREC) $(BIN) |
wdenk | 717b5aa | 2002-04-27 11:09:31 +0000 | [diff] [blame] | 65 | |
| 66 | ######################################################################### |
| 67 | $(LIB): .depend $(LIBOBJS) |
| 68 | $(AR) crv $@ $(LIBOBJS) |
| 69 | |
| 70 | %.srec: %.o $(LIB) |
| 71 | $(LD) -g -Ttext $(LOAD_ADDR) -o $(<:.o=) -e $(<:.o=) $< $(LIB) |
| 72 | $(OBJCOPY) -O srec $(<:.o=) $@ |
| 73 | |
wdenk | dc7c9a1 | 2003-03-26 06:55:25 +0000 | [diff] [blame] | 74 | %.bin: %.srec |
wdenk | ac6dbb8 | 2003-03-26 11:42:53 +0000 | [diff] [blame] | 75 | $(OBJCOPY) -O binary $< $@ 2>/dev/null |
wdenk | dc7c9a1 | 2003-03-26 06:55:25 +0000 | [diff] [blame] | 76 | |
wdenk | 717b5aa | 2002-04-27 11:09:31 +0000 | [diff] [blame] | 77 | ######################################################################### |
| 78 | |
| 79 | .depend: Makefile $(OBJS:.o=.c) $(LIBCOBJS:.o=.c) $(LIBAOBJS:.o=.S) |
| 80 | $(CC) -M $(CFLAGS) $(OBJS:.o=.c) $(LIBCOBJS:.o=.c) $(LIBAOBJS:.o=.S) > $@ |
| 81 | |
| 82 | sinclude .depend |
| 83 | |
| 84 | ######################################################################### |