aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/gadget/function
diff options
context:
space:
mode:
authorRui Miguel Silva <rui.silva@linaro.org>2015-05-20 09:52:40 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2015-07-10 12:49:33 -0400
commit1e4205d4e0b0579b906de8ec7c5920968bfb32a9 (patch)
tree08718c752e98012a4508806188796bcd8ddb2cf9 /drivers/usb/gadget/function
parentbfa06e6258be556d44aad030fe1babeed4f92240 (diff)
usb: gadget: f_fs: add extra check before unregister_gadget_item
commit f14e9ad17f46051b02bffffac2036486097de19e upstream. ffs_closed can race with configfs_rmdir which will call config_item_release, so add an extra check to avoid calling the unregister_gadget_item with an null gadget item. Signed-off-by: Rui Miguel Silva <rui.silva@linaro.org> Signed-off-by: Felipe Balbi <balbi@ti.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/usb/gadget/function')
-rw-r--r--drivers/usb/gadget/function/f_fs.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/drivers/usb/gadget/function/f_fs.c b/drivers/usb/gadget/function/f_fs.c
index 3507f880eb74..45b8c8b338df 100644
--- a/drivers/usb/gadget/function/f_fs.c
+++ b/drivers/usb/gadget/function/f_fs.c
@@ -3435,6 +3435,7 @@ done:
3435static void ffs_closed(struct ffs_data *ffs) 3435static void ffs_closed(struct ffs_data *ffs)
3436{ 3436{
3437 struct ffs_dev *ffs_obj; 3437 struct ffs_dev *ffs_obj;
3438 struct f_fs_opts *opts;
3438 3439
3439 ENTER(); 3440 ENTER();
3440 ffs_dev_lock(); 3441 ffs_dev_lock();
@@ -3449,8 +3450,13 @@ static void ffs_closed(struct ffs_data *ffs)
3449 ffs_obj->ffs_closed_callback) 3450 ffs_obj->ffs_closed_callback)
3450 ffs_obj->ffs_closed_callback(ffs); 3451 ffs_obj->ffs_closed_callback(ffs);
3451 3452
3452 if (!ffs_obj->opts || ffs_obj->opts->no_configfs 3453 if (ffs_obj->opts)
3453 || !ffs_obj->opts->func_inst.group.cg_item.ci_parent) 3454 opts = ffs_obj->opts;
3455 else
3456 goto done;
3457
3458 if (opts->no_configfs || !opts->func_inst.group.cg_item.ci_parent
3459 || !atomic_read(&opts->func_inst.group.cg_item.ci_kref.refcount))
3454 goto done; 3460 goto done;
3455 3461
3456 unregister_gadget_item(ffs_obj->opts-> 3462 unregister_gadget_item(ffs_obj->opts->