head	1.6;
access;
symbols
	perseant-exfatfs-base-20250801:1.6
	perseant-exfatfs-base-20240630:1.6
	perseant-exfatfs:1.6.0.140
	perseant-exfatfs-base:1.6
	bouyer-sunxi-drm:1.6.0.138
	bouyer-sunxi-drm-base:1.6
	cjep_sun2x:1.6.0.136
	cjep_sun2x-base:1.6
	cjep_staticlib_x-base1:1.6
	cjep_staticlib_x:1.6.0.134
	cjep_staticlib_x-base:1.6
	thorpej-futex-base:1.6
	bouyer-xenpvh-base2:1.6
	phil-wifi-20200421:1.6
	bouyer-xenpvh-base1:1.6
	phil-wifi-20200411:1.6
	bouyer-xenpvh:1.6.0.132
	bouyer-xenpvh-base:1.6
	phil-wifi-20200406:1.6
	ad-namecache-base3:1.6
	ad-namecache-base2:1.6
	ad-namecache-base1:1.6
	ad-namecache:1.6.0.130
	ad-namecache-base:1.6
	isaki-audio2:1.6.0.128
	isaki-audio2-base:1.6
	pgoyette-compat-merge-20190127:1.6
	pgoyette-compat-20190127:1.6
	pgoyette-compat-20190118:1.6
	pgoyette-compat-1226:1.6
	pgoyette-compat-1126:1.6
	pgoyette-compat-1020:1.6
	pgoyette-compat-0930:1.6
	pgoyette-compat-0906:1.6
	pgoyette-compat-0728:1.6
	pgoyette-compat-0625:1.6
	pgoyette-compat-0521:1.6
	pgoyette-compat-0502:1.6
	pgoyette-compat-0422:1.6
	pgoyette-compat-0415:1.6
	pgoyette-compat-0407:1.6
	pgoyette-compat-0330:1.6
	pgoyette-compat-0322:1.6
	pgoyette-compat-0315:1.6
	pgoyette-compat:1.6.0.8
	pgoyette-compat-base:1.6
	perseant-stdc-iso10646:1.6.0.126
	perseant-stdc-iso10646-base:1.6
	prg-localcount2-base3:1.6
	prg-localcount2-base2:1.6
	prg-localcount2-base1:1.6
	prg-localcount2:1.6.0.124
	prg-localcount2-base:1.6
	pgoyette-localcount-20170426:1.6
	bouyer-socketcan-base1:1.6
	pgoyette-localcount-20170320:1.6
	bouyer-socketcan:1.6.0.122
	bouyer-socketcan-base:1.6
	pgoyette-localcount-20170107:1.6
	pgoyette-localcount-20161104:1.6
	localcount-20160914:1.6
	pgoyette-localcount-20160806:1.6
	pgoyette-localcount-20160726:1.6
	pgoyette-localcount:1.6.0.120
	pgoyette-localcount-base:1.6
	netbsd-5-2-3-RELEASE:1.6
	netbsd-5-1-5-RELEASE:1.6
	yamt-pagecache-base9:1.6
	yamt-pagecache-tag8:1.6
	tls-earlyentropy:1.6.0.118
	tls-earlyentropy-base:1.6
	riastradh-xf86-video-intel-2-7-1-pre-2-21-15:1.6
	riastradh-drm2-base3:1.6
	netbsd-5-2-2-RELEASE:1.6
	netbsd-5-1-4-RELEASE:1.6
	netbsd-5-2-1-RELEASE:1.6
	netbsd-5-1-3-RELEASE:1.6
	rmind-smpnet-nbase:1.6
	rmind-smpnet:1.6.0.114
	rmind-smpnet-base:1.6
	agc-symver:1.6.0.116
	agc-symver-base:1.6
	tls-maxphys-base:1.6
	yamt-pagecache-base8:1.6
	netbsd-5-2:1.6.0.112
	yamt-pagecache-base7:1.6
	netbsd-5-2-RELEASE:1.6
	netbsd-5-2-RC1:1.6
	yamt-pagecache-base6:1.6
	yamt-pagecache-base5:1.6
	yamt-pagecache-base4:1.6
	netbsd-5-1-2-RELEASE:1.6
	netbsd-5-1-1-RELEASE:1.6
	jmcneill-usbmp:1.6.0.110
	jmcneill-usbmp-base:1.6
	jmcneill-audiomp3:1.6.0.108
	jmcneill-audiomp3-base:1.6
	yamt-pagecache-base3:1.6
	yamt-pagecache-base2:1.6
	yamt-pagecache:1.6.0.106
	yamt-pagecache-base:1.6
	rmind-uvmplock-nbase:1.6
	jym-xensuspend-nbase:1.6
	bouyer-quota2-nbase:1.6
	bouyer-quota2:1.6.0.104
	bouyer-quota2-base:1.6
	jruoho-x86intr:1.6.0.102
	jruoho-x86intr-base:1.6
	matt-nb5-pq3:1.6.0.100
	matt-nb5-pq3-base:1.6
	netbsd-5-1:1.6.0.98
	netbsd-5-1-RELEASE:1.6
	yamt-nfs-mp-base11:1.6
	netbsd-5-1-RC4:1.6
	uebayasi-xip-base2:1.6
	yamt-nfs-mp-base10:1.6
	netbsd-5-1-RC3:1.6
	netbsd-5-1-RC2:1.6
	netbsd-5-1-RC1:1.6
	rmind-uvmplock:1.6.0.96
	rmind-uvmplock-base:1.6
	yamt-nfs-mp-base9:1.6
	uebayasi-xip:1.6.0.94
	uebayasi-xip-base:1.6
	netbsd-5-0-2-RELEASE:1.6
	yamt-nfs-mp-base8:1.6
	yamt-nfs-mp-base7:1.6
	netbsd-5-0-1-RELEASE:1.6
	jymxensuspend-base:1.6
	yamt-nfs-mp-base6:1.6
	yamt-nfs-mp-base5:1.6
	yamt-nfs-mp-base4:1.6
	yamt-nfs-mp-base3:1.6
	netbsd-5-0:1.6.0.92
	netbsd-5-0-RELEASE:1.6
	netbsd-5-0-RC4:1.6
	netbsd-5-0-RC3:1.6
	netbsd-5-0-RC2:1.6
	jym-xensuspend:1.6.0.90
	jym-xensuspend-base:1.6
	netbsd-5-0-RC1:1.6
	haad-dm-base2:1.6
	haad-nbase2:1.6
	ad-audiomp2:1.6.0.88
	ad-audiomp2-base:1.6
	netbsd-5:1.6.0.86
	netbsd-5-base:1.6
	haad-dm-base1:1.6
	haad-dm:1.6.0.84
	haad-dm-base:1.6
	simonb-wapbl-nbase:1.6
	yamt-pf42-base4:1.6
	simonb-wapbl:1.6.0.82
	simonb-wapbl-base:1.6
	yamt-pf42-base3:1.6
	hpcarm-cleanup-nbase:1.6
	yamt-pf42-base2:1.6
	yamt-nfs-mp-base2:1.6
	yamt-nfs-mp:1.6.0.80
	yamt-nfs-mp-base:1.6
	yamt-pf42:1.6.0.78
	yamt-pf42-base:1.6
	ad-socklock-base1:1.6
	yamt-lazymbuf-base15:1.6
	yamt-lazymbuf-base14:1.6
	keiichi-mipv6-nbase:1.6
	mjf-devfs2:1.6.0.76
	mjf-devfs2-base:1.6
	keiichi-mipv6:1.6.0.74
	keiichi-mipv6-base:1.6
	bouyer-xeni386-merge1:1.6
	vmlocking2-base3:1.6
	bouyer-xeni386-nbase:1.6
	yamt-kmem-base3:1.6
	cube-autoconf:1.6.0.72
	cube-autoconf-base:1.6
	yamt-kmem-base2:1.6
	bouyer-xeni386:1.6.0.70
	bouyer-xeni386-base:1.6
	yamt-kmem:1.6.0.68
	yamt-kmem-base:1.6
	vmlocking2-base2:1.6
	reinoud-bufcleanup-nbase:1.6
	vmlocking2:1.6.0.66
	vmlocking2-base1:1.6
	jmcneill-base:1.6
	mjf-devfs:1.6.0.64
	mjf-devfs-base:1.6
	bouyer-xenamd64-base2:1.6
	vmlocking-nbase:1.6
	yamt-x86pmap-base4:1.6
	bouyer-xenamd64:1.6.0.62
	bouyer-xenamd64-base:1.6
	yamt-x86pmap-base3:1.6
	yamt-x86pmap-base2:1.6
	yamt-x86pmap:1.6.0.60
	yamt-x86pmap-base:1.6
	jmcneill-pm:1.6.0.58
	jmcneill-pm-base:1.6
	hpcarm-cleanup:1.6.0.56
	hpcarm-cleanup-base:1.6
	mjf-ufs-trans-base:1.6
	yamt-idlelwp-base8:1.6
	ppcoea-renovation:1.6.0.54
	ppcoea-renovation-base:1.6
	reinoud-bufcleanup-base:1.6
	vmlocking:1.6.0.52
	vmlocking-base:1.6
	ad-audiomp:1.6.0.50
	ad-audiomp-base:1.6
	yamt-idlelwp:1.6.0.48
	post-newlock2-merge:1.6
	newlock2-nbase:1.6
	yamt-splraiseipl-base5:1.6
	yamt-splraiseipl-base4:1.6
	yamt-splraiseipl-base3:1.6
	yamt-splraiseipl-base2:1.6
	yamt-splraiseipl:1.6.0.46
	yamt-splraiseipl-base:1.6
	newlock2:1.6.0.44
	newlock2-base:1.6
	yamt-pdpolicy-base8:1.6
	yamt-pdpolicy-base7:1.6
	yamt-pdpolicy-base6:1.6
	gdamore-uart:1.6.0.42
	gdamore-uart-base:1.6
	simonb-timcounters-final:1.6
	yamt-pdpolicy-base5:1.6
	elad-kernelauth-nbase:1.6
	yamt-pdpolicy-base4:1.6
	yamt-pdpolicy-base3:1.6
	yamt-pdpolicy-base2:1.6
	yamt-pdpolicy:1.6.0.40
	yamt-pdpolicy-base:1.6
	yamt-uio_vmspace-base5:1.6
	simonb-timecounters:1.6.0.38
	simonb-timecounters-base:1.6
	rpaulo-netinet-merge-pcb:1.6.0.36
	rpaulo-netinet-merge-pcb-base:1.6
	yamt-uio_vmspace:1.6.0.34
	yamt-readahead-base3:1.6
	yamt-readahead-base2:1.6
	yamt-readahead:1.6.0.32
	yamt-readahead-base:1.6
	yamt-vop-base3:1.6
	yamt-vop-base2:1.6
	thorpej-vnode-attr:1.6.0.30
	thorpej-vnode-attr-base:1.6
	yamt-vop:1.6.0.28
	yamt-vop-base:1.6
	yamt-lazymbuf:1.6.0.26
	yamt-km-base4:1.6
	yamt-km-base3:1.6
	yamt-km-base2:1.6
	yamt-km:1.6.0.24
	yamt-km-base:1.6
	kent-audio2:1.6.0.22
	kent-audio2-base:1.6
	ktrace-lwp:1.6.0.20
	ktrace-lwp-base:1.6
	nathanw_sa_before_merge:1.6
	gmcgarry_ctxsw:1.6.0.18
	gmcgarry_ctxsw_base:1.6
	gmcgarry_ucred:1.6.0.16
	gmcgarry_ucred_base:1.6
	nathanw_sa_base:1.6
	gehenna-devsw:1.6.0.14
	gehenna-devsw-base:1.6
	netbsd-1-5-PATCH003:1.5
	eeh-devprop:1.6.0.12
	eeh-devprop-base:1.6
	newlock:1.6.0.10
	newlock-base:1.6
	ifpoll-base:1.6
	thorpej-mips-cache:1.6.0.6
	thorpej-mips-cache-base:1.6
	thorpej-devvp:1.6.0.4
	thorpej-devvp-base:1.6
	netbsd-1-5-PATCH002:1.5
	kqueue:1.6.0.2
	kqueue-base:1.6
	netbsd-1-5-PATCH001:1.5
	thorpej_scsipi_beforemerge:1.6
	thorpej_scsipi_nbase:1.6
	thorpej_scsipi_base:1.6
	thorpej_scsipi:1.5.0.6
	netbsd-1-5-RELEASE:1.5
	netbsd-1-5-BETA2:1.5
	netbsd-1-5-BETA:1.5
	netbsd-1-5-ALPHA2:1.5
	netbsd-1-5:1.5.0.4
	netbsd-1-5-base:1.5
	minoura-xpg4dl:1.5.0.2
	minoura-xpg4dl-base:1.5;
