Makefile.usermode revision 1.40
11.40Schristos# $NetBSD: Makefile.usermode,v 1.40 2017/12/10 14:29:47 christos 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.36SuebayasiKERNLDSCRIPT?=	${USERMODE}/conf/kern.ldscript
721.21Sreinoud
731.38SuebayasiSYSTEM_LD=	@do_system_ld() { \
741.38Suebayasi		target=$$1; shift; \
751.38Suebayasi		${_MKSHMSG} "   link  ${.CURDIR:T}/${.TARGET}"; \
761.6Sjmcneill		${_MKSHECHO}\
771.39Suebayasi		${CC} -static ${COPTS} -Wl,-Map,$${target}.map -o $${target} ${LINKFORMAT} -Ttext ${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o ${USERMODE_LIBS} $$@; \
781.32Sreinoud		${SYSTEM_LD_FIX} \
791.39Suebayasi		${CC} -static ${COPTS} -Wl,-Map,$${target}.map -o $${target} ${LINKFORMAT} -Ttext ${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o ${USERMODE_LIBS} $$@; \
801.38Suebayasi		}; \
811.38Suebayasi		do_system_ld
821.7SjmcneillNVFLAGS=	-n
831.1Sjmcneill
841.1Sjmcneill##
851.1Sjmcneill## (6) port specific target dependencies
861.1Sjmcneill##
871.1Sjmcneill
881.9Sjmcneill.if !make(obj) && !make(clean) && !make(cleandir)
891.40Schristos.BEGIN::
901.40Schristos	-@rm -f i386 && \
911.9Sjmcneill		ln -s $S/arch/i386/include i386
921.40Schristos	-@rm -f amd64 && \
931.29Sreinoud		ln -s $S/arch/amd64/include amd64
941.40Schristos	-@rm -f arm && \
951.34Sjmcneill		ln -s $S/arch/arm/include arm
961.9Sjmcneill.endif
971.9Sjmcneill
981.15Sjmcneillthunk.d: ${USERMODE}/usermode/thunk.c
991.15Sjmcneill	${MKDEP} -f ${.TARGET} -- ${MKDEP_CFLAGS} \
1001.15Sjmcneill	    ${CPPFLAGS.thunk.c} ${USERMODE}/usermode/thunk.c
1011.15Sjmcneill
1021.8Sjmcneillthunk.o: ${USERMODE}/usermode/thunk.c
1031.27Schristos	${CC} ${COPTS} ${CPPFLAGS.thunk.c} -c -o $@ ${USERMODE}/usermode/thunk.c
1041.8Sjmcneill
1051.34Sjmcneillcpu_${MACHINE_CPU}.o:	${USERMODE}/target/${MACHINE_CPU}/cpu_${MACHINE_CPU}.c
1061.33Syamt
1071.1Sjmcneill##
1081.1Sjmcneill## (7) misc settings
1091.1Sjmcneill##
1101.1Sjmcneill
1111.1Sjmcneill##
1121.1Sjmcneill## (8) config(8) generated machinery
1131.1Sjmcneill%INCLUDES
1141.1Sjmcneill
1151.1Sjmcneill%OBJS
1161.1Sjmcneill
1171.1Sjmcneill%CFILES
1181.1Sjmcneill
1191.1Sjmcneill%SFILES
1201.1Sjmcneill
1211.1Sjmcneill%LOAD
1221.1Sjmcneill
1231.1Sjmcneill%RULES
1241.1Sjmcneill
1251.1Sjmcneill##
1261.1Sjmcneill## (9) port independent kernel machinery
1271.1Sjmcneill##
1281.1Sjmcneill.include "$S/conf/Makefile.kern.inc"
1291.1Sjmcneill
1301.1Sjmcneill##
1311.1Sjmcneill## (10) appending make options
1321.1Sjmcneill##
1331.1Sjmcneill%MAKEOPTIONSAPPEND
134