1c3aac50fSPeter Wemm# $FreeBSD$ 2c21dee17SSøren Schmidt 3c09808d0SWarner Losh.if ${MACHINE_CPUARCH} == "amd64" 4adfa0adeSAlexander LeidingerSFX= 32 5841c0c7eSNathan WhitehornCFLAGS+=-DCOMPAT_FREEBSD32 -DCOMPAT_LINUX32 6adfa0adeSAlexander Leidinger.endif 7adfa0adeSAlexander Leidinger 8193d9e76SEnji Cooper.PATH: ${SRCTOP}/sys/compat/linux ${SRCTOP}/sys/${MACHINE_CPUARCH}/linux${SFX} 9e9b13c66SConrad Meyer.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64" 10e9b13c66SConrad Meyer.PATH: ${SRCTOP}/sys/x86/linux 11e9b13c66SConrad Meyer.endif 12c68159a6SDavid E. O'Brien 13a654d072SPeter WemmKMOD= linux 14df4ca45cSTijl CoosemansSRCS= linux_fork.c linux${SFX}_dummy_machdep.c linux_file.c linux_event.c \ 15b12698e1SRoman Divacky linux_futex.c linux_getcwd.c linux_ioctl.c linux_ipc.c \ 1667d39748SDmitry Chagin linux${SFX}_machdep.c linux_misc.c linux_signal.c \ 176a1162d4SAlexander Leidinger linux_socket.c linux_stats.c linux_sysctl.c linux${SFX}_sysent.c \ 1867d39748SDmitry Chagin linux${SFX}_sysvec.c linux_uid16.c linux_time.c \ 19ee55d560SDmitry Chagin linux_timer.c linux_vdso.c linux_rseq.c \ 2054366c0bSAttilio Rao opt_inet6.h opt_compat.h opt_posix.h opt_usb.h vnode_if.h \ 210cde66afSKonstantin Belousov device_if.h bus_if.h 22e9b13c66SConrad Meyer.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64" 23*2b378d59SDmitry ChaginSRCS+= linux_dummy_x86.c 249931033bSDmitry ChaginVDSODEPS=linux_vdso_gettc_x86.inc 25e9b13c66SConrad Meyer.endif 260cde66afSKonstantin Belousov.if ${MACHINE_CPUARCH} == "amd64" 270cde66afSKonstantin BelousovSRCS+= linux${SFX}_support.s 28447636e4SEdward Tomasz NapieralaSRCS+= linux_elf32.c 290cde66afSKonstantin Belousov.else 300cde66afSKonstantin BelousovSRCS+= linux_copyout.c 310cde66afSKonstantin Belousov.endif 32fc2a8776SEd MasteDPSRCS= assym.inc linux${SFX}_genassym.c 331c182de9SKonstantin Belousov 34fc2a8776SEd Maste# XXX: for assym.inc 356469bdcdSBrooks DavisSRCS+= opt_kstack_pages.h opt_nfs.h opt_hwpmc_hooks.h 36c09808d0SWarner Losh.if ${MACHINE_CPUARCH} == "i386" 37b2cc900aSDag-Erling SmørgravSRCS+= opt_apic.h 38b2cc900aSDag-Erling Smørgrav.endif 391c182de9SKonstantin Belousov 409931033bSDmitry ChaginOBJS= linux${SFX}_vdso.so 41bdc37934SDmitry Chagin 42c09808d0SWarner Losh.if ${MACHINE_CPUARCH} == "i386" 434dfd6122SEdward Tomasz NapieralaSRCS+= linux_ptrace_machdep.c imgact_linux.c linux_util.c linux_mib.c \ 442434137fSDmitry Chagin linux_mmap.c linux_dummy.c linux_emul.c linux_errno.c opt_cpu.h linux.c \ 45*2b378d59SDmitry Chagin linux_x86.c linux_vdso_selector_x86.c 46849baab8SDavid E. O'Brien.endif 47849baab8SDavid E. O'Brien 4867d39748SDmitry Chagin.if ${MACHINE_CPUARCH} == "i386" 49bea8bf95SDag-Erling SmørgravEXPORT_SYMS= 50bea8bf95SDag-Erling SmørgravEXPORT_SYMS+= linux_emul_path 51bea8bf95SDag-Erling SmørgravEXPORT_SYMS+= linux_get_osname 52bea8bf95SDag-Erling SmørgravEXPORT_SYMS+= linux_get_osrelease 53bea8bf95SDag-Erling SmørgravEXPORT_SYMS+= linux_ioctl_register_handler 54bea8bf95SDag-Erling SmørgravEXPORT_SYMS+= linux_ioctl_unregister_handler 5567d39748SDmitry Chagin.endif 56bea8bf95SDag-Erling Smørgrav 577c28c7e8SDmitry ChaginCLEANFILES= linux${SFX}_assym.h linux${SFX}_genassym.o linux${SFX}_locore.o \ 589931033bSDmitry Chagin genassym.o linux${SFX}_vdso_gtod.o linux${SFX}_vdso.so.o 59785d64c4SPeter Wemm 60adfa0adeSAlexander Leidingerlinux${SFX}_assym.h: linux${SFX}_genassym.o 61528013d5SWarner Losh sh ${SYSDIR}/kern/genassym.sh linux${SFX}_genassym.o > ${.TARGET} 62785d64c4SPeter Wemm 639931033bSDmitry Chagin.if ${MACHINE_CPUARCH} == "amd64" 64e36d0e86SKonstantin BelousovVDSOFLAGS=-DCOMPAT_FREEBSD32 -DCOMPAT_LINUX32 -m32 65b0fa09a0SDmitry Chagin.else 66b0fa09a0SDmitry ChaginVDSOFLAGS=-mregparm=0 679931033bSDmitry Chagin.endif 689931033bSDmitry Chagin 69fc2a8776SEd Mastelinux${SFX}_locore.o: linux${SFX}_assym.h assym.inc 709931033bSDmitry Chagin ${CC} -c -x assembler-with-cpp -DLOCORE -fPIC -pipe -O2 -Werror \ 71b0fa09a0SDmitry Chagin -msoft-float \ 72de273c83SDmitry Chagin -fno-common -nostdinc -fasynchronous-unwind-tables \ 739931033bSDmitry Chagin -fno-omit-frame-pointer -foptimize-sibling-calls ${VDSOFLAGS} \ 749931033bSDmitry Chagin -fno-stack-protector -I. -I${SYSDIR} -I${SRCTOP}/include \ 75c11bd941SBruce Evans ${.IMPSRC} -o ${.TARGET} 76785d64c4SPeter Wemm 779931033bSDmitry Chaginlinux${SFX}_vdso_gtod.o: linux_vdso_gtod.inc ${VDSODEPS} 78b0fa09a0SDmitry Chagin ${CC} -c -fPIC -pipe -O2 -Werror -msoft-float \ 79de273c83SDmitry Chagin -fno-common -nostdinc -fasynchronous-unwind-tables \ 809931033bSDmitry Chagin -fno-omit-frame-pointer -foptimize-sibling-calls ${VDSOFLAGS} \ 819931033bSDmitry Chagin -fno-stack-protector -I. -I${SYSDIR} -I${SRCTOP}/include \ 829931033bSDmitry Chagin ${.IMPSRC} -o ${.TARGET} 839931033bSDmitry Chagin 849931033bSDmitry Chaginlinux${SFX}_vdso.so.o: linux${SFX}_locore.o linux${SFX}_vdso_gtod.o 859931033bSDmitry Chagin ${LD} -m elf_i386 --shared --eh-frame-hdr -soname=linux-gate.so.1 \ 869931033bSDmitry Chagin --no-undefined --hash-style=both -warn-common -nostdlib \ 879931033bSDmitry Chagin --strip-debug -s --build-id=sha1 --Bsymbolic \ 889931033bSDmitry Chagin -T${SRCTOP}/sys/${MACHINE}/linux${SFX}/linux${SFX}_vdso.lds.s \ 899931033bSDmitry Chagin -o ${.TARGET} ${.ALLSRC:M*.o} 909931033bSDmitry Chagin 919931033bSDmitry Chagin.if ${MACHINE_CPUARCH} == "amd64" 929931033bSDmitry ChaginOBJCOPY_TARGET=--output-target elf64-x86-64-freebsd --binary-architecture i386 939931033bSDmitry Chagin.elif ${MACHINE_CPUARCH} == "i386" 949931033bSDmitry ChaginOBJCOPY_TARGET=--output-target elf32-i386-freebsd --binary-architecture i386 959931033bSDmitry Chagin.else 969931033bSDmitry Chagin.error ${MACHINE_CPUARCH} not yet supported by linux 979931033bSDmitry Chagin.endif 989931033bSDmitry Chagin 999931033bSDmitry Chaginlinux${SFX}_vdso.so: linux${SFX}_vdso.so.o 1009931033bSDmitry Chagin ${OBJCOPY} --input-target binary ${OBJCOPY_TARGET} \ 1019931033bSDmitry Chagin linux${SFX}_vdso.so.o ${.TARGET} 1029931033bSDmitry Chagin ${STRIPBIN} -N _binary_linux${SFX}_vdso_so_o_size ${.TARGET} 1039931033bSDmitry Chagin 1040cde66afSKonstantin Belousov.if ${MACHINE_CPUARCH} == "amd64" 105fc2a8776SEd Mastelinux${SFX}_support.o: linux${SFX}_assym.h assym.inc 1061c182de9SKonstantin Belousov ${CC} -c -x assembler-with-cpp -DLOCORE ${CFLAGS} \ 1071c182de9SKonstantin Belousov ${.IMPSRC} -o ${.TARGET} 108bdc37934SDmitry Chagin.endif 109bdc37934SDmitry Chagin 110ccca101fSBryan Drewerylinux${SFX}_genassym.o: offset.inc 1114db3ef4cSAlex Richardson ${CC} -c ${CFLAGS:N-flto:N-fno-common} -fcommon ${.IMPSRC} 112785d64c4SPeter Wemm 1136e4cf32eSDmitry Chagin.if !defined(KERNBUILDDIR) 1146e4cf32eSDmitry Chagin.warning Building Linuxulator outside of a kernel does not make sense 1156e4cf32eSDmitry Chagin.endif 1166e4cf32eSDmitry Chagin 1175bb3134aSKonstantin BelousovEXPORT_SYMS= YES 1185bb3134aSKonstantin Belousov 11964db83a8SPeter Wemm.include <bsd.kmod.mk> 120