source: trunk/softs/tsar_boot/Makefile @ 679

Last change on this file since 679 was 662, checked in by cfuguet, 11 years ago

Bugfix in tsar_boot makefile:

  • when defining makefile parameters (SOCLIB, RAMDISK, USE_DT), the assigned value is used instead of only their definition.

Example: make PLATFORM_DIR=<path> SOCLIB=1 RAMDISK=1

make PLATFORM_DIR=<path> SOCLIB=1 RAMDISK=0

In the former example, the preloader sould be compiled for
SOCLIB using RAMDISK.
In the latter the preloader should be compiled for SOCLIB
without using RAMDISK.

Before modifications in this commit, the two invocations examples
would result on SOCLIB using RAMDISK because the value was not
used but only the definition.

File size: 3.8 KB
RevLine 
[411]1# let the user have a default configuration (ie for PLATFORM_DIR and SOCLIB)
2-include ./build.mk
3
[425]4MAKECMDGOALS ?= none
[662]5RAMDISK      ?= 0
6SOCLIB       ?= 0
[293]7
[388]8ifneq ($(MAKECMDGOALS),$(filter $(MAKECMDGOALS),clean distclean clean-doc doc))
9  ifndef PLATFORM_DIR
10    $(error please define PLATFORM_DIR 'make PLATFORM_DIR=foo')
11  else
[662]12    ifeq ($(SOCLIB),1)
13      ifeq ($(RAMDISK),1)
[653]14        DEFS+= -DUSE_RDK
15      else
16        DEFS+= -DUSE_BDV
17      endif
[388]18      DTS=platform_soclib.dts
[586]19      $(info Make for $(PLATFORM_DIR), SocLib variant)
[388]20    else
[653]21      DEFS+= -DUSE_SPI
[388]22      DTS=platform_fpga.dts
[586]23      $(info Make for $(PLATFORM_DIR), FPGA variant)
[388]24    endif
25  endif
26endif
27
[653]28LD         := mipsel-unknown-elf-ld
29CC         := mipsel-unknown-elf-gcc
30AS         := mipsel-unknown-elf-as
31DU         := mipsel-unknown-elf-objdump
32RM         := rm -rf
33ECHO       := @echo
34MKDIR      := mkdir
35DTC        := dtc
36HEXDUMP    := hexdump
[388]37DOXYGEN    := doxygen
[293]38
39BUILD_DIR  := build
40SRCS_DIR   := src
41INCS_DIR   := include
42
43# =============================================================================
44# Include files paths
45# =============================================================================
46
[653]47INCLUDE    += -I. -I$(INCS_DIR) -I$(PLATFORM_DIR)
[293]48
49# =============================================================================
50# Paths of sources in another directories
51# =============================================================================
52
53VPATH      += $(SRCS_DIR)
54VPATH      += $(PLATFORM_DIR)
55
56# =============================================================================
57# Object files
58# =============================================================================
59
[586]60CFLAGS     := -Wall                \
61              -mno-gpopt           \
62              -ffreestanding       \
63              -fomit-frame-pointer \
64              -mips32              \
[653]65              -ggdb                \
[586]66              -mlong-calls         \
67              -Werror
[293]68
[653]69C_SRCS     := reset_elf_loader.c \
[586]70              reset_ioc.c        \
71              reset_utils.c      \
72              reset_tty.c        \
73              reset_exception.c
[406]74
[662]75ifeq ($(SOCLIB),0)
[406]76  C_SRCS   += sdcard.c spi.c
[293]77endif
78
[653]79S_SRCS     := reset.S
[293]80
81OBJS       := $(subst .c,.o, $(notdir $(C_SRCS)))
82OBJS       += $(subst .S,.o, $(notdir $(S_SRCS)))
83OBJS       := $(addprefix $(BUILD_DIR)/, $(OBJS))
84
[586]85TARGET     := preloader.elf
[293]86
[653]87USE_DT     ?= 1
[293]88
89all: $(TARGET)
90
[587]91 $(BUILD_DIR)/version.o: $(BUILD_DIR) $(OBJS) version version.sh
92        $(ECHO) "[version.sh]"
93        ./version.sh > $(BUILD_DIR)/version.c
94        $(ECHO) "[   CC    ]     $(BUILD_DIR)/version.c"
95        $(CC) $(DEFS) $(CFLAGS) $(INCLUDE) -c -o $@ $(BUILD_DIR)/version.c
96        $(DU) -D $@ > $@.txt
[502]97
[587]98$(TARGET): $(BUILD_DIR) $(BUILD_DIR)/version.o $(OBJS) $(PLATFORM_DIR)/ldscript $(BUILD_DIR)/platform.ld
[388]99        $(ECHO) "[   LD    ]     $@"
[587]100        $(LD) -o $@ -T $(PLATFORM_DIR)/ldscript $(OBJS) $(BUILD_DIR)/version.o
[293]101        $(DU) -D $@ > $@.txt
102
[425]103ifeq ($(USE_DT), 1)
[293]104$(BUILD_DIR)/platform.ld: $(BUILD_DIR)/platform.dtb
[388]105        $(ECHO) "[ HEXDUMP ]     $(notdir $<)"
[293]106        $(HEXDUMP) -v -e '"BYTE(0x" 1/1 "%02X" ")\n"' $< > $@
[425]107else
108$(BUILD_DIR)/platform.ld:
109        $(ECHO) "[  TOUCH  ]     $(notdir $@)"
110        touch $@
111endif
[293]112
113$(BUILD_DIR)/platform.dtb: $(DTS)
[388]114        $(ECHO) "[   DTC   ]     $(notdir $<)"
[390]115        ${DTC} -O dtb -o $@ $< &> /dev/null
[293]116
117$(BUILD_DIR):
118        $(MKDIR) $@
119
[388]120doc: Doxyfile
121        $(DOXYGEN) Doxyfile
122
[293]123clean:
124        $(RM) $(TARGET).txt $(TARGET) *~ $(BUILD_DIR)
125
[388]126clean-doc:
127        $(RM) doc
[293]128
[388]129distclean: clean clean-doc
130
[293]131# =============================================================================
132# Implicit makefile rules
133
134$(BUILD_DIR)/%.o: %.c
[388]135        $(ECHO) "[   CC    ]     $(notdir $<)"
[293]136        $(CC) $(DEFS) $(CFLAGS) $(INCLUDE) -c -o $@ $<
137        $(DU) -D $@ > $@.txt
138
139$(BUILD_DIR)/%.o: %.S
[388]140        $(ECHO) "[   AS    ]     $(notdir $<)"
[293]141        $(CC) $(DEFS) ${INCLUDE} -g -mips32 -c -o $@ $<
142        $(DU) -D $@ > $@.txt
143
[654]144.SILENT:
Note: See TracBrowser for help on using the repository browser.