locks; strict;
comment	@# @;


1.6
date	2000.12.03.07.59.47;	author matt;	state dead;
branches;
next	1.5;

1.5
date	2000.05.21.02.50.11;	author soren;	state Exp;
branches
	1.5.6.1;
next	1.4;

1.4
date	2000.05.09.00.56.23;	author hubertf;	state Exp;
branches;
next	1.3;

1.3
date	2000.05.09.00.32.21;	author thorpej;	state Exp;
branches;
next	1.2;

1.2
date	2000.03.30.20.08.37;	author soren;	state Exp;
branches;
next	1.1;

1.1
date	2000.03.19.23.07.44;	author soren;	state Exp;
branches;
next	;

1.5.6.1
date	2000.05.21.02.50.11;	author bouyer;	state dead;
branches;
next	1.5.6.2;

1.5.6.2
date	2000.11.20.20.07.01;	author bouyer;	state Exp;
branches;
next	1.5.6.3;

1.5.6.3
date	2000.12.08.09.26.26;	author bouyer;	state dead;
branches;
next	;


desc
@@


1.6
log
@Use shared Makefile.mips
@
text
@#	$NetBSD: Makefile.cobalt,v 1.5 2000/05/21 02:50:11 soren Exp $

# Makefile for NetBSD
#
# This makefile is constructed from a machine description:
#	config machineid
# Most changes should be made in the machine description
#	/sys/arch/cobalt/conf/``machineid''
# after which you should do
#	config machineid
# Machine generic makefile changes should be made in
#	/sys/arch/cobalt/conf/Makefile.cobalt
# after which config should be rerun for all machines of that type.
#
# N.B.: NO DEPENDENCIES ON FOLLOWING FLAGS ARE VISIBLE TO MAKEFILE
#	IF YOU CHANGE THE DEFINITION OF ANY OF THESE RECOMPILE EVERYTHING
#
# -DTRACE	compile in kernel tracing hooks
# -DQUOTA	compile in file system quotas

