1 1.29 reinoud # $NetBSD: Makefile.usermode,v 1.29 2012/01/06 20:44:57 reinoud Exp $ 2 1.1 jmcneill 3 1.18 jmcneill OPT_CPU_HOST= %CPU_HOST% 4 1.18 jmcneill .if !empty(OPT_CPU_HOST) 5 1.18 jmcneill MACHINE_ARCH= ${OPT_CPU_HOST} 6 1.18 jmcneill .else 7 1.1 jmcneill MACHINE_ARCH= usermode 8 1.18 jmcneill .endif 9 1.1 jmcneill USETOOLS?= no 10 1.1 jmcneill NEED_OWN_INSTALL_TARGET?= no 11 1.1 jmcneill .include <bsd.own.mk> 12 1.1 jmcneill 13 1.1 jmcneill ## 14 1.1 jmcneill ## (1) port identification 15 1.1 jmcneill ## 16 1.1 jmcneill USERMODE= $S/arch/usermode 17 1.1 jmcneill GENASSYM_CONF= ${USERMODE}/usermode/genassym.cf 18 1.1 jmcneill 19 1.1 jmcneill ## 20 1.1 jmcneill ## (2) compile settings 21 1.1 jmcneill ## 22 1.17 jmcneill USERMODE_HOSTOS!=uname -s 23 1.18 jmcneill USERMODE_HOSTMACHINE!=uname -m 24 1.21 reinoud USERMODE_LIBS= -lc -lrt 25 1.20 jmcneill USERMODE_CPPFLAGS=${DEBUG} -U_KERNEL -I/usr/include 26 1.18 jmcneill USERMODE_CPPFLAGS+=${CWARNFLAGS} ${NOGCCERROR:D:U-Werror} 27 1.18 jmcneill 28 1.17 jmcneill .if ${USERMODE_HOSTOS} == "Linux" 29 1.17 jmcneill USERMODE_LIBS+= -lpthread 30 1.18 jmcneill CPPFLAGS+=-Dstrtoul=netbsd_strtoul 31 1.18 jmcneill CPPFLAGS+=-Dstrtoll=netbsd_strtoll 32 1.18 jmcneill CPPFLAGS+=-Dstrtoull=netbsd_strtoull 33 1.19 jmcneill CPPFLAGS+=-D__NetBSD__ -Wno-unused-but-set-variable 34 1.17 jmcneill .endif 35 1.10 jmcneill 36 1.12 reinoud DEFCOPTS= -fno-omit-frame-pointer 37 1.19 jmcneill CPPFLAGS+= -Dusermode 38 1.28 jmcneill CPPFLAGS+= -Dsyscall=kernel_syscall 39 1.2 jmcneill CPPFLAGS.init_main.c+= -Dmain=kernmain 40 1.1 jmcneill 41 1.14 jmcneill CPPFLAGS.thunk.c+= ${USERMODE_CPPFLAGS} 42 1.8 jmcneill 43 1.1 jmcneill ## 44 1.1 jmcneill ## (3) libkern and compat 45 1.1 jmcneill ## 46 1.18 jmcneill KERN_AS= library 47 1.18 jmcneill COMPAT_AS= library 48 1.1 jmcneill 49 1.1 jmcneill ## 50 1.1 jmcneill ## (4) local objects, compile rules, and dependencies 51 1.1 jmcneill ## 52 1.8 jmcneill MD_OBJS= thunk.o 53 1.8 jmcneill MD_CFILES= ${USERMODE}/usermode/thunk.c 54 1.16 jmcneill MD_SFILES= 55 1.16 jmcneill 56 1.29 reinoud MD_OBJS+= machdep.${USERMODE_CPU}.o 57 1.29 reinoud MD_CFILES+= ${USERMODE}/usermode/machdep.${USERMODE_CPU}.c 58 1.29 reinoud 59 1.1 jmcneill ## 60 1.1 jmcneill ## (5) link settings 61 1.1 jmcneill ## 62 1.24 jmcneill TEXTADDR?= %TEXTADDR% 63 1.21 reinoud 64 1.21 reinoud LINKFLAGS_NORMAL= -X 65 1.21 reinoud KERN_LDSCRIPT?= kern.ldscript 66 1.21 reinoud #LINKFORMAT= -T ${USERMODE}/conf/${KERN_LDSCRIPT} 67 1.21 reinoud 68 1.8 jmcneill SYSTEM_LD= @${_MKSHMSG} " link ${.CURDIR:T}/${.TARGET}"; \ 69 1.6 jmcneill ${_MKSHECHO}\ 70 1.21 reinoud ${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o ${USERMODE_LIBS}; \ 71 1.21 reinoud ${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o ${USERMODE_LIBS} 72 1.7 jmcneill NVFLAGS= -n 73 1.1 jmcneill 74 1.1 jmcneill ## 75 1.1 jmcneill ## (6) port specific target dependencies 76 1.1 jmcneill ## 77 1.1 jmcneill 78 1.9 jmcneill .if !make(obj) && !make(clean) && !make(cleandir) 79 1.9 jmcneill .BEGIN: 80 1.9 jmcneill @rm -f i386 && \ 81 1.9 jmcneill ln -s $S/arch/i386/include i386 82 1.29 reinoud @rm -f amd64 && \ 83 1.29 reinoud ln -s $S/arch/amd64/include amd64 84 1.9 jmcneill .endif 85 1.9 jmcneill 86 1.15 jmcneill thunk.d: ${USERMODE}/usermode/thunk.c 87 1.15 jmcneill ${MKDEP} -f ${.TARGET} -- ${MKDEP_CFLAGS} \ 88 1.15 jmcneill ${CPPFLAGS.thunk.c} ${USERMODE}/usermode/thunk.c 89 1.15 jmcneill 90 1.8 jmcneill thunk.o: ${USERMODE}/usermode/thunk.c 91 1.27 christos ${CC} ${COPTS} ${CPPFLAGS.thunk.c} -c -o $@ ${USERMODE}/usermode/thunk.c 92 1.8 jmcneill 93 1.1 jmcneill ## 94 1.1 jmcneill ## (7) misc settings 95 1.1 jmcneill ## 96 1.1 jmcneill 97 1.1 jmcneill ## 98 1.1 jmcneill ## (8) config(8) generated machinery 99 1.1 jmcneill %INCLUDES 100 1.1 jmcneill 101 1.1 jmcneill %OBJS 102 1.1 jmcneill 103 1.1 jmcneill %CFILES 104 1.1 jmcneill 105 1.1 jmcneill %SFILES 106 1.1 jmcneill 107 1.1 jmcneill %LOAD 108 1.1 jmcneill 109 1.1 jmcneill %RULES 110 1.1 jmcneill 111 1.1 jmcneill ## 112 1.1 jmcneill ## (9) port independent kernel machinery 113 1.1 jmcneill ## 114 1.1 jmcneill .include "$S/conf/Makefile.kern.inc" 115 1.1 jmcneill 116 1.1 jmcneill ## 117 1.1 jmcneill ## (10) appending make options 118 1.1 jmcneill ## 119 1.1 jmcneill %MAKEOPTIONSAPPEND 120