Skip site navigation (1)Skip section navigation (2)
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>