# DEBUG is set to -g if debugging.
# PROF is set to -pg if profiling.

AR?=		ar
AS?=		as
CC?=		cc
CPP?=		cpp
LD?=		ld
LORDER?=	lorder
MKDEP?=		mkdep
NM?=		nm
RANLIB?=	ranlib
SIZE?=		size
STRIP?=		strip
TSORT?=		tsort -q

COPTS?=		-O2

TEXTADDR?=	0x80001000

# source tree is located via $S relative to the compilation directory
.ifndef S
#S!=	cd ../../../..; pwd
S=	../../../..
.endif
COBALT= $S/arch/cobalt
MIPS=	$S/arch/mips

HAVE_EGCS!=	${CC} --version | egrep "^(2\.[89]|egcs)" ; echo
INCLUDES=	-I. -I$S/arch -I$S -nostdinc
CPPFLAGS=	${INCLUDES} ${IDENT} ${PARAM} -D_KERNEL -Dcobalt
CWARNFLAGS?=	-Wall -Werror -Wstrict-prototypes -Wmissing-prototypes \
		-Wpointer-arith
# XXX Delete -Wuninitialized for now, since the compiler doesn't
# XXX always get it right.  --thorpej 
CWARNFLAGS+=    -Wno-uninitialized
.if (${HAVE_EGCS} != "")
CWARNFLAGS+=	-Wno-main
.endif
GP?=		-G 0
CFLAGS=		${DEBUG} ${COPTS} ${CWARNFLAGS} ${GP} \
		-mno-abicalls -mno-half-pic
