Second Attempt: Driver model usage on embedded processors

Andy Fleming afleming at freescale.com
Thu Dec 9 03:10:53 EST 2004


On Dec 7, 2004, at 08:53, Dan Malek wrote:
>> The issue I've got with #2 is that some of these devices (and 
>> therefor drivers) will end up existing on various parts from 
>> Freescale that might have an ARM core or PPC core.
>
> If the configuration options are truly static, we can do just like we 
> do today
> with processor cores that share similar peripherals.  Just #define 
> those things
> that are constants and compile them into the driver.  These could be 
> address
> offsets, functional support (like RMON), and so on.  There are examples
> of these drivers that work fine today and could work even better with 
> minor
> touch ups of the configuration options.  You have already #define'd 
> this
> stuff in the board/processor configuration files.  Why put them into a 
> static
> data structure and then find some complex method to access it?  These
> are embedded systems, after all, that want to minimize overhead.

The issue here is that the driver supports devices which can vary in 
features on the same processor.  An example is the gianfar driver for 
the 8540.  The driver supports the two TSEC devices, as well as the 
FEC.  In order to make the driver applicable to different processors 
with different device configurations, the driver needs to be agnostic 
about how many devices there are, and what features they have.  As 
such, defining constants does not solve the problem.

These things could be assigned statically at compile time, in the 
driver, but this means that every new processor will require adding 
#ifdefs to the driver, which will become progressively more difficult 
to maintain.

Anyway, I like the idea of using feature_call.  Are we sure, though, 
that it's not using a hammer for a screw?  I'm not very familiar with 
the function's intent.


Andy Fleming
Open Source Team
Freescale Semiconductor, Inc




More information about the Linuxppc-embedded mailing list