Makefile.usermode revision 1.34
11.34Sjmcneill# $NetBSD: Makefile.usermode,v 1.34 2013/11/10 19:49:49 jmcneill 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.33SyamtUSERMODE_CPPFLAGS=${DEBUG} -U_KERNEL
251.33SyamtUSERMODE_CPPFLAGS+=-I${DESTDIR}/usr/include
261.18SjmcneillUSERMODE_CPPFLAGS+=${CWARNFLAGS} ${NOGCCERROR:D:U-Werror}
271.18Sjmcneill
281.32Sreinoud## XXX hack to make it work under build.sh
291.32Sreinoud.if ${TOOLDIR:Uno} != "no"
301.32SreinoudUSERMODE_LIBS+= crti.o
311.32SreinoudSYSTEM_LD_FIX= cp ${DESTDIR}/usr/lib/crt0.o ${DESTDIR}/usr/lib/crtbegin.o ${DESTDIR}/usr/lib/crtend.o ${DESTDIR}/usr/lib/crti.o .;
321.32Sreinoud.endif
331.32Sreinoud
341.17Sjmcneill.if ${USERMODE_HOSTOS} == "Linux"
351.17SjmcneillUSERMODE_LIBS+=	-lpthread
361.18SjmcneillCPPFLAGS+=-Dstrtoul=netbsd_strtoul
371.18SjmcneillCPPFLAGS+=-Dstrtoll=netbsd_strtoll
381.18SjmcneillCPPFLAGS+=-Dstrtoull=netbsd_strtoull
391.19SjmcneillCPPFLAGS+=-D__NetBSD__ -Wno-unused-but-set-variable
401.17Sjmcneill.endif
411.10Sjmcneill
421.12SreinoudDEFCOPTS=	-fno-omit-frame-pointer
431.19SjmcneillCPPFLAGS+=	-Dusermode
441.28SjmcneillCPPFLAGS+=	-Dsyscall=kernel_syscall
451.2SjmcneillCPPFLAGS.init_main.c+=	-Dmain=kernmain
461.1Sjmcneill
471.14SjmcneillCPPFLAGS.thunk.c+=	${USERMODE_CPPFLAGS}
481.8Sjmcneill
491.1Sjmcneill##
501.1Sjmcneill## (3) libkern and compat
511.1Sjmcneill##
521.18SjmcneillKERN_AS=	library
531.18SjmcneillCOMPAT_AS=	library
541.1Sjmcneill
551.1Sjmcneill##
561.1Sjmcneill## (4) local objects, compile rules, and dependencies
571.1Sjmcneill##
581.8SjmcneillMD_OBJS=	thunk.o
591.8SjmcneillMD_CFILES=	${USERMODE}/usermode/thunk.c
601.16SjmcneillMD_SFILES=
611.16Sjmcneill
621.34SjmcneillMD_OBJS+=	cpu_${MACHINE_CPU}.o
631.34SjmcneillMD_CFILES+=	${USERMODE}/target/${MACHINE_CPU}/cpu_${MACHINE_CPU}.c
641.29Sreinoud
651.1Sjmcneill##
661.1Sjmcneill## (5) link settings
671.1Sjmcneill##
681.24SjmcneillTEXTADDR?=	  %TEXTADDR%
691.21Sreinoud
701.21SreinoudLINKFLAGS_NORMAL=	-X
711.21SreinoudKERN_LDSCRIPT?=	kern.ldscript
721.21Sreinoud#LINKFORMAT=	-T ${USERMODE}/conf/${KERN_LDSCRIPT}
731.21Sreinoud
741.8SjmcneillSYSTEM_LD=	@${_MKSHMSG} "   link  ${.CURDIR:T}/${.TARGET}"; \
751.6Sjmcneill		${_MKSHECHO}\
761.21Sreinoud		${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o ${USERMODE_LIBS}; \
771.32Sreinoud		${SYSTEM_LD_FIX} \
781.21Sreinoud		${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o ${USERMODE_LIBS}
791.7SjmcneillNVFLAGS=	-n
801.1Sjmcneill
811.1Sjmcneill##
821.1Sjmcneill## (6) port specific target dependencies
831.1Sjmcneill##
841.1Sjmcneill
851.9Sjmcneill.if !make(obj) && !make(clean) && !make(cleandir)
861.9Sjmcneill.BEGIN:
871.9Sjmcneill	@rm -f i386 && \
881.9Sjmcneill		ln -s $S/arch/i386/include i386
891.29Sreinoud	@rm -f amd64 && \
901.29Sreinoud		ln -s $S/arch/amd64/include amd64
911.34Sjmcneill	@rm -f arm && \
921.34Sjmcneill		ln -s $S/arch/arm/include arm
931.9Sjmcneill.endif
941.9Sjmcneill
951.15Sjmcneillthunk.d: ${USERMODE}/usermode/thunk.c
961.15Sjmcneill	${MKDEP} -f ${.TARGET} -- ${MKDEP_CFLAGS} \
971.15Sjmcneill	    ${CPPFLAGS.thunk.c} ${USERMODE}/usermode/thunk.c
981.15Sjmcneill
991.8Sjmcneillthunk.o: ${USERMODE}/usermode/thunk.c
1001.27Schristos	${CC} ${COPTS} ${CPPFLAGS.thunk.c} -c -o $@ ${USERMODE}/usermode/thunk.c
1011.8Sjmcneill
1021.34Sjmcneillcpu_${MACHINE_CPU}.o:	${USERMODE}/target/${MACHINE_CPU}/cpu_${MACHINE_CPU}.c
1031.33Syamt
1041.1Sjmcneill##
1051.1Sjmcneill## (7) misc settings
1061.1Sjmcneill##
1071.1Sjmcneill
1081.1Sjmcneill##
1091.1Sjmcneill## (8) config(8) generated machinery
1101.1Sjmcneill%INCLUDES
1111.1Sjmcneill
1121.1Sjmcneill%OBJS
1131.1Sjmcneill
1141.1Sjmcneill%CFILES
1151.1Sjmcneill
1161.1Sjmcneill%SFILES
1171.1Sjmcneill
1181.1Sjmcneill%LOAD
1191.1Sjmcneill
1201.1Sjmcneill%RULES
1211.1Sjmcneill
1221.1Sjmcneill##
1231.1Sjmcneill## (9) port independent kernel machinery
1241.1Sjmcneill##
1251.1Sjmcneill.include "$S/conf/Makefile.kern.inc"
1261.1Sjmcneill
1271.1Sjmcneill##
1281.1Sjmcneill## (10) appending make options
1291.1Sjmcneill##
1301.1Sjmcneill%MAKEOPTIONSAPPEND
131