AFLAGS=		-x assembler-with-cpp -traditional-cpp -D_LOCORE
LINKFLAGS=	-T${MIPS}/conf/kern.ldscript.le -Ttext ${TEXTADDR} \
		-e start ${GP}
STRIPFLAGS=	-g -X -x

%INCLUDES

### find out what to use for libkern
.include "$S/lib/libkern/Makefile.inc"
.ifndef PROF
LIBKERN=	${KERNLIB}
.else
LIBKERN=	${KERNLIB_PROF}
.endif

### find out what to use for libcompat
.include "$S/compat/common/Makefile.inc"
.ifndef PROF
LIBCOMPAT=	${COMPATLIB}
.else
LIBCOMPAT=	${COMPATLIB_PROF}
.endif

# compile rules: rules are named ${TYPE}_${SUFFIX} where TYPE is NORMAL or
# HOSTED}, and SUFFIX is the file suffix, capitalized (e.g. C for a .c file).

NORMAL_C=	${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $<
NOPROF_C=	${CC} ${CFLAGS} ${CPPFLAGS} -c $<
NORMAL_S=	${CC} ${AFLAGS} ${CPPFLAGS} -c $<

%OBJS

%CFILES

%SFILES

# load lines for config "xxx" will be emitted as:
# xxx: ${SYSTEM_DEP} swapxxx.o
#	${SYSTEM_LD_HEAD}
#	${SYSTEM_LD} swapxxx.o
#	${SYSTEM_LD_TAIL}
SYSTEM_OBJ=	locore.o locore_machdep.o
.if !empty(IDENT:M-DMIPS1)
SYSTEM_OBJ+=	locore_mips1.o
.endif
.if !empty(IDENT:M-DMIPS3)
SYSTEM_OBJ+=	locore_mips3.o
.endif
SYSTEM_OBJ+=	fp.o param.o ioconf.o ${OBJS} ${LIBKERN} ${LIBCOMPAT}
SYSTEM_DEP=	Makefile ${SYSTEM_OBJ}
SYSTEM_LD_HEAD=	@@rm -f $@@
SYSTEM_LD=	@@echo ${LD} ${LINKFLAGS} -o $@@ '$${SYSTEM_OBJ}' vers.o ; \
		${LD} ${LINKFLAGS} -o $@@ ${SYSTEM_OBJ} vers.o
SYSTEM_LD_TAIL=	@@${SIZE} $@@; chmod 755 $@@

DEBUG?=
.if ${DEBUG} == "-g"
LINKFLAGS+=	-X
SYSTEM_LD_TAIL+=; \
		echo mv -f $@@ $@@.gdb; mv -f $@@ $@@.gdb; \
		echo ${STRIP} ${STRIPFLAGS} -o $@@ $@@.gdb; \
		${STRIP} ${STRIPFLAGS} -o $@@ $@@.gdb
.else
LINKFLAGS+=	-x
.endif

%LOAD

assym.h: $S/kern/genassym.sh ${MIPS}/mips/genassym.cf
	sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} \
	  < ${MIPS}/mips/genassym.cf > assym.h.tmp && \
	mv -f assym.h.tmp assym.h


