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 <la...@cn.fujitsu.com>

Acked-by: Tejun Heo <t...@kernel.org>

Thanks.

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

Reply via email to