Re: [PATCH] Block on access to temporarily unavailable pci device

From: Nick Piggin
Date: Wed Oct 18 2006 - 11:28:12 EST


Matthew Wilcox wrote:
On Thu, Oct 19, 2006 at 01:12:42AM +1000, Nick Piggin wrote:

Why not just WARN if it is already blocked as well? Presumably if the


Because the driver can check the return value and fail the higher level
operation.


driver needs nested blocking, it is going to have to carry some state
to know when to do the final unblock anyway, so it may as well just
not do these redundant blocks either.


No driver needs nested blocking, but blocks may be imposed on a driver's
device by the PCI core, for example.

So doesn't that mean it needs nested blocking? Surely that's better than
failing the operation due to an implementation detail.


** or ** just do a counting block/unblock to properly support nesting
them. That is, go one way or the other, and do it properly.


I don't think that's necessary. Right now, we have one user (IPR's
BIST) and I'm trying to add a second (D-state transitions). We don't
need nested blocks, but we do need to fail in the highly unlikely case
someone tries to do them.

Well if you really don't need nested blocking and you want to fail in
the highly unlikely case that someone tries... add the WARN.

If it turns out we actually need them later, let's revisit this when we
have a user.

I don't know much about the pci layer, so I'm sure you know better than
me whether they are needed or not. But if you think they are not, then
do the WARN rather than return failure.

--
SUSE Labs, Novell Inc.

Send instant messages to your online friends http://au.messenger.yahoo.com -
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/