Re: [PATCH 2/8] idr: fix unexpected id-removal when idr_remove(unallocated_id)

From: Tejun Heo
Date: Fri Apr 18 2014 - 12:57:20 EST


On Fri, Apr 18, 2014 at 08:49:49PM +0800, Lai Jiangshan wrote:
> If unallocated_id = (ANY * idr_max(idp->layers) + existed_id) is passed

existing_id

> to idr_remove(). The existed_id will be removed unexpected.

ditto.

>
> The following test shows this unexpected id-removal:
>
> static void test4(void)
> {
> int id;
> DEFINE_IDR(test_idr);
>
> printk(KERN_INFO "Start test4\n");
> id = idr_alloc(&test_idr, (void *)1, 42, 43, GFP_KERNEL);
> BUG_ON(id != 42);
> idr_remove(&test_idr, 42 + IDR_SIZE);
> TEST_BUG_ON(idr_find(&test_idr, 42) != (void *)1);
> idr_destroy(&test_idr);
> printk(KERN_INFO "End of test4\n");
> }
>
> It only happens when unallocated_id, it is caller's fault. It is not
> a bug. But it is better to add the proper check and complains instead

complain

> of removing an existed_id silently.

existing_id

> Signed-off-by: Lai Jiangshan <laijs@xxxxxxxxxxxxxx>

Acked-by: Tejun Heo <tj@xxxxxxxxxx>

Thanks.

--
tejun
--
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/