1999-08-28 01:08:13 +00:00
|
|
|
# $FreeBSD$
|
1995-06-25 17:32:43 +00:00
|
|
|
|
2010-08-23 06:13:29 +00:00
|
|
|
.if ${MACHINE_CPUARCH} == "amd64"
|
2006-08-15 13:01:36 +00:00
|
|
|
SFX= 32
|
2010-03-11 14:49:06 +00:00
|
|
|
CFLAGS+=-DCOMPAT_FREEBSD32 -DCOMPAT_LINUX32
|
2006-08-15 13:01:36 +00:00
|
|
|
.endif
|
|
|
|
|
2017-03-04 10:10:17 +00:00
|
|
|
.PATH: ${SRCTOP}/sys/compat/linux ${SRCTOP}/sys/${MACHINE_CPUARCH}/linux${SFX}
|
2001-01-06 14:00:42 +00:00
|
|
|
|
2015-05-24 15:28:17 +00:00
|
|
|
VDSO= linux${SFX}_vdso
|
|
|
|
|
1998-10-16 04:30:52 +00:00
|
|
|
KMOD= linux
|
2015-05-24 16:41:39 +00:00
|
|
|
SRCS= linux_fork.c linux${SFX}_dummy.c linux_file.c linux_event.c \
|
2013-09-18 18:48:33 +00:00
|
|
|
linux_futex.c linux_getcwd.c linux_ioctl.c linux_ipc.c \
|
2015-05-24 15:51:18 +00:00
|
|
|
linux${SFX}_machdep.c linux_misc.c linux_signal.c \
|
MFP4 (with some minor changes):
Implement the linux_io_* syscalls (AIO). They are only enabled if the native
AIO code is available (either compiled in to the kernel or as a module) at
the time the functions are used. If the AIO stuff is not available there
will be a ENOSYS.
From the submitter:
---snip---
DESIGN NOTES:
1. Linux permits a process to own multiple AIO queues (distinguished by
"context"), but FreeBSD creates only one single AIO queue per process.
My code maintains a request queue (STAILQ of queue(3)) per "context",
and throws all AIO requests of all contexts owned by a process into
the single FreeBSD per-process AIO queue.
When the process calls io_destroy(2), io_getevents(2), io_submit(2) and
io_cancel(2), my code can pick out requests owned by the specified context
from the single FreeBSD per-process AIO queue according to the per-context
request queues maintained by my code.
2. The request queue maintained by my code stores contrast information between
Linux IO control blocks (struct linux_iocb) and FreeBSD IO control blocks
(struct aiocb). FreeBSD IO control block actually exists in userland memory
space, required by FreeBSD native aio_XXXXXX(2).
3. It is quite troubling that the function io_getevents() of libaio-0.3.105
needs to use Linux-specific "struct aio_ring", which is a partial mirror
of context in user space. I would rather take the address of context in
kernel as the context ID, but the io_getevents() of libaio forces me to
take the address of the "ring" in user space as the context ID.
To my surprise, one comment line in the file "io_getevents.c" of
libaio-0.3.105 reads:
Ben will hate me for this
REFERENCE:
1. Linux kernel source code: http://www.kernel.org/pub/linux/kernel/v2.6/
(include/linux/aio_abi.h, fs/aio.c)
2. Linux manual pages: http://www.kernel.org/pub/linux/docs/manpages/
(io_setup(2), io_destroy(2), io_getevents(2), io_submit(2), io_cancel(2))
3. Linux Scalability Effort: http://lse.sourceforge.net/io/aio.html
The design notes: http://lse.sourceforge.net/io/aionotes.txt
4. The package libaio, both source and binary:
http://rpmfind.net/linux/rpm2html/search.php?query=libaio
Simple transparent interface to Linux AIO system calls.
5. Libaio-oracle: http://oss.oracle.com/projects/libaio-oracle/
POSIX AIO implementation based on Linux AIO system calls (depending on
libaio).
---snip---
Submitted by: Li, Xiao <intron@intron.ac>
2006-10-15 14:22:14 +00:00
|
|
|
linux_socket.c linux_stats.c linux_sysctl.c linux${SFX}_sysent.c \
|
2015-05-24 15:51:18 +00:00
|
|
|
linux${SFX}_sysvec.c linux_uid16.c linux_time.c \
|
2015-05-24 15:28:17 +00:00
|
|
|
linux_timer.c linux_vdso.c \
|
2013-11-25 07:38:45 +00:00
|
|
|
opt_inet6.h opt_compat.h opt_posix.h opt_usb.h vnode_if.h \
|
2014-10-17 04:36:53 +00:00
|
|
|
device_if.h bus_if.h assym.s \
|
2015-05-24 15:28:17 +00:00
|
|
|
linux${SFX}_support.s
|
2014-10-27 18:37:11 +00:00
|
|
|
DPSRCS= linux${SFX}_genassym.c
|
2007-05-23 08:33:06 +00:00
|
|
|
|
|
|
|
# XXX: for assym.s
|
2009-05-26 20:22:03 +00:00
|
|
|
SRCS+= opt_kstack_pages.h opt_nfs.h opt_compat.h opt_hwpmc_hooks.h
|
2010-08-23 06:13:29 +00:00
|
|
|
.if ${MACHINE_CPUARCH} == "i386"
|
2009-05-26 20:57:19 +00:00
|
|
|
SRCS+= opt_apic.h
|
|
|
|
.endif
|
2007-05-23 08:33:06 +00:00
|
|
|
|
2015-05-24 15:28:17 +00:00
|
|
|
OBJS= ${VDSO}.so
|
|
|
|
|
2010-08-23 06:13:29 +00:00
|
|
|
.if ${MACHINE_CPUARCH} == "i386"
|
2016-07-10 08:22:04 +00:00
|
|
|
SRCS+= linux_ptrace.c imgact_linux.c linux_util.c linux_mib.c linux_mmap.c \
|
2015-05-24 17:47:20 +00:00
|
|
|
linux_emul.c opt_cpu.h linux.c
|
2000-09-06 20:21:15 +00:00
|
|
|
.endif
|
|
|
|
|
2015-05-24 15:51:18 +00:00
|
|
|
.if ${MACHINE_CPUARCH} == "i386"
|
2002-02-22 18:21:20 +00:00
|
|
|
EXPORT_SYMS=
|
|
|
|
EXPORT_SYMS+= linux_emul_path
|
|
|
|
EXPORT_SYMS+= linux_get_osname
|
|
|
|
EXPORT_SYMS+= linux_get_osrelease
|
|
|
|
EXPORT_SYMS+= linux_ioctl_register_handler
|
|
|
|
EXPORT_SYMS+= linux_ioctl_unregister_handler
|
2015-05-24 15:51:18 +00:00
|
|
|
.endif
|
2002-02-22 18:21:20 +00:00
|
|
|
|
2015-05-24 15:28:17 +00:00
|
|
|
CLEANFILES= linux${SFX}_assym.h linux${SFX}_genassym.o linux${SFX}_locore.o
|
1996-03-02 20:00:35 +00:00
|
|
|
|
2006-08-15 13:01:36 +00:00
|
|
|
linux${SFX}_assym.h: linux${SFX}_genassym.o
|
2014-11-06 16:48:37 +00:00
|
|
|
sh ${SYSDIR}/kern/genassym.sh linux${SFX}_genassym.o > ${.TARGET}
|
1996-03-02 20:00:35 +00:00
|
|
|
|
2014-10-17 04:36:53 +00:00
|
|
|
linux${SFX}_locore.o: linux${SFX}_assym.h assym.s
|
2015-05-24 15:28:17 +00:00
|
|
|
${CC} -x assembler-with-cpp -DLOCORE -m32 -shared -s \
|
|
|
|
-pipe -I. -I${SYSDIR} -Werror -Wall -fno-common -nostdinc -nostdlib \
|
2016-02-25 19:26:14 +00:00
|
|
|
-fno-omit-frame-pointer -fPIC \
|
2017-03-04 10:10:17 +00:00
|
|
|
-Wl,-T${SRCTOP}/sys/${MACHINE_CPUARCH}/linux${SFX}/${VDSO}.lds.s \
|
2016-02-25 19:26:14 +00:00
|
|
|
-Wl,-soname=${VDSO}.so.1,--eh-frame-hdr,-warn-common \
|
2001-01-06 14:00:42 +00:00
|
|
|
${.IMPSRC} -o ${.TARGET}
|
1996-03-02 20:00:35 +00:00
|
|
|
|
2014-10-17 04:36:53 +00:00
|
|
|
linux${SFX}_support.o: linux${SFX}_assym.h assym.s
|
2007-05-23 08:33:06 +00:00
|
|
|
${CC} -c -x assembler-with-cpp -DLOCORE ${CFLAGS} \
|
|
|
|
${.IMPSRC} -o ${.TARGET}
|
|
|
|
|
2015-05-24 15:28:17 +00:00
|
|
|
.if ${MACHINE_CPUARCH} == "amd64"
|
|
|
|
${VDSO}.so: linux${SFX}_locore.o
|
2015-05-25 01:07:55 +00:00
|
|
|
${OBJCOPY} --input-target binary --output-target elf64-x86-64-freebsd \
|
2015-05-24 15:28:17 +00:00
|
|
|
--binary-architecture i386 linux${SFX}_locore.o ${.TARGET}
|
|
|
|
.else
|
|
|
|
${VDSO}.so: linux${SFX}_locore.o
|
2015-05-25 01:07:55 +00:00
|
|
|
${OBJCOPY} --input-target binary --output-target elf32-i386-freebsd \
|
2015-05-24 15:28:17 +00:00
|
|
|
--binary-architecture i386 linux${SFX}_locore.o ${.TARGET}
|
|
|
|
.endif
|
|
|
|
|
2014-10-17 04:36:53 +00:00
|
|
|
linux${SFX}_genassym.o:
|
2017-02-21 18:59:17 +00:00
|
|
|
${CC} -c ${CFLAGS:N-flto:N-fno-common} ${.IMPSRC}
|
1996-03-02 20:00:35 +00:00
|
|
|
|
2005-10-14 23:30:17 +00:00
|
|
|
.if !defined(KERNBUILDDIR)
|
2009-05-07 10:01:05 +00:00
|
|
|
.if defined(KTR)
|
|
|
|
CFLAGS+= -DKTR
|
|
|
|
.endif
|
2015-05-24 15:28:17 +00:00
|
|
|
.if defined(DEBUG)
|
|
|
|
CFLAGS+= -DDEBUG
|
|
|
|
.endif
|
2005-10-14 23:30:17 +00:00
|
|
|
.endif
|
2003-02-03 17:43:20 +00:00
|
|
|
|
2000-05-27 01:14:33 +00:00
|
|
|
.include <bsd.kmod.mk>
|