On Mon, 20 Sep 2010 16:11:31 +0200
Ohad Ben-Cohen<ohad@xxxxxxxxxx> wrote:
Occasionally, drivers care about the value that idr associates withIt seems OK to me - it's an improvement over what we have now.
their pointers.
Today we have idr_get_new_above() which allocates a new idr entry
above or equal to a given starting id, but sometimes drivers need to
force an exact value.
To overcome this small API gap, drivers are wrapping idr_get_new_above
and then either BUG_ON() or just call idr_remove() and returns -EBUSY
when idr allocates them an id which is different than their requested
value.
There are only a handful of users who need this (see below. especially
note the i2c comment :), but it might be nice to have such an API (a
bit less of code, and a bit less error prone).
Would something like the below be desirable/acceptable ?