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