Mike Frysinger | 94bae5c | 2008-03-30 15:46:13 -0400 | [diff] [blame] | 1 | # |
| 2 | # U-boot - Makefile |
| 3 | # |
| 4 | # Copyright (c) 2005-2008 Analog Device Inc. |
| 5 | # |
| 6 | # (C) Copyright 2000-2006 |
| 7 | # Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
| 8 | # |
| 9 | # Licensed under the GPL-2 or later. |
| 10 | # |
| 11 | |
| 12 | include $(TOPDIR)/config.mk |
| 13 | |
| 14 | LIB = $(obj)lib$(CPU).a |
| 15 | |
| 16 | EXTRA := |
| 17 | CEXTRA := initcode.o |
| 18 | SEXTRA := start.o |
Mike Frysinger | f9c015b | 2008-08-07 17:52:59 -0400 | [diff] [blame] | 19 | SOBJS := interrupt.o cache.o |
Mike Frysinger | bc3c042 | 2010-04-29 01:34:57 -0400 | [diff] [blame] | 20 | COBJS-$(CONFIG_BOOTCOUNT_LIMIT) += bootcount.o |
Mike Frysinger | b52c2d1 | 2010-06-02 04:34:49 -0400 | [diff] [blame] | 21 | COBJS-$(CONFIG_CMD_GPIO) += cmd_gpio.o |
Mike Frysinger | ab673ea | 2009-07-09 20:56:56 -0400 | [diff] [blame] | 22 | COBJS-y += cpu.o |
Mike Frysinger | 83ebf37 | 2010-06-02 04:17:26 -0400 | [diff] [blame] | 23 | COBJS-y += gpio.o |
Mike Frysinger | ab673ea | 2009-07-09 20:56:56 -0400 | [diff] [blame] | 24 | COBJS-y += interrupts.o |
Mike Frysinger | 7504e97 | 2008-10-11 21:51:20 -0400 | [diff] [blame] | 25 | COBJS-$(CONFIG_JTAG_CONSOLE) += jtag-console.o |
Mike Frysinger | ab673ea | 2009-07-09 20:56:56 -0400 | [diff] [blame] | 26 | COBJS-y += os_log.o |
| 27 | COBJS-y += reset.o |
| 28 | COBJS-y += serial.o |
| 29 | COBJS-y += traps.o |
Mike Frysinger | 5443bc4 | 2009-11-12 18:42:07 -0500 | [diff] [blame] | 30 | COBJS-$(CONFIG_HW_WATCHDOG) += watchdog.o |
Mike Frysinger | 94bae5c | 2008-03-30 15:46:13 -0400 | [diff] [blame] | 31 | |
| 32 | ifeq ($(CONFIG_BFIN_BOOT_MODE),BFIN_BOOT_BYPASS) |
Mike Frysinger | 7504e97 | 2008-10-11 21:51:20 -0400 | [diff] [blame] | 33 | COBJS-y += initcode.o |
Mike Frysinger | 94bae5c | 2008-03-30 15:46:13 -0400 | [diff] [blame] | 34 | endif |
| 35 | |
Mike Frysinger | 7504e97 | 2008-10-11 21:51:20 -0400 | [diff] [blame] | 36 | SRCS := $(SEXTRA:.o=.S) $(SOBJS:.o=.S) $(COBJS-y:.o=.c) |
| 37 | OBJS := $(addprefix $(obj),$(COBJS-y) $(SOBJS)) |
Mike Frysinger | 94bae5c | 2008-03-30 15:46:13 -0400 | [diff] [blame] | 38 | EXTRA := $(addprefix $(obj),$(EXTRA)) |
| 39 | CEXTRA := $(addprefix $(obj),$(CEXTRA)) |
| 40 | SEXTRA := $(addprefix $(obj),$(SEXTRA)) |
| 41 | |
| 42 | all: $(obj).depend $(LIB) $(obj).depend $(EXTRA) $(CEXTRA) $(SEXTRA) check_initcode |
| 43 | |
| 44 | $(LIB): $(OBJS) |
| 45 | $(AR) $(ARFLAGS) $@ $(OBJS) |
| 46 | |
| 47 | $(OBJS): $(obj)bootrom-asm-offsets.h |
| 48 | $(obj)bootrom-asm-offsets.c: bootrom-asm-offsets.c.in bootrom-asm-offsets.awk |
| 49 | echo '#include <asm/mach-common/bits/bootrom.h>' | $(CPP) $(CPPFLAGS) - | gawk -f ./bootrom-asm-offsets.awk > $@.tmp |
| 50 | mv $@.tmp $@ |
| 51 | $(obj)bootrom-asm-offsets.s: $(obj)bootrom-asm-offsets.c |
| 52 | $(CC) $(CFLAGS) -S $^ -o $@.tmp |
| 53 | mv $@.tmp $@ |
| 54 | $(obj)bootrom-asm-offsets.h: $(obj)bootrom-asm-offsets.s |
| 55 | sed -ne "/^->/{s:^->\([^ ]*\) [\$$#]*\([^ ]*\) \(.*\):#define \1 \2 /* \3 */:; s:->::; p;}" $^ > $@ |
| 56 | |
| 57 | # make sure our initcode (which goes into LDR) does not |
| 58 | # have relocs or external references |
Mike Frysinger | 26bf0cbe | 2008-10-24 18:18:16 -0400 | [diff] [blame] | 59 | $(obj)initcode.o: CFLAGS += -fno-function-sections -fno-data-sections |
Mike Frysinger | 94bae5c | 2008-03-30 15:46:13 -0400 | [diff] [blame] | 60 | READINIT = env LC_ALL=C $(CROSS_COMPILE)readelf -s $< |
| 61 | check_initcode: $(obj)initcode.o |
| 62 | ifneq ($(CONFIG_BFIN_BOOT_MODE),BFIN_BOOT_BYPASS) |
| 63 | @if $(READINIT) | grep '\<GLOBAL\>.*\<UND\>' ; then \ |
| 64 | echo "$< contains external references!" 1>&2 ; \ |
| 65 | exit 1 ; \ |
| 66 | fi |
| 67 | endif |
| 68 | |
| 69 | ######################################################################### |
| 70 | |
| 71 | # defines $(obj).depend target |
| 72 | include $(SRCTREE)/rules.mk |
| 73 | |
| 74 | sinclude $(obj).depend |
| 75 | |
| 76 | ######################################################################### |