2007-11-30 23:07:06 +08:00
|
|
|
#
|
2005-04-17 06:20:36 +08:00
|
|
|
# cris/Makefile
|
|
|
|
#
|
|
|
|
# This file is included by the global makefile so that you can add your own
|
|
|
|
# architecture-specific flags and dependencies. Remember to do have actions
|
|
|
|
# for "archclean" and "archdep" for cleaning up and making dependencies for
|
|
|
|
# this architecture
|
|
|
|
#
|
|
|
|
# This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
# License. See the file "COPYING" in the main directory of this archive
|
|
|
|
# for more details.
|
|
|
|
|
2008-02-27 01:47:03 +08:00
|
|
|
KBUILD_DEFCONFIG := etrax-100lx_v2_defconfig
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
arch-y := v10
|
|
|
|
arch-$(CONFIG_ETRAX_ARCH_V10) := v10
|
2005-07-28 02:44:30 +08:00
|
|
|
arch-$(CONFIG_ETRAX_ARCH_V32) := v32
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2007-11-30 23:07:06 +08:00
|
|
|
# No config available for make clean etc
|
|
|
|
mach-y := fs
|
|
|
|
mach-$(CONFIG_CRIS_MACH_ARTPEC3) := a3
|
|
|
|
mach-$(CONFIG_ETRAXFS) := fs
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
ifneq ($(arch-y),)
|
|
|
|
SARCH := arch-$(arch-y)
|
2008-10-21 23:45:58 +08:00
|
|
|
inc := -Iarch/cris/include/arch-$(arch-y) -Iarch/cris/include/arch-$(arch-y)/arch
|
2005-04-17 06:20:36 +08:00
|
|
|
else
|
|
|
|
SARCH :=
|
2008-10-21 23:45:58 +08:00
|
|
|
inc :=
|
2005-04-17 06:20:36 +08:00
|
|
|
endif
|
|
|
|
|
2007-11-30 23:07:06 +08:00
|
|
|
ifneq ($(mach-y),)
|
|
|
|
MACH := mach-$(mach-y)
|
2008-10-21 23:45:58 +08:00
|
|
|
inc += -Iarch/cris/include/$(SARCH)/$(MACH)/
|
|
|
|
inc += -Iarch/cris/include/$(SARCH)/$(MACH)/mach
|
2007-11-30 23:07:06 +08:00
|
|
|
else
|
|
|
|
MACH :=
|
|
|
|
endif
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
LD = $(CROSS_COMPILE)ld -mcrislinux
|
|
|
|
|
|
|
|
OBJCOPYFLAGS := -O binary -R .note -R .comment -S
|
|
|
|
|
|
|
|
CPPFLAGS_vmlinux.lds = -DDRAM_VIRTUAL_BASE=0x$(CONFIG_ETRAX_DRAM_VIRTUAL_BASE)
|
|
|
|
|
2008-10-21 23:45:58 +08:00
|
|
|
KBUILD_AFLAGS += -mlinux -march=$(arch-y) $(inc)
|
|
|
|
KBUILD_CFLAGS += -mlinux -march=$(arch-y) -pipe $(inc)
|
|
|
|
KBUILD_CPPFLAGS += $(inc)
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
ifdef CONFIG_FRAME_POINTER
|
2007-10-15 04:21:35 +08:00
|
|
|
KBUILD_CFLAGS := $(subst -fomit-frame-pointer,,$(KBUILD_CFLAGS)) -g
|
|
|
|
KBUILD_CFLAGS += -fno-omit-frame-pointer
|
2005-04-17 06:20:36 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
head-y := arch/$(ARCH)/$(SARCH)/kernel/head.o
|
|
|
|
|
2007-10-15 04:21:35 +08:00
|
|
|
LIBGCC = $(shell $(CC) $(KBUILD_CFLAGS) -print-file-name=libgcc.a)
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
core-y += arch/$(ARCH)/kernel/ arch/$(ARCH)/mm/
|
|
|
|
core-y += arch/$(ARCH)/$(SARCH)/kernel/ arch/$(ARCH)/$(SARCH)/mm/
|
2007-11-30 23:07:06 +08:00
|
|
|
ifdef CONFIG_ETRAX_ARCH_V32
|
|
|
|
core-y += arch/$(ARCH)/$(SARCH)/$(MACH)/
|
|
|
|
endif
|
2005-04-17 06:20:36 +08:00
|
|
|
drivers-y += arch/$(ARCH)/$(SARCH)/drivers/
|
|
|
|
libs-y += arch/$(ARCH)/$(SARCH)/lib/ $(LIBGCC)
|
|
|
|
|
2005-07-28 02:44:30 +08:00
|
|
|
# cris source path
|
|
|
|
SRC_ARCH = $(srctree)/arch/$(ARCH)
|
|
|
|
# cris object files path
|
|
|
|
OBJ_ARCH = $(objtree)/arch/$(ARCH)
|
|
|
|
|
2007-11-30 23:07:06 +08:00
|
|
|
boot := arch/$(ARCH)/boot
|
|
|
|
MACHINE := arch/$(ARCH)/$(SARCH)
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2007-11-30 23:07:06 +08:00
|
|
|
all: zImage
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2007-11-30 23:07:06 +08:00
|
|
|
zImage Image: vmlinux
|
|
|
|
$(Q)$(MAKE) $(build)=$(boot) MACHINE=$(MACHINE) $(boot)/$@
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2008-10-21 23:45:58 +08:00
|
|
|
archprepare: $(SRC_ARCH)/.links FORCE
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
# Create some links to make all tools happy
|
2005-07-28 02:44:30 +08:00
|
|
|
$(SRC_ARCH)/.links:
|
|
|
|
@rm -rf $(SRC_ARCH)/drivers
|
2007-11-30 23:07:06 +08:00
|
|
|
@ln -sfn $(SARCH)/drivers $(SRC_ARCH)/drivers
|
2005-07-28 02:44:30 +08:00
|
|
|
@rm -rf $(SRC_ARCH)/boot
|
2007-11-30 23:07:06 +08:00
|
|
|
@ln -sfn $(SARCH)/boot $(SRC_ARCH)/boot
|
2005-07-28 02:44:30 +08:00
|
|
|
@rm -rf $(SRC_ARCH)/lib
|
2007-11-30 23:07:06 +08:00
|
|
|
@ln -sfn $(SARCH)/lib $(SRC_ARCH)/lib
|
|
|
|
@rm -f $(SRC_ARCH)/arch/mach
|
|
|
|
@rm -rf $(SRC_ARCH)/arch
|
|
|
|
@ln -sfn $(SARCH) $(SRC_ARCH)/arch
|
|
|
|
ifdef CONFIG_ETRAX_ARCH_V32
|
|
|
|
@ln -sfn ../$(SARCH)/$(MACH) $(SRC_ARCH)/arch/mach
|
|
|
|
endif
|
|
|
|
@rm -rf $(SRC_ARCH)/kernel/vmlinux.lds.S
|
|
|
|
@ln -sfn ../$(SARCH)/vmlinux.lds.S $(SRC_ARCH)/kernel/vmlinux.lds.S
|
|
|
|
@rm -rf $(SRC_ARCH)/kernel/asm-offsets.c
|
|
|
|
@ln -sfn ../$(SARCH)/kernel/asm-offsets.c $(SRC_ARCH)/kernel/asm-offsets.c
|
2005-04-17 06:20:36 +08:00
|
|
|
@touch $@
|
|
|
|
|
2007-11-30 23:07:06 +08:00
|
|
|
archclean:
|
|
|
|
$(Q)if [ -e arch/$(ARCH)/boot ]; then \
|
|
|
|
$(MAKE) $(clean)=arch/$(ARCH)/boot; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
CLEAN_FILES += \
|
|
|
|
$(MACHINE)/boot/zImage \
|
|
|
|
$(MACHINE)/boot/compressed/decompress.bin \
|
|
|
|
$(MACHINE)/boot/compressed/piggy.gz \
|
|
|
|
$(MACHINE)/boot/rescue/rescue.bin \
|
2008-10-21 23:45:58 +08:00
|
|
|
$(SRC_ARCH)/.links
|
2007-11-30 23:07:06 +08:00
|
|
|
|
|
|
|
MRPROPER_FILES += \
|
|
|
|
$(SRC_ARCH)/drivers \
|
|
|
|
$(SRC_ARCH)/boot \
|
|
|
|
$(SRC_ARCH)/lib \
|
|
|
|
$(SRC_ARCH)/arch \
|
|
|
|
$(SRC_ARCH)/kernel/vmlinux.lds.S \
|
|
|
|
$(SRC_ARCH)/kernel/asm-offsets.c
|
|
|
|
|
|
|
|
define archhelp
|
|
|
|
echo '* zImage - Compressed kernel image (arch/$(ARCH)/boot/zImage)'
|
|
|
|
echo '* Image - Uncompressed kernel image (arch/$(ARCH)/boot/Image)'
|
|
|
|
endef
|