Date: Wed, 09 Nov 2005 22:52:48 -0500 From: Chuck Swiger <cswiger@mac.com> To: Scott Long <scottl@samsco.org> Cc: Poul-Henning Kamp <phk@phk.freebsd.dk>, Julian Elischer <julian@elischer.org>, current@freebsd.org Subject: Re: Generic Kernel API Message-ID: <4372C410.5060707@mac.com> In-Reply-To: <4372B360.50203@samsco.org> References: <1566.1131574723@critter.freebsd.dk> <916E69BA-AE58-4BB4-AB8A-01BDFBA5FF49@mac.com> <43729ED9.9050204@samsco.org> <4372AED7.9000403@elischer.org> <4372B360.50203@samsco.org>
next in thread | previous in thread | raw e-mail | index | archive | help
Scott Long wrote: > Julian Elischer wrote: [ ... ] >> but if we could implement it we could run apple drivers.... >> (when they move to x86) > > No, we can't, unless we emulate the rest of the kernel API in OSX. > IOKit doesn't describe the entire kernel API. Think of it as 'newbus > done right' and nothing more. The rest of the kernel interfaces are > up for grabs. Some look and act like their BSD counterparts, some do > not. Scott's right that the IOKit is not a complete set of calls. The primary thing [1] that would be missing for Apple's drivers would be Mach messaging and Mach memory calls, which provide some of the underlying serialization capabilites of events, or clearly pertain to DMA (respectively). Apple has a portability layer written for Solaris, HP/UX, and even Windows which has a nmserver daemon which handles Mach messaging, and a shim for Mach memory calls using the SysV shared-memory interface. This has been included with PDO/EOF, WebObjects, and the FoundationKit packages with slight name variantions over time. The code is probably used by the ports of lookupd and netinfod...? -- -Chuck [1]: The complete KPI list for compliant drivers ought to be: com.apple.kernel.iokit, com.apple.kernel.libkern ...which would be enough for open source drivers, but a complete emulation layer would probably involve much of: com.apple.kernel, com.apple.kernel.mach, com.apple.kernel.bsd, com.apple.kernel.libkern, com.apple.kernel.iokit Fortunately, the upstream BSD layer is reasonably close to what FreeBSD has, except for Mach exception handling versus traditional BSD signals. MachO is not that different from ELF, and GCC already supports the BFD for it. There is some difference in dynamic linking semantics and namespaces, and someone would have to figure out the C++ name mangling, too. If this part was done, you might obtain reasonable compatibility with closed drivers available as binaries only, similar to what Project Evil/NDIS does now.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?4372C410.5060707>