Makefile.usermode revision 1.32
11.32Sreinoud# $NetBSD: Makefile.usermode,v 1.32 2012/06/30 15:03:57 reinoud 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.20SjmcneillUSERMODE_CPPFLAGS=${DEBUG} -U_KERNEL -I/usr/include 251.18SjmcneillUSERMODE_CPPFLAGS+=${CWARNFLAGS} ${NOGCCERROR:D:U-Werror} 261.18Sjmcneill 271.32Sreinoud## XXX hack to make it work under build.sh 281.32Sreinoud.if ${TOOLDIR:Uno} != "no" 291.32SreinoudUSERMODE_LIBS+= crti.o 301.32SreinoudSYSTEM_LD_FIX= cp ${DESTDIR}/usr/lib/crt0.o ${DESTDIR}/usr/lib/crtbegin.o ${DESTDIR}/usr/lib/crtend.o ${DESTDIR}/usr/lib/crti.o .; 311.32Sreinoud.endif 321.32Sreinoud 331.17Sjmcneill.if ${USERMODE_HOSTOS} == "Linux" 341.17SjmcneillUSERMODE_LIBS+= -lpthread 351.18SjmcneillCPPFLAGS+=-Dstrtoul=netbsd_strtoul 361.18SjmcneillCPPFLAGS+=-Dstrtoll=netbsd_strtoll 371.18SjmcneillCPPFLAGS+=-Dstrtoull=netbsd_strtoull 381.19SjmcneillCPPFLAGS+=-D__NetBSD__ -Wno-unused-but-set-variable 391.17Sjmcneill.endif 401.10Sjmcneill 411.12SreinoudDEFCOPTS= -fno-omit-frame-pointer 421.19SjmcneillCPPFLAGS+= -Dusermode 431.28SjmcneillCPPFLAGS+= -Dsyscall=kernel_syscall 441.2SjmcneillCPPFLAGS.init_main.c+= -Dmain=kernmain 451.1Sjmcneill 461.14SjmcneillCPPFLAGS.thunk.c+= ${USERMODE_CPPFLAGS} 471.8Sjmcneill 481.1Sjmcneill## 491.1Sjmcneill## (3) libkern and compat 501.1Sjmcneill## 511.18SjmcneillKERN_AS= library 521.18SjmcneillCOMPAT_AS= library 531.1Sjmcneill 541.1Sjmcneill## 551.1Sjmcneill## (4) local objects, compile rules, and dependencies 561.1Sjmcneill## 571.8SjmcneillMD_OBJS= thunk.o 581.8SjmcneillMD_CFILES= ${USERMODE}/usermode/thunk.c 591.16SjmcneillMD_SFILES= 601.16Sjmcneill 611.31SreinoudMD_OBJS+= cpu_${MACHINE_ARCH}.o 621.31SreinoudMD_CFILES+= ${USERMODE}/target/${MACHINE_ARCH}/cpu_${MACHINE_ARCH}.c 631.29Sreinoud 641.1Sjmcneill## 651.1Sjmcneill## (5) link settings 661.1Sjmcneill## 671.24SjmcneillTEXTADDR?= %TEXTADDR% 681.21Sreinoud 691.21SreinoudLINKFLAGS_NORMAL= -X 701.21SreinoudKERN_LDSCRIPT?= kern.ldscript 711.21Sreinoud#LINKFORMAT= -T ${USERMODE}/conf/${KERN_LDSCRIPT} 721.21Sreinoud 731.8SjmcneillSYSTEM_LD= @${_MKSHMSG} " link ${.CURDIR:T}/${.TARGET}"; \ 741.6Sjmcneill ${_MKSHECHO}\ 751.21Sreinoud ${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o ${USERMODE_LIBS}; \ 761.32Sreinoud ${SYSTEM_LD_FIX} \ 771.21Sreinoud ${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o ${USERMODE_LIBS} 781.7SjmcneillNVFLAGS= -n 791.1Sjmcneill 801.1Sjmcneill## 811.1Sjmcneill## (6) port specific target dependencies 821.1Sjmcneill## 831.1Sjmcneill 841.9Sjmcneill.if !make(obj) && !make(clean) && !make(cleandir) 851.9Sjmcneill.BEGIN: 861.9Sjmcneill @rm -f i386 && \ 871.9Sjmcneill ln -s $S/arch/i386/include i386 881.29Sreinoud @rm -f amd64 && \ 891.29Sreinoud ln -s $S/arch/amd64/include amd64 901.9Sjmcneill.endif 911.9Sjmcneill 921.15Sjmcneillthunk.d: ${USERMODE}/usermode/thunk.c 931.15Sjmcneill ${MKDEP} -f ${.TARGET} -- ${MKDEP_CFLAGS} \ 941.15Sjmcneill ${CPPFLAGS.thunk.c} ${USERMODE}/usermode/thunk.c 951.15Sjmcneill 961.8Sjmcneillthunk.o: ${USERMODE}/usermode/thunk.c 971.27Schristos ${CC} ${COPTS} ${CPPFLAGS.thunk.c} -c -o $@ ${USERMODE}/usermode/thunk.c 981.8Sjmcneill 991.1Sjmcneill## 1001.1Sjmcneill## (7) misc settings 1011.1Sjmcneill## 1021.1Sjmcneill 1031.1Sjmcneill## 1041.1Sjmcneill## (8) config(8) generated machinery 1051.1Sjmcneill%INCLUDES 1061.1Sjmcneill 1071.1Sjmcneill%OBJS 1081.1Sjmcneill 1091.1Sjmcneill%CFILES 1101.1Sjmcneill 1111.1Sjmcneill%SFILES 1121.1Sjmcneill 1131.1Sjmcneill%LOAD 1141.1Sjmcneill 1151.1Sjmcneill%RULES 1161.1Sjmcneill 1171.1Sjmcneill## 1181.1Sjmcneill## (9) port independent kernel machinery 1191.1Sjmcneill## 1201.1Sjmcneill.include "$S/conf/Makefile.kern.inc" 1211.1Sjmcneill 1221.1Sjmcneill## 1231.1Sjmcneill## (10) appending make options 1241.1Sjmcneill## 1251.1Sjmcneill%MAKEOPTIONSAPPEND 126