Makefile.usermode revision 1.32
11.32Sreinoud# $NetBSD: Makefile.usermode,v 1.32 2012/06/30 15:03:57 reinoud Exp $
21.1Sjmcneill
31.1SjmcneillUSETOOLS?=			no
41.1SjmcneillNEED_OWN_INSTALL_TARGET?=	no
51.1Sjmcneill.include <bsd.own.mk>
61.1Sjmcneill
71.1Sjmcneill##
81.1Sjmcneill## (1) port identification
91.1Sjmcneill##
101.1SjmcneillUSERMODE=	$S/arch/usermode
111.1SjmcneillGENASSYM_CONF=	${USERMODE}/usermode/genassym.cf
121.32Sreinoud
131.32Sreinoud## support for crosscompiling
141.32Sreinoud.if ${MACHINE_ARCH:Uunset} == "unset"
151.31SreinoudMACHINE_ARCH!=uname -p
161.32Sreinoud.endif
171.1Sjmcneill
181.1Sjmcneill##
191.1Sjmcneill## (2) compile settings
201.1Sjmcneill##
211.17SjmcneillUSERMODE_HOSTOS!=uname -s
221.18SjmcneillUSERMODE_HOSTMACHINE!=uname -m
231.32SreinoudUSERMODE_LIBS= -L${DESTDIR}/usr/lib -lrt
241.20SjmcneillUSERMODE_CPPFLAGS=${DEBUG} -U_KERNEL -I/usr/include
251.18SjmcneillUSERMODE_CPPFLAGS+=${CWARNFLAGS} ${NOGCCERROR:D:U-Werror}
261.18Sjmcneill
271.32Sreinoud## XXX hack to make it work under build.sh
281.32Sreinoud.if ${TOOLDIR:Uno} != "no"
291.32SreinoudUSERMODE_LIBS+= crti.o
301.32SreinoudSYSTEM_LD_FIX= cp ${DESTDIR}/usr/lib/crt0.o ${DESTDIR}/usr/lib/crtbegin.o ${DESTDIR}/usr/lib/crtend.o ${DESTDIR}/usr/lib/crti.o .;
311.32Sreinoud.endif
321.32Sreinoud
331.17Sjmcneill.if ${USERMODE_HOSTOS} == "Linux"
341.17SjmcneillUSERMODE_LIBS+=	-lpthread
351.18SjmcneillCPPFLAGS+=-Dstrtoul=netbsd_strtoul
361.18SjmcneillCPPFLAGS+=-Dstrtoll=netbsd_strtoll
371.18SjmcneillCPPFLAGS+=-Dstrtoull=netbsd_strtoull
381.19SjmcneillCPPFLAGS+=-D__NetBSD__ -Wno-unused-but-set-variable
391.17Sjmcneill.endif
401.10Sjmcneill
411.12SreinoudDEFCOPTS=	-fno-omit-frame-pointer
421.19SjmcneillCPPFLAGS+=	-Dusermode
431.28SjmcneillCPPFLAGS+=	-Dsyscall=kernel_syscall
441.2SjmcneillCPPFLAGS.init_main.c+=	-Dmain=kernmain
451.1Sjmcneill
461.14SjmcneillCPPFLAGS.thunk.c+=	${USERMODE_CPPFLAGS}
471.8Sjmcneill
481.1Sjmcneill##
491.1Sjmcneill## (3) libkern and compat
501.1Sjmcneill##
511.18SjmcneillKERN_AS=	library
521.18SjmcneillCOMPAT_AS=	library
531.1Sjmcneill
541.1Sjmcneill##
551.1Sjmcneill## (4) local objects, compile rules, and dependencies
561.1Sjmcneill##
571.8SjmcneillMD_OBJS=	thunk.o
581.8SjmcneillMD_CFILES=	${USERMODE}/usermode/thunk.c
591.16SjmcneillMD_SFILES=
601.16Sjmcneill
611.31SreinoudMD_OBJS+=	cpu_${MACHINE_ARCH}.o
621.31SreinoudMD_CFILES+=	${USERMODE}/target/${MACHINE_ARCH}/cpu_${MACHINE_ARCH}.c
631.29Sreinoud
641.1Sjmcneill##
651.1Sjmcneill## (5) link settings
661.1Sjmcneill##
671.24SjmcneillTEXTADDR?=	  %TEXTADDR%
681.21Sreinoud
691.21SreinoudLINKFLAGS_NORMAL=	-X
701.21SreinoudKERN_LDSCRIPT?=	kern.ldscript
711.21Sreinoud#LINKFORMAT=	-T ${USERMODE}/conf/${KERN_LDSCRIPT}
721.21Sreinoud
731.8SjmcneillSYSTEM_LD=	@${_MKSHMSG} "   link  ${.CURDIR:T}/${.TARGET}"; \
741.6Sjmcneill		${_MKSHECHO}\
751.21Sreinoud		${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o ${USERMODE_LIBS}; \
761.32Sreinoud		${SYSTEM_LD_FIX} \
771.21Sreinoud		${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o ${USERMODE_LIBS}
781.7SjmcneillNVFLAGS=	-n
791.1Sjmcneill
801.1Sjmcneill##
811.1Sjmcneill## (6) port specific target dependencies
821.1Sjmcneill##
831.1Sjmcneill
841.9Sjmcneill.if !make(obj) && !make(clean) && !make(cleandir)
851.9Sjmcneill.BEGIN:
861.9Sjmcneill	@rm -f i386 && \
871.9Sjmcneill		ln -s $S/arch/i386/include i386
881.29Sreinoud	@rm -f amd64 && \
891.29Sreinoud		ln -s $S/arch/amd64/include amd64
901.9Sjmcneill.endif
911.9Sjmcneill
921.15Sjmcneillthunk.d: ${USERMODE}/usermode/thunk.c
931.15Sjmcneill	${MKDEP} -f ${.TARGET} -- ${MKDEP_CFLAGS} \
941.15Sjmcneill	    ${CPPFLAGS.thunk.c} ${USERMODE}/usermode/thunk.c
951.15Sjmcneill
961.8Sjmcneillthunk.o: ${USERMODE}/usermode/thunk.c
971.27Schristos	${CC} ${COPTS} ${CPPFLAGS.thunk.c} -c -o $@ ${USERMODE}/usermode/thunk.c
981.8Sjmcneill
991.1Sjmcneill##
1001.1Sjmcneill## (7) misc settings
1011.1Sjmcneill##
1021.1Sjmcneill
1031.1Sjmcneill##
1041.1Sjmcneill## (8) config(8) generated machinery
1051.1Sjmcneill%INCLUDES
1061.1Sjmcneill
1071.1Sjmcneill%OBJS
1081.1Sjmcneill
1091.1Sjmcneill%CFILES
1101.1Sjmcneill
1111.1Sjmcneill%SFILES
1121.1Sjmcneill
1131.1Sjmcneill%LOAD
1141.1Sjmcneill
1151.1Sjmcneill%RULES
1161.1Sjmcneill
1171.1Sjmcneill##
1181.1Sjmcneill## (9) port independent kernel machinery
1191.1Sjmcneill##
1201.1Sjmcneill.include "$S/conf/Makefile.kern.inc"
1211.1Sjmcneill
1221.1Sjmcneill##
1231.1Sjmcneill## (10) appending make options
1241.1Sjmcneill##
1251.1Sjmcneill%MAKEOPTIONSAPPEND
126