Makefile.usermode revision 1.43
11.43Sreinoud# $NetBSD: Makefile.usermode,v 1.43 2018/08/17 20:16:07 reinoud Exp $
21.1Sjmcneill
31.42SreinoudMKCTF?=				no
41.1SjmcneillUSETOOLS?=			no
51.1SjmcneillNEED_OWN_INSTALL_TARGET?=	no
61.1Sjmcneill.include <bsd.own.mk>
71.1Sjmcneill
81.1Sjmcneill##
91.1Sjmcneill## (1) port identification
101.1Sjmcneill##
111.1SjmcneillUSERMODE=	$S/arch/usermode
121.1SjmcneillGENASSYM_CONF=	${USERMODE}/usermode/genassym.cf
131.32Sreinoud
141.32Sreinoud## support for crosscompiling
151.32Sreinoud.if ${MACHINE_ARCH:Uunset} == "unset"
161.31SreinoudMACHINE_ARCH!=uname -p
171.32Sreinoud.endif
181.1Sjmcneill
191.1Sjmcneill##
201.1Sjmcneill## (2) compile settings
211.1Sjmcneill##
221.17SjmcneillUSERMODE_HOSTOS!=uname -s
231.18SjmcneillUSERMODE_HOSTMACHINE!=uname -m
241.32SreinoudUSERMODE_LIBS= -L${DESTDIR}/usr/lib -lrt
251.33SyamtUSERMODE_CPPFLAGS=${DEBUG} -U_KERNEL
261.33SyamtUSERMODE_CPPFLAGS+=-I${DESTDIR}/usr/include
271.18SjmcneillUSERMODE_CPPFLAGS+=${CWARNFLAGS} ${NOGCCERROR:D:U-Werror}
281.18Sjmcneill
291.32Sreinoud## XXX hack to make it work under build.sh
301.32Sreinoud.if ${TOOLDIR:Uno} != "no"
311.32SreinoudUSERMODE_LIBS+= crti.o
321.32SreinoudSYSTEM_LD_FIX= cp ${DESTDIR}/usr/lib/crt0.o ${DESTDIR}/usr/lib/crtbegin.o ${DESTDIR}/usr/lib/crtend.o ${DESTDIR}/usr/lib/crti.o .;
331.32Sreinoud.endif
341.32Sreinoud
351.17Sjmcneill.if ${USERMODE_HOSTOS} == "Linux"
361.17SjmcneillUSERMODE_LIBS+=	-lpthread
371.18SjmcneillCPPFLAGS+=-Dstrtoul=netbsd_strtoul
381.18SjmcneillCPPFLAGS+=-Dstrtoll=netbsd_strtoll
391.18SjmcneillCPPFLAGS+=-Dstrtoull=netbsd_strtoull
401.19SjmcneillCPPFLAGS+=-D__NetBSD__ -Wno-unused-but-set-variable
411.17Sjmcneill.endif
421.10Sjmcneill
431.12SreinoudDEFCOPTS=	-fno-omit-frame-pointer
441.19SjmcneillCPPFLAGS+=	-Dusermode
451.28SjmcneillCPPFLAGS+=	-Dsyscall=kernel_syscall
461.2SjmcneillCPPFLAGS.init_main.c+=	-Dmain=kernmain
471.1Sjmcneill
481.14SjmcneillCPPFLAGS.thunk.c+=	${USERMODE_CPPFLAGS}
491.8Sjmcneill
501.1Sjmcneill##
511.1Sjmcneill## (3) libkern and compat
521.1Sjmcneill##
531.18SjmcneillKERN_AS=	library
541.18SjmcneillCOMPAT_AS=	library
551.1Sjmcneill
561.1Sjmcneill##
571.1Sjmcneill## (4) local objects, compile rules, and dependencies
581.1Sjmcneill##
591.8SjmcneillMD_OBJS=	thunk.o
601.8SjmcneillMD_CFILES=	${USERMODE}/usermode/thunk.c
611.16SjmcneillMD_SFILES=
621.16Sjmcneill
631.34SjmcneillMD_OBJS+=	cpu_${MACHINE_CPU}.o
641.34SjmcneillMD_CFILES+=	${USERMODE}/target/${MACHINE_CPU}/cpu_${MACHINE_CPU}.c
651.29Sreinoud
661.1Sjmcneill##
671.1Sjmcneill## (5) link settings
681.1Sjmcneill##
691.24SjmcneillTEXTADDR?=	  %TEXTADDR%
701.21Sreinoud
711.21SreinoudLINKFLAGS_NORMAL=	-X
721.36SuebayasiKERNLDSCRIPT?=	${USERMODE}/conf/kern.ldscript
731.21Sreinoud
741.38SuebayasiSYSTEM_LD=	@do_system_ld() { \
751.38Suebayasi		${_MKSHMSG} "   link  ${.CURDIR:T}/${.TARGET}"; \
761.6Sjmcneill		${_MKSHECHO}\
771.43Sreinoud		${CC} -static ${COPTS} -Wl,-Map,$${target}.map -o ${.TARGET} ${LINKFORMAT} -Wl,-Ttext,${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o netbsd.ldscript ${USERMODE_LIBS} $$@; \
781.32Sreinoud		${SYSTEM_LD_FIX} \
791.43Sreinoud		${CC} -static ${COPTS} -Wl,-Map,$${target}.map -o ${.TARGET} ${LINKFORMAT} -Wl,-Ttext,${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o netbsd.ldscript ${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