summaryrefslogtreecommitdiffstats
path: root/Makefile
diff options
context:
space:
mode:
Diffstat (limited to 'Makefile')
-rw-r--r--Makefile234
1 files changed, 170 insertions, 64 deletions
diff --git a/Makefile b/Makefile
index 26380dc13..25fe85fd3 100644
--- a/Makefile
+++ b/Makefile
@@ -1,9 +1,21 @@
-VERSION = 1
-PATCHLEVEL = 3
-SUBLEVEL = 0
+VERSION = 2
+PATCHLEVEL = 1
+SUBLEVEL = 14
ARCH = mips
+#
+# For SMP kernels, set this. We don't want to have this in the config file
+# because it makes re-config very ugly and too many fundamental files depend
+# on "CONFIG_SMP"
+#
+# NOTE! SMP is experimental. See the file Documentation/SMP.txt
+#
+# SMP = 1
+#
+# SMP profiling options
+# SMP_PROF = 1
+
.EXPORT_ALL_VARIABLES:
CONFIG_SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
@@ -11,15 +23,25 @@ CONFIG_SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
else echo sh; fi ; fi)
TOPDIR := $(shell if [ "$$PWD" != "" ]; then echo $$PWD; else pwd; fi)
-AS =as
-LD =ld
-HOSTCC =gcc -I$(TOPDIR)/include
-CC =gcc -D__KERNEL__ -I$(TOPDIR)/include
+HPATH = $(TOPDIR)/include
+FINDHPATH = $(HPATH)/asm $(HPATH)/linux $(HPATH)/scsi $(HPATH)/net
+
+HOSTCC =gcc
+HOSTCFLAGS =-O2 -fomit-frame-pointer
+
+CROSS_COMPILE =
+
+AS =$(CROSS_COMPILE)as
+LD =$(CROSS_COMPILE)ld
+CC =$(CROSS_COMPILE)gcc -D__KERNEL__ -I$(HPATH)
+CPP =$(CC) -E $(CFLAGS)
+AR =$(CROSS_COMPILE)ar
+NM =$(CROSS_COMPILE)nm
+STRIP =$(CROSS_COMPILE)strip
+RANLIB =$(CROSS_COMPILE)ranlib
+OBJCOPY =$(CROSS_COMPILE)objcopy
+OBJDUMP =$(CROSS_COMPILE)objdump
MAKE =make
-CPP =$(CC) -E
-AR =ar
-NM =nm
-STRIP =strip
all: do-it-all
@@ -46,9 +68,6 @@ endif
# This can be either FLOPPY, CURRENT, /dev/xxxx or empty, in which case
# the default of FLOPPY is used by 'build'.
#
-# NOTE: This does NOT work with Linux/MIPS yet. You need to hardcode
-# ROOT_DEV in arch/mips/kernel/setup.c !
-#
ROOT_DEV = CURRENT
@@ -77,6 +96,16 @@ ifdef CONFIG_CPP
CFLAGS := $(CFLAGS) -x c++
endif
+ifdef SMP
+CFLAGS += -D__SMP__
+AFLAGS += -D__SMP__
+
+ifdef SMP_PROF
+CFLAGS += -D__SMP_PROF__
+AFLAGS += -D__SMP_PROF__
+endif
+endif
+
#
# if you want the ram-disk device, define this to be the
# size in blocks.
@@ -87,19 +116,28 @@ endif
# Include the make variables (CC, etc...)
#
-ARCHIVES =kernel/kernel.o mm/mm.o fs/fs.o net/net.o ipc/ipc.o
+ARCHIVES =kernel/kernel.o mm/mm.o fs/fs.o ipc/ipc.o net/network.a
FILESYSTEMS =fs/filesystems.a
DRIVERS =drivers/block/block.a \
- drivers/char/char.a \
- drivers/net/net.a
+ drivers/char/char.a
LIBS =$(TOPDIR)/lib/lib.a
SUBDIRS =kernel drivers mm fs net ipc lib
-ifdef CONFIG_SCSI
+ifeq ($(CONFIG_ISDN),y)
+DRIVERS := $(DRIVERS) drivers/isdn/isdn.a
+endif
+
+DRIVERS := $(DRIVERS) drivers/net/net.a
+
+ifeq ($(CONFIG_SCSI),y)
DRIVERS := $(DRIVERS) drivers/scsi/scsi.a
endif
-ifdef CONFIG_SOUND
+ifneq ($(CONFIG_CD_NO_IDESCSI)$(CONFIG_BLK_DEV_IDECD)$(CONFIG_BLK_DEV_SR),)
+DRIVERS := $(DRIVERS) drivers/cdrom/cdrom.a
+endif
+
+ifeq ($(CONFIG_SOUND),y)
DRIVERS := $(DRIVERS) drivers/sound/sound.a
endif
@@ -107,21 +145,30 @@ ifdef CONFIG_PCI
DRIVERS := $(DRIVERS) drivers/pci/pci.a
endif
+ifdef CONFIG_SBUS
+DRIVERS := $(DRIVERS) drivers/sbus/sbus.a
+endif
+
include arch/$(ARCH)/Makefile
-.c.s:
- $(CC) $(CFLAGS) -S -o $*.s $<
-.s.o:
- $(AS) -o $*.o $<
-.c.o:
- $(CC) $(CFLAGS) -c -o $*.o $<
+ifdef SMP
+
.S.s:
- $(CC) -D__ASSEMBLY__ -traditional -E -o $*.o $<
+ $(CC) -D__ASSEMBLY__ $(AFLAGS) -traditional -E -o $*.s $<
+.S.o:
+ $(CC) -D__ASSEMBLY__ $(AFLAGS) -traditional -c -o $*.o $<
+
+else
+
+.S.s:
+ $(CC) -D__ASSEMBLY__ -traditional -E -o $*.s $<
.S.o:
$(CC) -D__ASSEMBLY__ -traditional -c -o $*.o $<
+endif
+
Version: dummy
- rm -f include/linux/version.h
+ @rm -f include/linux/compile.h
boot: vmlinux
@$(MAKE) -C arch/$(ARCH)/boot
@@ -139,42 +186,57 @@ symlinks:
( cd include ; ln -sf asm-$(ARCH) asm)
oldconfig: symlinks
- $(CONFIG_SHELL) Configure -d arch/$(ARCH)/config.in
+ $(CONFIG_SHELL) scripts/Configure -d arch/$(ARCH)/config.in
+
+xconfig: symlinks
+ $(MAKE) -C scripts kconfig.tk
+ wish -f scripts/kconfig.tk
+
+menuconfig: include/linux/version.h symlinks
+ $(MAKE) -C scripts/lxdialog all
+ $(CONFIG_SHELL) scripts/Menuconfig arch/$(ARCH)/config.in
config: symlinks
- $(CONFIG_SHELL) Configure arch/$(ARCH)/config.in
+ $(CONFIG_SHELL) scripts/Configure arch/$(ARCH)/config.in
linuxsubdirs: dummy
set -e; for i in $(SUBDIRS); do $(MAKE) -C $$i; done
$(TOPDIR)/include/linux/version.h: include/linux/version.h
+$(TOPDIR)/include/linux/compile.h: include/linux/compile.h
newversion:
@if [ ! -f .version ]; then \
echo 1 > .version; \
else \
- expr `cat .version` + 1 > .version; \
+ expr 0`cat .version` + 1 > .version; \
fi
-include/linux/version.h: $(CONFIGURATION) Makefile newversion
- @echo \#define UTS_RELEASE \"$(VERSION).$(PATCHLEVEL).$(SUBLEVEL)\" > include/linux/version.h
+include/linux/compile.h: $(CONFIGURATION) include/linux/version.h newversion
@if [ -f .name ]; then \
echo \#define UTS_VERSION \"\#`cat .version`-`cat .name` `date`\"; \
else \
echo \#define UTS_VERSION \"\#`cat .version` `date`\"; \
- fi >> include/linux/version.h
- @echo \#define LINUX_COMPILE_TIME \"`date +%T`\" >> include/linux/version.h
- @echo \#define LINUX_COMPILE_BY \"`whoami`\" >> include/linux/version.h
- @echo \#define LINUX_COMPILE_HOST \"`hostname`\" >> include/linux/version.h
+ fi >> .ver
+ @echo \#define LINUX_COMPILE_TIME \"`date +%T`\" >> .ver
+ @echo \#define LINUX_COMPILE_BY \"`whoami`\" >> .ver
+ @echo \#define LINUX_COMPILE_HOST \"`hostname`\" >> .ver
@if [ -x /bin/dnsdomainname ]; then \
echo \#define LINUX_COMPILE_DOMAIN \"`dnsdomainname`\"; \
- else \
+ elif [ -x /bin/domainname ]; then \
echo \#define LINUX_COMPILE_DOMAIN \"`domainname`\"; \
- fi >> include/linux/version.h
- @echo \#define LINUX_COMPILER \"`$(CC) -v 2>&1 | tail -1`\" >> include/linux/version.h
- @echo \#define LINUX_VERSION_CODE `expr $(VERSION) \\* 65536 + $(PATCHLEVEL) \\* 256 + $(SUBLEVEL)` >> include/linux/version.h
+ else \
+ echo \#define LINUX_COMPILE_DOMAIN ; \
+ fi >> .ver
+ @echo \#define LINUX_COMPILER \"`$(CC) -v 2>&1 | tail -1`\" >> .ver
+ @mv -f .ver $@
+
+include/linux/version.h: ./Makefile
+ @echo \#define UTS_RELEASE \"$(VERSION).$(PATCHLEVEL).$(SUBLEVEL)\" > .ver
+ @echo \#define LINUX_VERSION_CODE `expr $(VERSION) \\* 65536 + $(PATCHLEVEL) \\* 256 + $(SUBLEVEL)` >> .ver
+ @mv -f .ver $@
-init/version.o: init/version.c include/linux/version.h
+init/version.o: init/version.c include/linux/compile.h
$(CC) $(CFLAGS) -DUTS_MACHINE='"$(ARCH)"' -c -o init/version.o init/version.c
init/main.o: init/main.c
@@ -201,13 +263,18 @@ drivers: dummy
net: dummy
$(MAKE) linuxsubdirs SUBDIRS=net
+MODFLAGS = -DMODULE
+ifdef CONFIG_MODULES
ifdef CONFIG_MODVERSIONS
-MODV = -DCONFIG_MODVERSIONS
+MODFLAGS += -DMODVERSIONS -include $(HPATH)/linux/modversions.h
endif
modules: include/linux/version.h
- @set -e; for i in $(SUBDIRS); do $(MAKE) -C $$i CFLAGS="$(CFLAGS) -DMODULE $(MODV)" modules; done
-
+ @set -e; \
+ for i in $(SUBDIRS); \
+ do $(MAKE) -C $$i CFLAGS="$(CFLAGS) $(MODFLAGS)" MAKING_MODULES=1 modules; \
+ done
+
modules_install:
@( \
MODLIB=/lib/modules/$(VERSION).$(PATCHLEVEL).$(SUBLEVEL); \
@@ -218,9 +285,13 @@ modules_install:
echo Installing modules under $$MODLIB/$$2; \
}; \
\
- if [ -f NET_MODULES ]; then inst_mod NET_MODULES net; fi; \
- if [ -f SCSI_MODULES ]; then inst_mod SCSI_MODULES scsi; fi; \
- if [ -f FS_MODULES ]; then inst_mod FS_MODULES fs; fi; \
+ if [ -f BLOCK_MODULES ]; then inst_mod BLOCK_MODULES block; fi; \
+ if [ -f NET_MODULES ]; then inst_mod NET_MODULES net; fi; \
+ if [ -f IPV4_MODULES ]; then inst_mod IPV4_MODULES ipv4; fi; \
+ if [ -f IPV6_MODULES ]; then inst_mod IPV6_MODULES ipv6; fi; \
+ if [ -f SCSI_MODULES ]; then inst_mod SCSI_MODULES scsi; fi; \
+ if [ -f FS_MODULES ]; then inst_mod FS_MODULES fs; fi; \
+ if [ -f CDROM_MODULES ]; then inst_mod CDROM_MODULES cdrom; fi; \
\
ls *.o > .allmods; \
echo $$MODULES | tr ' ' '\n' | sort | comm -23 .allmods - > .misc; \
@@ -228,44 +299,69 @@ modules_install:
rm -f .misc .allmods; \
)
+# modules disabled....
+
+else
+modules modules_install: dummy
+ @echo
+ @echo "The present kernel configuration has modules disabled."
+ @echo "Type 'make config' and enable loadable module support."
+ @echo "Then build a kernel with module support enabled."
+ @echo
+ @exit 1
+endif
+
clean: archclean
- rm -f kernel/ksyms.lst
- rm -f core `find . -name '*.[oas]' -print`
+ rm -f kernel/ksyms.lst include/linux/compile.h
+ rm -f core `find . -name '*.[oas]' ! -regex '.*lxdialog/.*' -print`
rm -f core `find . -type f -name 'core' -print`
rm -f vmlinux System.map
rm -f .tmp* drivers/sound/configure
- rm -fr modules/*
+ rm -f modules/*
+ rm -f submenu*
mrproper: clean
rm -f include/linux/autoconf.h include/linux/version.h
- rm -f drivers/sound/local.h
+ rm -f drivers/sound/local.h drivers/sound/.defines
+ rm -f drivers/scsi/aic7xxx_asm drivers/scsi/aic7xxx_seq.h
+ rm -f drivers/char/uni_hash.tbl drivers/char/conmakehash
rm -f .version .config* config.in config.old
+ rm -f scripts/tkparse scripts/kconfig.tk scripts/kconfig.tmp
+ rm -f scripts/lxdialog/*.o scripts/lxdialog/lxdialog
+ rm -f .menuconfig .menuconfig.log
rm -f include/asm
rm -f .depend `find . -name .depend -print`
-ifdef CONFIG_MODVERSIONS
+ rm -f .hdepend scripts/mkdep
rm -f $(TOPDIR)/include/linux/modversions.h
rm -f $(TOPDIR)/include/linux/modules/*
-endif
+
distclean: mrproper
+ rm -f core `find . \( -name '*.orig' -o -name '*.rej' -o -name '*~' \
+ -o -name '*.bak' -o -name '#*#' -o -name '.*.orig' \
+ -o -name '.*.rej' -o -name '.SUMS' -o -size 0 \) -print` TAGS
backup: mrproper
- cd .. && tar cf - linux | gzip -9 > backup.gz
+ cd .. && tar cf - linux/ | gzip -9 > backup.gz
sync
-depend dep: archdep
- touch include/linux/version.h
- for i in init/*.c;do echo -n "init/";$(CPP) -M $$i;done > .tmpdepend
- set -e; for i in $(SUBDIRS); do $(MAKE) -C $$i dep; done
- rm -f include/linux/version.h
+sums:
+ find . -type f -print | sort | xargs sum > .SUMS
+
+dep-files: scripts/mkdep archdep include/linux/version.h
+ scripts/mkdep init/*.c > .tmpdepend
+ scripts/mkdep `find $(FINDHPATH) -follow -name \*.h ! -name modversions.h -print` > .hdepend
+ set -e; for i in $(SUBDIRS); do $(MAKE) -C $$i fastdep; done
mv .tmpdepend .depend
+
+MODVERFILE :=
+
ifdef CONFIG_MODVERSIONS
- @echo updating $(TOPDIR)/include/linux/modversions.h
- @(cd $(TOPDIR)/include/linux/modules; for f in *.ver;\
- do echo "#include <linux/modules/$${f}>"; done) \
- > $(TOPDIR)/include/linux/modversions.h
+MODVERFILE := $(TOPDIR)/include/linux/modversions.h
endif
+depend dep: dep-files $(MODVERFILE)
+
ifdef CONFIGURATION
..$(CONFIGURATION):
@echo
@@ -277,10 +373,20 @@ ifdef CONFIGURATION
@echo
exit 1
-dummy: ..$(CONFIGURATION)
+#dummy: ..$(CONFIGURATION)
+dummy:
else
dummy:
endif
+
+include Rules.make
+
+#
+# This generates dependencies for the .h files.
+#
+
+scripts/mkdep: scripts/mkdep.c
+ $(HOSTCC) $(HOSTCFLAGS) -o scripts/mkdep scripts/mkdep.c