diff options
| author | Rui Miguel Silva <rui.silva@linaro.org> | 2015-05-20 09:52:40 -0400 |
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2015-07-10 12:49:33 -0400 |
| commit | 1e4205d4e0b0579b906de8ec7c5920968bfb32a9 (patch) | |
| tree | 08718c752e98012a4508806188796bcd8ddb2cf9 /drivers/usb/gadget/function | |
| parent | bfa06e6258be556d44aad030fe1babeed4f92240 (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.c | 10 |
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: | |||
| 3435 | static void ffs_closed(struct ffs_data *ffs) | 3435 | static 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-> |
