Makefile.usermode revision 1.28
11.28Sjmcneill# $NetBSD: Makefile.usermode,v 1.28 2012/01/05 12:12:58 jmcneill 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.1Sjmcneill## 571.1Sjmcneill## (5) link settings 581.1Sjmcneill## 591.24SjmcneillTEXTADDR?= %TEXTADDR% 601.21Sreinoud 611.21SreinoudLINKFLAGS_NORMAL= -X 621.21SreinoudKERN_LDSCRIPT?= kern.ldscript 631.21Sreinoud#LINKFORMAT= -T ${USERMODE}/conf/${KERN_LDSCRIPT} 641.21Sreinoud 651.8SjmcneillSYSTEM_LD= @${_MKSHMSG} " link ${.CURDIR:T}/${.TARGET}"; \ 661.6Sjmcneill ${_MKSHECHO}\ 671.21Sreinoud ${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o ${USERMODE_LIBS}; \ 681.21Sreinoud ${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o ${USERMODE_LIBS} 691.7SjmcneillNVFLAGS= -n 701.1Sjmcneill 711.1Sjmcneill## 721.1Sjmcneill## (6) port specific target dependencies 731.1Sjmcneill## 741.1Sjmcneill 751.9Sjmcneill.if !make(obj) && !make(clean) && !make(cleandir) 761.9Sjmcneill.BEGIN: 771.9Sjmcneill @rm -f i386 && \ 781.9Sjmcneill ln -s $S/arch/i386/include i386 791.9Sjmcneill.endif 801.9Sjmcneill 811.15Sjmcneillthunk.d: ${USERMODE}/usermode/thunk.c 821.15Sjmcneill ${MKDEP} -f ${.TARGET} -- ${MKDEP_CFLAGS} \ 831.15Sjmcneill ${CPPFLAGS.thunk.c} ${USERMODE}/usermode/thunk.c 841.15Sjmcneill 851.8Sjmcneillthunk.o: ${USERMODE}/usermode/thunk.c 861.27Schristos ${CC} ${COPTS} ${CPPFLAGS.thunk.c} -c -o $@ ${USERMODE}/usermode/thunk.c 871.8Sjmcneill 881.1Sjmcneill## 891.1Sjmcneill## (7) misc settings 901.1Sjmcneill## 911.1Sjmcneill 921.1Sjmcneill## 931.1Sjmcneill## (8) config(8) generated machinery 941.1Sjmcneill%INCLUDES 951.1Sjmcneill 961.1Sjmcneill%OBJS 971.1Sjmcneill 981.1Sjmcneill%CFILES 991.1Sjmcneill 1001.1Sjmcneill%SFILES 1011.1Sjmcneill 1021.1Sjmcneill%LOAD 1031.1Sjmcneill 1041.1Sjmcneill%RULES 1051.1Sjmcneill 1061.1Sjmcneill## 1071.1Sjmcneill## (9) port independent kernel machinery 1081.1Sjmcneill## 1091.1Sjmcneill.include "$S/conf/Makefile.kern.inc" 1101.1Sjmcneill 1111.1Sjmcneill## 1121.1Sjmcneill## (10) appending make options 1131.1Sjmcneill## 1141.1Sjmcneill%MAKEOPTIONSAPPEND 115