d1a8a803e4
Eliminate the MOVEOBJ definition from tools/Config.mk, Makefiles, and other locations. The MOVEOBJ definition was used to work around the case where the object output of a compile or assemble is in a different directory than the source file. The ZDS-II tools have no command line option to perform this move; MOVEOBJ handled the move as a post-compiler operation. MOVEOBJ is no longer needed because this the ez80 COMPILE and ASSEMBLE definitions now handle all of the object file movement cases.
140 lines
4.2 KiB
Makefile
140 lines
4.2 KiB
Makefile
############################################################################
|
|
# mm/Makefile
|
|
#
|
|
# Copyright (C) 2007, 2012, 2013-2014, 2017 Gregory Nutt. All rights reserved.
|
|
# Author: Gregory Nutt <gnutt@nuttx.org>
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions
|
|
# are met:
|
|
#
|
|
# 1. Redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer.
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
# notice, this list of conditions and the following disclaimer in
|
|
# the documentation and/or other materials provided with the
|
|
# distribution.
|
|
# 3. Neither the name NuttX nor the names of its contributors may be
|
|
# used to endorse or promote products derived from this software
|
|
# without specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
# COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
# OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
#
|
|
############################################################################
|
|
|
|
-include $(TOPDIR)/Make.defs
|
|
|
|
# REVISIT: Backslash causes problems in $(COBJS) target
|
|
DELIM := $(strip /)
|
|
|
|
# CFLAGS
|
|
|
|
ifneq ($(CONFIG_BUILD_FLAT),y)
|
|
KDEFINE = ${shell $(DEFINE) "$(CC)" __KERNEL__}
|
|
endif
|
|
|
|
# Sources and paths
|
|
|
|
ASRCS =
|
|
CSRCS =
|
|
|
|
DEPPATH = --dep-path .
|
|
VPATH = .
|
|
|
|
include mm_heap/Make.defs
|
|
include umm_heap/Make.defs
|
|
include kmm_heap/Make.defs
|
|
include mm_gran/Make.defs
|
|
include shm/Make.defs
|
|
include iob/Make.defs
|
|
|
|
BINDIR ?= bin
|
|
|
|
AOBJS = $(patsubst %.S, $(BINDIR)$(DELIM)%$(OBJEXT), $(ASRCS))
|
|
COBJS = $(patsubst %.c, $(BINDIR)$(DELIM)%$(OBJEXT), $(CSRCS))
|
|
|
|
SRCS = $(ASRCS) $(CSRCS)
|
|
OBJS = $(AOBJS) $(COBJS)
|
|
|
|
UBIN = libumm$(LIBEXT)
|
|
KBIN = libkmm$(LIBEXT)
|
|
BIN ?= libmm$(LIBEXT)
|
|
|
|
all: $(BIN)
|
|
.PHONY: clean distclean
|
|
|
|
$(AOBJS): $(BINDIR)$(DELIM)%$(OBJEXT): %.S
|
|
$(call ASSEMBLE, $<, $@)
|
|
|
|
$(COBJS): $(BINDIR)$(DELIM)%$(OBJEXT): %.c
|
|
$(call COMPILE, $<, $@)
|
|
|
|
# Memory manager for the flat build
|
|
|
|
$(BIN): $(OBJS)
|
|
$(call ARCHIVE, $@, $(OBJS))
|
|
|
|
# Memory manager for the user phase of the two-pass kernel build
|
|
|
|
ifneq ($(BIN),$(UBIN))
|
|
$(UBIN):
|
|
$(Q) $(MAKE) $(UBIN) BIN=$(UBIN) BINDIR=ubin TOPDIR=$(TOPDIR) EXTRADEFINES=$(EXTRADEFINES)
|
|
endif
|
|
|
|
# Memory manager for the kernel phase of the two-pass kernel build
|
|
|
|
ifneq ($(BIN),$(KBIN))
|
|
$(KBIN):
|
|
$(Q) $(MAKE) $(KBIN) BIN=$(KBIN) BINDIR=kbin TOPDIR=$(TOPDIR) EXTRADEFINES=$(EXTRADEFINES)
|
|
endif
|
|
|
|
# Dependencies
|
|
|
|
.depend: Makefile $(SRCS)
|
|
ifeq ($(CONFIG_BUILD_FLAT),y)
|
|
$(Q) $(MKDEP) --obj-path bin --obj-suffix $(OBJEXT) $(DEPPATH) "$(CC)" -- $(CFLAGS) -- $(SRCS) >bin/Make.dep
|
|
else
|
|
$(Q) $(MKDEP) --obj-path ubin --obj-suffix $(OBJEXT) $(DEPPATH) "$(CC)" -- $(CFLAGS) -- $(SRCS) >ubin/Make.dep
|
|
$(Q) $(MKDEP) --obj-path kbin --obj-suffix $(OBJEXT) $(DEPPATH) "$(CC)" -- $(CFLAGS) $(KDEFINE) -- $(SRCS) >kbin/Make.dep
|
|
endif
|
|
$(Q) touch $@
|
|
|
|
depend: .depend
|
|
|
|
# Clean most derived files, retaining the configuration
|
|
|
|
clean:
|
|
$(Q) $(MAKE) -C bin clean TOPDIR=$(TOPDIR)
|
|
$(Q) $(MAKE) -C ubin clean TOPDIR=$(TOPDIR)
|
|
$(Q) $(MAKE) -C kbin clean TOPDIR=$(TOPDIR)
|
|
$(call DELFILE, $(BIN))
|
|
$(call DELFILE, $(UBIN))
|
|
$(call DELFILE, $(KBIN))
|
|
$(call CLEAN)
|
|
|
|
# Deep clean -- removes all traces of the configuration
|
|
|
|
distclean: clean
|
|
$(Q) $(MAKE) -C bin distclean TOPDIR=$(TOPDIR)
|
|
$(Q) $(MAKE) -C ubin distclean TOPDIR=$(TOPDIR)
|
|
$(Q) $(MAKE) -C kbin distclean TOPDIR=$(TOPDIR)
|
|
$(call DELFILE, bin/Make.dep)
|
|
$(call DELFILE, ubin/Make.dep)
|
|
$(call DELFILE, kbin/Make.dep)
|
|
$(call DELFILE, .depend)
|
|
|
|
-include bin/Make.dep
|
|
-include ubin/Make.dep
|
|
-include kbin/Make.dep
|