Re: [PATCH] gpiolib: Allow user-selection

From: David Brownell
Date: Thu Jul 03 2008 - 04:18:32 EST


On Wednesday 02 July 2008, Andrew Morton wrote:
>
> > I'm thinking some driver model changes broke the gpio sysfs
> > interface code, and this happens to show up right now because
> > that code wasn't previously getting built.
> >
> > Grumph.  I can easily switch the device_create() over to
> > use device_create_drvdata() -- didn't I already send in
> > a patch like that? -- but the other stuff is completely
> > backwards-incompatible.
> >
>
> beats me ididntdoitnobodysawmedoit.

I hope you got the T-shirt while you weren't doing all that! :)


> But what I am repeatedly seeing is people cheerfully raising 2.6.27
> patches against the 2.6.26 tree when we have a nice 2.6.27 tree for
> developing against.  Those days are over, guys.

In this case, the contract seems to have changed. Previously,
it was that folk doing the API changes would change everyone
using the APIs ... in this case, that's not happened. (And I
can sort of understand why. No matter how it's done, someone
is going to get extra work because of those changes.)


> I'm also seeing obvious signs that developers aren't _testing_ their
> new code within the context of the 2.6.27 tree.  They're obviously
> testing their stuff against 2.6.26

As they most certainly should. That's already a lot of
variables in the test process, and anyone wanting to
actually *USE* that code right now will probably not want
all the added turnover and variables of the -next tree.


> and then hoping and praying, only it
> doesn't always work out for them.

The new "-next" process is still working out. Backwards-incompatible
changes will *always* make problems. In this case there seem to
have been three such changes:

- device_create() vanishing, even for users which did the
locking correctly ... this was at least something of a
graceful migration, although it would have been better
if it were deprecated first. Change can work against
the current (2.6.26) code base.

- class.devices vanishing ... what I really needed was
more of a "is this class initialized yet" call, so
testing for class->devices.next non-null can be replaced
by a test for class->p non-null. (Or maybe this should
be viewed as needing a "real" driver model call, so that
code which must run before driver model init can more
easily cooperate with driver model stuff that has to
run much later, after the guts are initialized.)

- Extra parameter to class_find_device(). This could
have been done in a backwards-compatible manner, like
device_create() was, but ... it wasn't.

When I finish pulling linux-next, I'll make an updated patch.
And probably send in an updated version of Michaels patch;
though I imagine the update will be no more than a s-o-b.

- dave
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/