Subject: fix? for kernel loading problems on sparc
To: None <tech-kern@netbsd.org, port-sparc@netbsd.org>
From: Simon J. Gerraty <sjg@crufty.net>
List: tech-kern
Date: 09/25/2002 15:24:32
Many sparc users put something like:
COPTS+= -msupersparc
in /etc/mk.conf and sys.mk provides
DBG?= -O2
or whatever.
However sys/conf/Makefile.kern.inc does:
DEFCOPTS?= -O2
COPTS?= ${DEFCOPTS}
DBG= # might contain unwanted -Ofoo
the effect of this with the COPTS in mk.conf is that we lose the -O2
which bloats the kernel to the point where loading clobbers the boot
loader (recent thread on port-sparc):
with -O2
2508460 93324 268176 2869960 2bcac8 /netbsd
with -msupersparc
4477616 93324 268176 4839116 49d6cc /netbsd.ss
with -O2 -msupersparc
2521732 93324 268176 2883232 2bfea0 netbsd
The boot loader is at 388000.
Since most of the tree will pickup -O* from
${DBG} it isn't ideal to add -O2 to COPTS in mk.conf. With the
following in mk.conf
COPTS+= -msupersparc
# for kernel builds
DEFCOPTS= -O2 -msupersparc
and the patch below, things work better. This is perhaps not ideal
though. Why doesn't the kernel just use DBG?
Thanks
--sjg
Index: sys/conf/Makefile.kern.inc
===================================================================
RCS file: /cvsroot/syssrc/sys/conf/Makefile.kern.inc,v
retrieving revision 1.13.4.6
diff -u -p -r1.13.4.6 Makefile.kern.inc
--- sys/conf/Makefile.kern.inc 2002/08/17 16:02:38 1.13.4.6
+++ sys/conf/Makefile.kern.inc 2002/09/25 21:08:13
@@ -47,7 +47,7 @@ S!= cd ../../../..; pwd
INCLUDES?= -I. ${EXTRA_INCLUDES} -I$S/arch -I$S -nostdinc
CPPFLAGS+= ${INCLUDES} ${IDENT} ${PARAM} -D_KERNEL -D_KERNEL_OPT
DEFCOPTS?= -O2
-COPTS?= ${DEFCOPTS}
+COPTS= ${DEFCOPTS}
DBG= # might contain unwanted -Ofoo
DEFWARNINGS?= yes
.if (${DEFWARNINGS} == "yes")