Makefile.usermode revision 1.42
11.42Sreinoud# $NetBSD: Makefile.usermode,v 1.42 2018/06/01 07:22:33 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.41Sreinoud ${CC} -static ${COPTS} -Wl,-Map,$${target}.map -o ${.TARGET} ${LINKFORMAT} -Ttext ${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o ${USERMODE_LIBS} $$@; \ 781.32Sreinoud ${SYSTEM_LD_FIX} \ 791.41Sreinoud ${CC} -static ${COPTS} -Wl,-Map,$${target}.map -o ${.TARGET} ${LINKFORMAT} -Ttext ${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o ${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