Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 9 Nov 2005 21:06:28 +0000 (GMT)
From:      Robert Watson <rwatson@FreeBSD.org>
To:        Mark Linimon <linimon@lonesome.com>
Cc:        Marcin Jessa <lists@yazzy.org>, current@freebsd.org, Max Khon <fjoe@samodelkin.net>
Subject:   Re: Generic Kernel API
Message-ID:  <20051109210246.Y33260@fledge.watson.org>
In-Reply-To: <20051109200458.GA26742@soaustin.net>
References:  <20051108232855.2d1b7df5.lists@yazzy.org> <20051109093920.GA45506@samodelkin.net> <20051109110903.583bb72d.lists@yazzy.org> <20051109121720.M39365@fledge.watson.org> <20051109200458.GA26742@soaustin.net>

next in thread | previous in thread | raw e-mail | index | archive | help

On Wed, 9 Nov 2005, Mark Linimon wrote:

> On Wed, Nov 09, 2005 at 12:20:14PM +0000, Robert Watson wrote:
>> My hope is that in the next year or so, things will settle down
>> significantly as we begin to flush the last of the non-MPSAFE drivers
>> from the system, and reach a point where all device drivers can use
>> consistent synchronization.
>
> If we are working towards that, I'd like to see someone contact the 
> suppliers of the binary-only drivers and tell them that's where we're 
> heading.  IMHO we are starting to win back some 'mind-share' out there 
> in the real world with 6.0 and we should build on that momentum.

I think the first step is to figure out what we're doing.  In the past, 
we've tried to offer relative API/ABI stability across minor releases for 
two classes of device drivers:

- Network interface device drivers
- Storage device drivers

However, we've not made a formal effort to decide what APIs are "safe" for 
device driver vendors to use, and only in the 5/6 time frame have we 
attempted to start hardening the APIs so as to make it possible to keep 
evolving the implementation in a branch without breaking device drivers. 
Some work needs to be done up front to survey what APIs and ABIs device 
drivers currently use, or use indirectly -- things like which data 
structures they depend on for stability (offset of fields in struct 
thread?), which symbols they depend on, what structures they embed 
(meaning we need to preserve size, not just layout) in the stack or their 
own data structures.  In 6.x, with ifnet no longer being embedded in 
device driver data structures, we've improved quite a bit.  In the 
developer summit session on the topic, I'm proposing we identify 
depenendencies of network device drivers, and then discuss where to 
harden, where to hide, and so on.  We won't get it entirely right the 
first time, but I think a bit of investigation and a bit of cleanup will 
go a long way.  Fortunately, we have a pretty good sampling of network 
device drivers in our tree already to look at.

Robert N M Watson



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20051109210246.Y33260>