Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 131a8a9a authored by Frank Praznik's avatar Frank Praznik Committed by Jiri Kosina
Browse files

HID: sony: Prevent the freeing of an unitialized ida value



sony_allocate_output_report() was being called before sony_set_device_id()
which meant that an unallocated ida value was was freed if the output
report allocation failed and the probe function jumped to err_stop.

Do the device ID allocation before the output report allocation to avoid
freeing an unallocated value in case of a failure.

Signed-off-by: default avatarFrank Praznik <frank.praznik@oh.rr.com>
Acked-by: default avatarPavel Machek <pavel@ucw.cz>
Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
parent 8de29a35
Loading
Loading
Loading
Loading
+4 −4
Original line number Diff line number Diff line
@@ -1993,15 +1993,15 @@ static int sony_probe(struct hid_device *hdev, const struct hid_device_id *id)
		return ret;
	}

	ret = sony_allocate_output_report(sc);
	ret = sony_set_device_id(sc);
	if (ret < 0) {
		hid_err(hdev, "failed to allocate the output report buffer\n");
		hid_err(hdev, "failed to allocate the device id\n");
		goto err_stop;
	}

	ret = sony_set_device_id(sc);
	ret = sony_allocate_output_report(sc);
	if (ret < 0) {
		hid_err(hdev, "failed to allocate the device id\n");
		hid_err(hdev, "failed to allocate the output report buffer\n");
		goto err_stop;
	}