media: usb: go7007: s2250-board: fix leak in probe()
authorDan Carpenter <dan.carpenter@oracle.com>
Wed, 2 Feb 2022 17:52:01 +0000 (20:52 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 8 Apr 2022 12:23:17 +0000 (14:23 +0200)
[ Upstream commit 67e4550ecd6164bfbdff54c169e5bbf9ccfaf14d ]

Call i2c_unregister_device(audio) on this error path.

Fixes: d3b2ccd9e307 ("[media] s2250: convert to the control framework")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/media/usb/go7007/s2250-board.c

index c742cc88fac5ca8cb30fcdd1c1c3f82e7e341d66..1fa6f10ee157bb839d1c298a70c5027e1032950c 100644 (file)
@@ -504,6 +504,7 @@ static int s2250_probe(struct i2c_client *client,
        u8 *data;
        struct go7007 *go = i2c_get_adapdata(adapter);
        struct go7007_usb *usb = go->hpi_context;
+       int err = -EIO;
 
        audio = i2c_new_dummy_device(adapter, TLV320_ADDRESS >> 1);
        if (IS_ERR(audio))
@@ -532,11 +533,8 @@ static int s2250_probe(struct i2c_client *client,
                V4L2_CID_HUE, -512, 511, 1, 0);
        sd->ctrl_handler = &state->hdl;
        if (state->hdl.error) {
-               int err = state->hdl.error;
-
-               v4l2_ctrl_handler_free(&state->hdl);
-               kfree(state);
-               return err;
+               err = state->hdl.error;
+               goto fail;
        }
 
        state->std = V4L2_STD_NTSC;
@@ -600,7 +598,7 @@ fail:
        i2c_unregister_device(audio);
        v4l2_ctrl_handler_free(&state->hdl);
        kfree(state);
-       return -EIO;
+       return err;
 }
 
 static int s2250_remove(struct i2c_client *client)