param.c: $S/conf/param.c
	rm -f param.c
	cp $S/conf/param.c .

param.o: param.c Makefile
	${NORMAL_C}

ioconf.o: ioconf.c
	${NORMAL_C}

newvers: ${SYSTEM_DEP} ${SYSTEM_SWAP_DEP}
	sh $S/conf/newvers.sh
	${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c

__CLEANKERNEL: .USE
	@@echo "${.TARGET}ing the kernel objects"
	rm -f eddep *netbsd netbsd.ecoff netbsd.gdb tags *.[io] \
	  [a-z]*.s [Ee]rrs linterrs makelinks assym.h.tmp assym.h

__CLEANDEPEND: .USE
	rm -f .depend

clean: __CLEANKERNEL

cleandir distclean: __CLEANKERNEL __CLEANDEPEND

lint:
	@@lint -hbxncez -Dvolatile= ${CPPFLAGS} -UKGDB \
	  ${MIPS}/mips/Locore.c ${CFILES} \
	  ioconf.c param.c | \
	  grep -v 'static function .* unused'

tags:
	@@echo "see $S/kern/Makefile for tags"

links:
	egrep '#if' ${CFILES} | sed -f $S/conf/defines | \
	  sed -e 's/:.*//' -e 's/\.c/.o/' | sort -u > dontlink
	echo ${CFILES} | tr -s ' ' '\12' | sed 's/\.c/.o/' | \
	  sort -u | comm -23 - dontlink | \
	  sed 's,../.*/\(.*.o\),rm -f \1; ln -s ../GENERIC/\1 \1,' > makelinks
	sh makelinks && rm -f dontlink

SRCS=	${MIPS}/mips/locore.S ${MIPS}/mips/fp.S \
	${COBALT}/cobalt/locore_machdep.S \
	param.c ioconf.c ${CFILES} ${SFILES}
depend: .depend
.depend: ${SRCS} assym.h param.c
	${MKDEP} ${AFLAGS} ${CPPFLAGS} ${MIPS}/mips/locore.S ${MIPS}/mips/fp.S
	${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${COBALT}/cobalt/locore_machdep.S
	${MKDEP} -a ${CFLAGS} ${CPPFLAGS} param.c ioconf.c ${CFILES}
.if (${SFILES} != "")
	${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${SFILES}
.endif
	sh $S/kern/genassym.sh ${MKDEP} -f assym.dep ${CFLAGS} \
	  ${CPPFLAGS} < ${MIPS}/mips/genassym.cf
	@@sed -e 's/.*\.o:.*\.c/assym.h:/' < assym.dep >> .depend
	@@rm -f assym.dep


# depend on root or device configuration
autoconf.o conf.o: Makefile

# depend on network or filesystem configuration
uipc_proto.o vfs_conf.o: Makefile

# depend on maxusers
machdep.o: Makefile

# depend on CPU configuration
machdep.o mainbus.o trap.o: Makefile

# depend on System V IPC/shmem options
mips_machdep.o pmap.o: Makefile

locore.o: ${MIPS}/mips/locore.S assym.h
	${NORMAL_S}

locore_mips1.o: ${MIPS}/mips/locore_mips1.S assym.h
	${NORMAL_S}

locore_mips3.o: ${MIPS}/mips/locore_mips3.S assym.h
	${NORMAL_S}

fp.o: ${MIPS}/mips/fp.S assym.h
	${NORMAL_S}

locore_machdep.o: ${COBALT}/cobalt/locore_machdep.S assym.h
	${NORMAL_S}

# The install target can be redefined by putting a
# install-kernel-${MACHINE_NAME} target into /etc/mk.conf
MACHINE_NAME!=  uname -n
install: install-kernel-${MACHINE_NAME}
.if !target(install-kernel-${MACHINE_NAME}})
install-kernel-${MACHINE_NAME}:
	rm -f /onetbsd
	ln /netbsd /onetbsd
	cp netbsd /nnetbsd
	mv /nnetbsd /netbsd
.endif

%RULES
@


1.5
log
@Also share BE ldscripts.
@
text
@d1 1
a1 1
#	$NetBSD: Makefile.cobalt,v 1.4 2000/05/09 00:56:23 hubertf Exp $
@


1.5.6.1
log
@file Makefile.cobalt was added on branch thorpej_scsipi on 2000-11-20 20:07:01 +0000
@
text
@d1 239
@


1.5.6.2
log
@Update thorpej_scsipi to -current as of a month ago
A i386 GENERIC kernel compiles without the siop, ahc and bha drivers
(will be updated later). i386 IDE/ATAPI and ncr work, as well as
sparc/esp_sbus. alpha should work as well (untested yet).
siop, ahc and bha will be updated once I've updated the branch to current
-current, as well as machine-dependant code.
@
text
@a0 239
#	$NetBSD: Makefile.cobalt,v 1.5.6.1 2000/11/20 20:07:01 bouyer Exp $

# Makefile for NetBSD
#
# This makefile is constructed from a machine description:
#	config machineid
# Most changes should be made in the machine description
#	/sys/arch/cobalt/conf/``machineid''
# after which you should do
#	config machineid
# Machine generic makefile changes should be made in
#	/sys/arch/cobalt/conf/Makefile.cobalt
# after which config should be rerun for all machines of that type.
#
# N.B.: NO DEPENDENCIES ON FOLLOWING FLAGS ARE VISIBLE TO MAKEFILE
#	IF YOU CHANGE THE DEFINITION OF ANY OF THESE RECOMPILE EVERYTHING
#
# -DTRACE	compile in kernel tracing hooks
# -DQUOTA	compile in file system quotas

# DEBUG is set to -g if debugging.
# PROF is set to -pg if profiling.

AR?=		ar
AS?=		as
CC?=		cc
CPP?=		cpp
LD?=		ld
LORDER?=	lorder
MKDEP?=		mkdep
NM?=		nm
RANLIB?=	ranlib
SIZE?=		size
STRIP?=		strip
TSORT?=		tsort -q

COPTS?=		-O2

TEXTADDR?=	0x80001000

# source tree is located via $S relative to the compilation directory
.ifndef S
#S!=	cd ../../../..; pwd
S=	../../../..
.endif
COBALT= $S/arch/cobalt
MIPS=	$S/arch/mips

HAVE_EGCS!=	${CC} --version | egrep "^(2\.[89]|egcs)" ; echo
INCLUDES=	-I. -I$S/arch -I$S -nostdinc
CPPFLAGS=	${INCLUDES} ${IDENT} ${PARAM} -D_KERNEL -Dcobalt
CWARNFLAGS?=	-Wall -Werror -Wstrict-prototypes -Wmissing-prototypes \
		-Wpointer-arith
# XXX Delete -Wuninitialized for now, since the compiler doesn't
# XXX always get it right.  --thorpej 
CWARNFLAGS+=    -Wno-uninitialized
.if (${HAVE_EGCS} != "")
CWARNFLAGS+=	-Wno-main
.endif
GP?=		-G 0
CFLAGS=		${DEBUG} ${COPTS} ${CWARNFLAGS} ${GP} \
		-mno-abicalls -mno-half-pic
AFLAGS=		-x assembler-with-cpp -traditional-cpp -D_LOCORE
LINKFLAGS=	-T${MIPS}/conf/kern.ldscript.le -Ttext ${TEXTADDR} \
		-e start ${GP}
STRIPFLAGS=	-g -X -x

%INCLUDES

### find out what to use for libkern
.include "$S/lib/libkern/Makefile.inc"
.ifndef PROF
LIBKERN=	${KERNLIB}
.else
LIBKERN=	${KERNLIB_PROF}
.endif

### find out what to use for libcompat
.include "$S/compat/common/Makefile.inc"
.ifndef PROF
LIBCOMPAT=	${COMPATLIB}
.else
LIBCOMPAT=	${COMPATLIB_PROF}
.endif

# compile rules: rules are named ${TYPE}_${SUFFIX} where TYPE is NORMAL or
# HOSTED}, and SUFFIX is the file suffix, capitalized (e.g. C for a .c file).

NORMAL_C=	${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $<
NOPROF_C=	${CC} ${CFLAGS} ${CPPFLAGS} -c $<
NORMAL_S=	${CC} ${AFLAGS} ${CPPFLAGS} -c $<

%OBJS

%CFILES

%SFILES

# load lines for config "xxx" will be emitted as:
# xxx: ${SYSTEM_DEP} swapxxx.o
#	${SYSTEM_LD_HEAD}
#	${SYSTEM_LD} swapxxx.o
#	${SYSTEM_LD_TAIL}
SYSTEM_OBJ=	locore.o locore_machdep.o
.if !empty(IDENT:M-DMIPS1)
SYSTEM_OBJ+=	locore_mips1.o
.endif
.if !empty(IDENT:M-DMIPS3)
SYSTEM_OBJ+=	locore_mips3.o
.endif
SYSTEM_OBJ+=	fp.o param.o ioconf.o ${OBJS} ${LIBKERN} ${LIBCOMPAT}
SYSTEM_DEP=	Makefile ${SYSTEM_OBJ}
SYSTEM_LD_HEAD=	@@rm -f $@@
SYSTEM_LD=	@@echo ${LD} ${LINKFLAGS} -o $@@ '$${SYSTEM_OBJ}' vers.o ; \
		${LD} ${LINKFLAGS} -o $@@ ${SYSTEM_OBJ} vers.o
SYSTEM_LD_TAIL=	@@${SIZE} $@@; chmod 755 $@@

DEBUG?=
.if ${DEBUG} == "-g"
LINKFLAGS+=	-X
SYSTEM_LD_TAIL+=; \
		echo mv -f $@@ $@@.gdb; mv -f $@@ $@@.gdb; \
		echo ${STRIP} ${STRIPFLAGS} -o $@@ $@@.gdb; \
		${STRIP} ${STRIPFLAGS} -o $@@ $@@.gdb
.else
LINKFLAGS+=	-x
.endif

%LOAD

assym.h: $S/kern/genassym.sh ${MIPS}/mips/genassym.cf
	sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} \
	  < ${MIPS}/mips/genassym.cf > assym.h.tmp && \
	mv -f assym.h.tmp assym.h


param.c: $S/conf/param.c
	rm -f param.c
	cp $S/conf/param.c .

param.o: param.c Makefile
	${NORMAL_C}

ioconf.o: ioconf.c
	${NORMAL_C}

newvers: ${SYSTEM_DEP} ${SYSTEM_SWAP_DEP}
	sh $S/conf/newvers.sh
	${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c

__CLEANKERNEL: .USE
	@@echo "${.TARGET}ing the kernel objects"
	rm -f eddep *netbsd netbsd.ecoff netbsd.gdb tags *.[io] \
	  [a-z]*.s [Ee]rrs linterrs makelinks assym.h.tmp assym.h

__CLEANDEPEND: .USE
	rm -f .depend

clean: __CLEANKERNEL

cleandir distclean: __CLEANKERNEL __CLEANDEPEND

lint:
	@@lint -hbxncez -Dvolatile= ${CPPFLAGS} -UKGDB \
	  ${MIPS}/mips/Locore.c ${CFILES} \
	  ioconf.c param.c | \
	  grep -v 'static function .* unused'

tags:
	@@echo "see $S/kern/Makefile for tags"

links:
	egrep '#if' ${CFILES} | sed -f $S/conf/defines | \
	  sed -e 's/:.*//' -e 's/\.c/.o/' | sort -u > dontlink
	echo ${CFILES} | tr -s ' ' '\12' | sed 's/\.c/.o/' | \
	  sort -u | comm -23 - dontlink | \
	  sed 's,../.*/\(.*.o\),rm -f \1; ln -s ../GENERIC/\1 \1,' > makelinks
	sh makelinks && rm -f dontlink

SRCS=	${MIPS}/mips/locore.S ${MIPS}/mips/fp.S \
	${COBALT}/cobalt/locore_machdep.S \
	param.c ioconf.c ${CFILES} ${SFILES}
depend: .depend
.depend: ${SRCS} assym.h param.c
	${MKDEP} ${AFLAGS} ${CPPFLAGS} ${MIPS}/mips/locore.S ${MIPS}/mips/fp.S
	${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${COBALT}/cobalt/locore_machdep.S
	${MKDEP} -a ${CFLAGS} ${CPPFLAGS} param.c ioconf.c ${CFILES}
.if (${SFILES} != "")
	${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${SFILES}
.endif
	sh $S/kern/genassym.sh ${MKDEP} -f assym.dep ${CFLAGS} \
	  ${CPPFLAGS} < ${MIPS}/mips/genassym.cf
	@@sed -e 's/.*\.o:.*\.c/assym.h:/' < assym.dep >> .depend
	@@rm -f assym.dep


# depend on root or device configuration
autoconf.o conf.o: Makefile

# depend on network or filesystem configuration
uipc_proto.o vfs_conf.o: Makefile

# depend on maxusers
machdep.o: Makefile

# depend on CPU configuration
machdep.o mainbus.o trap.o: Makefile

# depend on System V IPC/shmem options
mips_machdep.o pmap.o: Makefile

locore.o: ${MIPS}/mips/locore.S assym.h
	${NORMAL_S}

locore_mips1.o: ${MIPS}/mips/locore_mips1.S assym.h
	${NORMAL_S}

locore_mips3.o: ${MIPS}/mips/locore_mips3.S assym.h
	${NORMAL_S}

fp.o: ${MIPS}/mips/fp.S assym.h
	${NORMAL_S}

locore_machdep.o: ${COBALT}/cobalt/locore_machdep.S assym.h
	${NORMAL_S}

# The install target can be redefined by putting a
# install-kernel-${MACHINE_NAME} target into /etc/mk.conf
MACHINE_NAME!=  uname -n
install: install-kernel-${MACHINE_NAME}
.if !target(install-kernel-${MACHINE_NAME}})
install-kernel-${MACHINE_NAME}:
	rm -f /onetbsd
	ln /netbsd /onetbsd
	cp netbsd /nnetbsd
	mv /nnetbsd /netbsd
.endif

%RULES
@


1.5.6.3
log
@Sync with HEAD.
@
text
@d1 239
@


1.4
log
@Add "install" target, so "make install" after building the kernel
does something useful.  The target can be redefined by putting a
install-kernel-${MACHINE_NAME} target that fits your needs into
/etc/mk.conf.
@
text
@d1 1
a1 1
#	$NetBSD: Makefile.cobalt,v 1.3 2000/05/09 00:32:21 thorpej Exp $
d64 2
a65 1
LINKFLAGS=	-T${MIPS}/conf/kern.ldscript -Ttext ${TEXTADDR} -e start ${GP}
@


1.3
log
@HAVE_GCC28 -> HAVE_EGCS, and make it match gcc 2.9 as well.  Also,
make the use of -Wno-uninitialized explicit, don't rely on a compiler
hack to do it for us.
@
text
@d1 1
a1 1
#	$NetBSD: Makefile.cobalt,v 1.2 2000/03/30 20:08:37 soren Exp $
d225 12
@


1.2
log
@Remove local hack.
@
text
@d1 1
a1 1
#	$NetBSD: Makefile.cobalt,v 1.1 2000/03/19 23:07:44 soren Exp $
d49 1
a49 1
HAVE_GCC28!=	${CC} --version | egrep "^(2\.8|egcs)" ; echo
d54 4
a57 1
.if (${HAVE_GCC28} != "")
@


1.1
log
@NetBSD/cobalt. Work-in-progress.
@
text
@d1 1
a1 1
#	$NetBSD$
d120 1
a120 6
		${STRIP} ${STRIPFLAGS} -o $@@ $@@.gdb; \
		sudo gzip -c $@@ > /nfsroot/boot/vmlinux_raq-2800.gz ; \
		ln -f /nfsroot/boot/vmlinux_raq-2800.gz /nfsroot/boot/n ; \
		echo bfd /boot/vmlinux_raq-2800.gz root=/dev/nfs \
			nfsroot=/nfsroot ; \
		echo bfd /boot/n nfsroot=/nfsroot
@
