blob: 015b6b2a26b96676eadbae477d68ea4e82ebf340 [file] [log] [blame]
Chris Zankel8e1a6dd2005-06-23 22:01:10 -07001#
2# This file is subject to the terms and conditions of the GNU General Public
3# License. See the file "COPYING" in the main directory of this archive
4# for more details.
5#
6# Copyright (C) 2001 - 2005 Tensilica Inc.
7#
8# This file is included by the global makefile so that you can add your own
9# architecture-specific flags and dependencies. Remember to do have actions
10# for "archclean" and "archdep" for cleaning up and making dependencies for
11# this architecture
12
13# Core configuration.
Chris Zankel173d66812006-12-10 02:18:48 -080014# (Use VAR=<xtensa_config> to use another default compiler.)
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070015
Chris Zankel173d66812006-12-10 02:18:48 -080016variant-$(CONFIG_XTENSA_VARIANT_FSF) := fsf
Chris Zankel00254272008-10-21 09:11:43 -070017variant-$(CONFIG_XTENSA_VARIANT_DC232B) := dc232b
Chris Zankel173d66812006-12-10 02:18:48 -080018variant-$(CONFIG_XTENSA_VARIANT_LINUX_CUSTOM) := custom
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070019
Chris Zankel173d66812006-12-10 02:18:48 -080020VARIANT = $(variant-y)
21export VARIANT
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070022
23# Platform configuration
24
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070025platform-$(CONFIG_XTENSA_PLATFORM_XT2000) := xt2000
26platform-$(CONFIG_XTENSA_PLATFORM_ISS) := iss
27
28PLATFORM = $(platform-y)
29export PLATFORM
30
Chris Zankelb2444d32007-08-04 09:23:54 -070031# temporarily until string.h is fixed
Sam Ravnborga0f97e02007-10-14 22:21:35 +020032KBUILD_CFLAGS += -ffreestanding
Chris Zankelb2444d32007-08-04 09:23:54 -070033
Sam Ravnborga0f97e02007-10-14 22:21:35 +020034KBUILD_CFLAGS += -pipe -mlongcalls
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070035
Chris Zankele7d163f2005-06-30 02:58:59 -070036KBUILD_DEFCONFIG := iss_defconfig
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070037
38# ramdisk/initrd support
39# You need a compressed ramdisk image, named ramdisk.gz in
40# arch/xtensa/boot/ramdisk
41
42core-$(CONFIG_EMBEDDED_RAMDISK) += arch/xtensa/boot/ramdisk/
43
44# Test for cross compiling
45
Chris Zankel173d66812006-12-10 02:18:48 -080046ifneq ($(VARIANT),)
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070047 COMPILE_ARCH = $(shell uname -m)
48
49 ifneq ($(COMPILE_ARCH), xtensa)
50 ifndef CROSS_COMPILE
Chris Zankel173d66812006-12-10 02:18:48 -080051 CROSS_COMPILE = xtensa_$(VARIANT)-
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070052 endif
53 endif
54endif
55
56#
57
Sam Ravnborga0f97e02007-10-14 22:21:35 +020058LIBGCC := $(shell $(CC) $(KBUILD_CFLAGS) -print-libgcc-file-name)
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070059
60head-y := arch/xtensa/kernel/head.o
Chris Zankele7d163f2005-06-30 02:58:59 -070061core-y += arch/xtensa/kernel/ arch/xtensa/mm/
62ifneq ($(PLATFORM),)
Chris Zankelb26d0ab2007-09-13 13:44:07 -070063core-y += arch/xtensa/platforms/$(PLATFORM)/
Chris Zankele7d163f2005-06-30 02:58:59 -070064endif
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070065libs-y += arch/xtensa/lib/ $(LIBGCC)
66
Chris Zankele7d163f2005-06-30 02:58:59 -070067boot := arch/xtensa/boot
68
69archinc := include/asm-xtensa
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070070
Sam Ravnborg5bb78262005-09-11 22:30:22 +020071archprepare: $(archinc)/.platform
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070072
Chris Zankel173d66812006-12-10 02:18:48 -080073# Update processor variant and platform symlinks if something which affects
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070074# them changed.
75
Roman Zippel2e3646e2006-06-08 22:12:42 -070076$(archinc)/.platform: $(wildcard include/config/arch/*.h) include/config/auto.conf
Chris Zankel173d66812006-12-10 02:18:48 -080077 @echo ' SYMLINK $(archinc)/variant -> $(archinc)/variant-$(VARIANT)'
Chris Zankele7d163f2005-06-30 02:58:59 -070078 $(Q)mkdir -p $(archinc)
Chris Zankel173d66812006-12-10 02:18:48 -080079 $(Q)ln -fsn $(srctree)/$(archinc)/variant-$(VARIANT) $(archinc)/variant
Chris Zankele7d163f2005-06-30 02:58:59 -070080 @echo ' SYMLINK $(archinc)/platform -> $(archinc)/platform-$(PLATFORM)'
81 $(Q)ln -fsn $(srctree)/$(archinc)/platform-$(PLATFORM) $(archinc)/platform
82 @touch $@
83
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070084
85all: zImage
86
87bzImage : zImage
88
89zImage zImage.initrd: vmlinux
90 $(Q)$(MAKE) $(build)=$(boot) $@
91
Sam Ravnborg0013a852005-09-09 20:57:26 +020092CLEAN_FILES += arch/xtensa/vmlinux.lds \
Chris Zankel173d66812006-12-10 02:18:48 -080093 $(archinc)/platform $(archinc)/variant \
Chris Zankele7d163f2005-06-30 02:58:59 -070094 $(archinc)/.platform
Chris Zankel8e1a6dd2005-06-23 22:01:10 -070095
96define archhelp
97 @echo '* zImage - Compressed kernel image (arch/xtensa/boot/images/zImage.*)'
98endef
99