Makefile.usermode revision 1.29
11.29Sreinoud# $NetBSD: Makefile.usermode,v 1.29 2012/01/06 20:44:57 reinoud Exp $
21.1Sjmcneill
31.18SjmcneillOPT_CPU_HOST=			%CPU_HOST%
41.18Sjmcneill.if !empty(OPT_CPU_HOST)
51.18SjmcneillMACHINE_ARCH=			${OPT_CPU_HOST}
61.18Sjmcneill.else
71.1SjmcneillMACHINE_ARCH=			usermode
81.18Sjmcneill.endif
91.1SjmcneillUSETOOLS?=			no
101.1SjmcneillNEED_OWN_INSTALL_TARGET?=	no
111.1Sjmcneill.include <bsd.own.mk>
121.1Sjmcneill
131.1Sjmcneill##
141.1Sjmcneill## (1) port identification
151.1Sjmcneill##
161.1SjmcneillUSERMODE=	$S/arch/usermode
171.1SjmcneillGENASSYM_CONF=	${USERMODE}/usermode/genassym.cf
181.1Sjmcneill
191.1Sjmcneill##
201.1Sjmcneill## (2) compile settings
211.1Sjmcneill##
221.17SjmcneillUSERMODE_HOSTOS!=uname -s
231.18SjmcneillUSERMODE_HOSTMACHINE!=uname -m
241.21SreinoudUSERMODE_LIBS=	-lc -lrt
251.20SjmcneillUSERMODE_CPPFLAGS=${DEBUG} -U_KERNEL -I/usr/include
261.18SjmcneillUSERMODE_CPPFLAGS+=${CWARNFLAGS} ${NOGCCERROR:D:U-Werror}
271.18Sjmcneill
281.17Sjmcneill.if ${USERMODE_HOSTOS} == "Linux"
291.17SjmcneillUSERMODE_LIBS+=	-lpthread
301.18SjmcneillCPPFLAGS+=-Dstrtoul=netbsd_strtoul
311.18SjmcneillCPPFLAGS+=-Dstrtoll=netbsd_strtoll
321.18SjmcneillCPPFLAGS+=-Dstrtoull=netbsd_strtoull
331.19SjmcneillCPPFLAGS+=-D__NetBSD__ -Wno-unused-but-set-variable
341.17Sjmcneill.endif
351.10Sjmcneill
361.12SreinoudDEFCOPTS=	-fno-omit-frame-pointer
371.19SjmcneillCPPFLAGS+=	-Dusermode
381.28SjmcneillCPPFLAGS+=	-Dsyscall=kernel_syscall
391.2SjmcneillCPPFLAGS.init_main.c+=	-Dmain=kernmain
401.1Sjmcneill
411.14SjmcneillCPPFLAGS.thunk.c+=	${USERMODE_CPPFLAGS}
421.8Sjmcneill
431.1Sjmcneill##
441.1Sjmcneill## (3) libkern and compat
451.1Sjmcneill##
461.18SjmcneillKERN_AS=	library
471.18SjmcneillCOMPAT_AS=	library
481.1Sjmcneill
491.1Sjmcneill##
501.1Sjmcneill## (4) local objects, compile rules, and dependencies
511.1Sjmcneill##
521.8SjmcneillMD_OBJS=	thunk.o
531.8SjmcneillMD_CFILES=	${USERMODE}/usermode/thunk.c
541.16SjmcneillMD_SFILES=
551.16Sjmcneill
561.29SreinoudMD_OBJS+=	machdep.${USERMODE_CPU}.o
571.29SreinoudMD_CFILES+=	${USERMODE}/usermode/machdep.${USERMODE_CPU}.c
581.29Sreinoud
591.1Sjmcneill##
601.1Sjmcneill## (5) link settings
611.1Sjmcneill##
621.24SjmcneillTEXTADDR?=	  %TEXTADDR%
631.21Sreinoud
641.21SreinoudLINKFLAGS_NORMAL=	-X
651.21SreinoudKERN_LDSCRIPT?=	kern.ldscript
661.21Sreinoud#LINKFORMAT=	-T ${USERMODE}/conf/${KERN_LDSCRIPT}
671.21Sreinoud
681.8SjmcneillSYSTEM_LD=	@${_MKSHMSG} "   link  ${.CURDIR:T}/${.TARGET}"; \
691.6Sjmcneill		${_MKSHECHO}\
701.21Sreinoud		${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o ${USERMODE_LIBS}; \
711.21Sreinoud		${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o ${USERMODE_LIBS}
721.7SjmcneillNVFLAGS=	-n
731.1Sjmcneill
741.1Sjmcneill##
751.1Sjmcneill## (6) port specific target dependencies
761.1Sjmcneill##
771.1Sjmcneill
781.9Sjmcneill.if !make(obj) && !make(clean) && !make(cleandir)
791.9Sjmcneill.BEGIN:
801.9Sjmcneill	@rm -f i386 && \
811.9Sjmcneill		ln -s $S/arch/i386/include i386
821.29Sreinoud	@rm -f amd64 && \
831.29Sreinoud		ln -s $S/arch/amd64/include amd64
841.9Sjmcneill.endif
851.9Sjmcneill
861.15Sjmcneillthunk.d: ${USERMODE}/usermode/thunk.c
871.15Sjmcneill	${MKDEP} -f ${.TARGET} -- ${MKDEP_CFLAGS} \
881.15Sjmcneill	    ${CPPFLAGS.thunk.c} ${USERMODE}/usermode/thunk.c
891.15Sjmcneill
901.8Sjmcneillthunk.o: ${USERMODE}/usermode/thunk.c
911.27Schristos	${CC} ${COPTS} ${CPPFLAGS.thunk.c} -c -o $@ ${USERMODE}/usermode/thunk.c
921.8Sjmcneill
931.1Sjmcneill##
941.1Sjmcneill## (7) misc settings
951.1Sjmcneill##
961.1Sjmcneill
971.1Sjmcneill##
981.1Sjmcneill## (8) config(8) generated machinery
991.1Sjmcneill%INCLUDES
1001.1Sjmcneill
1011.1Sjmcneill%OBJS
1021.1Sjmcneill
1031.1Sjmcneill%CFILES
1041.1Sjmcneill
1051.1Sjmcneill%SFILES
1061.1Sjmcneill
1071.1Sjmcneill%LOAD
1081.1Sjmcneill
1091.1Sjmcneill%RULES
1101.1Sjmcneill
1111.1Sjmcneill##
1121.1Sjmcneill## (9) port independent kernel machinery
1131.1Sjmcneill##
1141.1Sjmcneill.include "$S/conf/Makefile.kern.inc"
1151.1Sjmcneill
1161.1Sjmcneill##
1171.1Sjmcneill## (10) appending make options
1181.1Sjmcneill##
1191.1Sjmcneill%MAKEOPTIONSAPPEND
120