1 1.28 jmcneill # $NetBSD: Makefile.usermode,v 1.28 2012/01/05 12:12:58 jmcneill 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.1 jmcneill ## 57 1.1 jmcneill ## (5) link settings 58 1.1 jmcneill ## 59 1.24 jmcneill TEXTADDR?= %TEXTADDR% 60 1.21 reinoud 61 1.21 reinoud LINKFLAGS_NORMAL= -X 62 1.21 reinoud KERN_LDSCRIPT?= kern.ldscript 63 1.21 reinoud #LINKFORMAT= -T ${USERMODE}/conf/${KERN_LDSCRIPT} 64 1.21 reinoud 65 1.8 jmcneill SYSTEM_LD= @${_MKSHMSG} " link ${.CURDIR:T}/${.TARGET}"; \ 66 1.6 jmcneill ${_MKSHECHO}\ 67 1.21 reinoud ${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} '$${SYSTEM_OBJ}' '$${EXTRA_OBJ}' vers.o ${USERMODE_LIBS}; \ 68 1.21 reinoud ${CC} -static ${COPTS} -Wl,-Map,$@.map -o $@ ${LINKFORMAT} -Ttext ${TEXTADDR} ${SYSTEM_OBJ} ${EXTRA_OBJ} vers.o ${USERMODE_LIBS} 69 1.7 jmcneill NVFLAGS= -n 70 1.1 jmcneill 71 1.1 jmcneill ## 72 1.1 jmcneill ## (6) port specific target dependencies 73 1.1 jmcneill ## 74 1.1 jmcneill 75 1.9 jmcneill .if !make(obj) && !make(clean) && !make(cleandir) 76 1.9 jmcneill .BEGIN: 77 1.9 jmcneill @rm -f i386 && \ 78 1.9 jmcneill ln -s $S/arch/i386/include i386 79 1.9 jmcneill .endif 80 1.9 jmcneill 81 1.15 jmcneill thunk.d: ${USERMODE}/usermode/thunk.c 82 1.15 jmcneill ${MKDEP} -f ${.TARGET} -- ${MKDEP_CFLAGS} \ 83 1.15 jmcneill ${CPPFLAGS.thunk.c} ${USERMODE}/usermode/thunk.c 84 1.15 jmcneill 85 1.8 jmcneill thunk.o: ${USERMODE}/usermode/thunk.c 86 1.27 christos ${CC} ${COPTS} ${CPPFLAGS.thunk.c} -c -o $@ ${USERMODE}/usermode/thunk.c 87 1.8 jmcneill 88 1.1 jmcneill ## 89 1.1 jmcneill ## (7) misc settings 90 1.1 jmcneill ## 91 1.1 jmcneill 92 1.1 jmcneill ## 93 1.1 jmcneill ## (8) config(8) generated machinery 94 1.1 jmcneill %INCLUDES 95 1.1 jmcneill 96 1.1 jmcneill %OBJS 97 1.1 jmcneill 98 1.1 jmcneill %CFILES 99 1.1 jmcneill 100 1.1 jmcneill %SFILES 101 1.1 jmcneill 102 1.1 jmcneill %LOAD 103 1.1 jmcneill 104 1.1 jmcneill %RULES 105 1.1 jmcneill 106 1.1 jmcneill ## 107 1.1 jmcneill ## (9) port independent kernel machinery 108 1.1 jmcneill ## 109 1.1 jmcneill .include "$S/conf/Makefile.kern.inc" 110 1.1 jmcneill 111 1.1 jmcneill ## 112 1.1 jmcneill ## (10) appending make options 113 1.1 jmcneill ## 114 1.1 jmcneill %MAKEOPTIONSAPPEND 115