Commit 527376c8 authored by Darren Hart (VMware)'s avatar Darren Hart (VMware)
Browse files

platform/x86: hp-wmi: Cleanup exit paths



Several exit paths were more complex than they needed to be. Remove
superfluous conditionals, use labels common cleanup, do not shadow
negative error codes.

Signed-off-by: default avatarDarren Hart (VMware) <dvhart@infradead.org>
Tested-by: default avatarCarlo Caione <carlo@endlessm.com>
Reviewed-by: default avatarAndy Shevchenko <andy.shevchenko@gmail.com>
parent a055f9ec
Loading
Loading
Loading
Loading
+33 −30
Original line number Original line Diff line number Diff line
@@ -223,7 +223,7 @@ static int hp_wmi_perform_query(int query, enum hp_wmi_command command,
	};
	};
	struct acpi_buffer input = { sizeof(struct bios_args), &args };
	struct acpi_buffer input = { sizeof(struct bios_args), &args };
	struct acpi_buffer output = { ACPI_ALLOCATE_BUFFER, NULL };
	struct acpi_buffer output = { ACPI_ALLOCATE_BUFFER, NULL };
	u32 rc;
	int ret = 0;


	if (WARN_ON(insize > sizeof(args.data)))
	if (WARN_ON(insize > sizeof(args.data)))
		return -EINVAL;
		return -EINVAL;
@@ -235,32 +235,32 @@ static int hp_wmi_perform_query(int query, enum hp_wmi_command command,


	if (!obj)
	if (!obj)
		return -EINVAL;
		return -EINVAL;
	else if (obj->type != ACPI_TYPE_BUFFER) {

		kfree(obj);
	if (obj->type != ACPI_TYPE_BUFFER) {
		return -EINVAL;
		ret = -EINVAL;
		goto out_free;
	}
	}


	bios_return = (struct bios_return *)obj->buffer.pointer;
	bios_return = (struct bios_return *)obj->buffer.pointer;
	rc = bios_return->return_code;
	ret = bios_return->return_code;


	if (rc) {
	if (ret) {
		if (rc != HPWMI_RET_UNKNOWN_CMDTYPE)
		if (ret != HPWMI_RET_UNKNOWN_CMDTYPE)
			pr_warn("query 0x%x returned error 0x%x\n", query, rc);
			pr_warn("query 0x%x returned error 0x%x\n", query, ret);
		kfree(obj);
		goto out_free;
		return rc;
	}
	}


	if (!outsize) {
	/* Ignore output data of zero size */
		/* ignore output data */
	if (!outsize)
		kfree(obj);
		goto out_free;
		return 0;
	}


	actual_outsize = min(outsize, (int)(obj->buffer.length - sizeof(*bios_return)));
	actual_outsize = min(outsize, (int)(obj->buffer.length - sizeof(*bios_return)));
	memcpy(buffer, obj->buffer.pointer + sizeof(*bios_return), actual_outsize);
	memcpy(buffer, obj->buffer.pointer + sizeof(*bios_return), actual_outsize);
	memset(buffer + actual_outsize, 0, outsize - actual_outsize);
	memset(buffer + actual_outsize, 0, outsize - actual_outsize);

out_free:
	kfree(obj);
	kfree(obj);
	return 0;
	return ret;
}
}


static int hp_wmi_read_int(int query)
static int hp_wmi_read_int(int query)
@@ -313,9 +313,8 @@ static int __init hp_wmi_enable_hotkeys(void)
	int value = 0x6e;
	int value = 0x6e;
	int ret = hp_wmi_perform_query(HPWMI_BIOS_QUERY, HPWMI_WRITE, &value,
	int ret = hp_wmi_perform_query(HPWMI_BIOS_QUERY, HPWMI_WRITE, &value,
				       sizeof(value), 0);
				       sizeof(value), 0);
	if (ret)

		return ret < 0 ? ret : -EINVAL;
	return ret <= 0 ? ret : -EINVAL;
	return 0;
}
}


static int hp_wmi_set_block(void *data, bool blocked)
static int hp_wmi_set_block(void *data, bool blocked)
@@ -326,9 +325,8 @@ static int hp_wmi_set_block(void *data, bool blocked)


	ret = hp_wmi_perform_query(HPWMI_WIRELESS_QUERY, HPWMI_WRITE,
	ret = hp_wmi_perform_query(HPWMI_WIRELESS_QUERY, HPWMI_WRITE,
				   &query, sizeof(query), 0);
				   &query, sizeof(query), 0);
	if (ret)

		return ret < 0 ? ret : -EINVAL;
	return ret <= 0 ? ret : -EINVAL;
	return 0;
}
}


static const struct rfkill_ops hp_wmi_rfkill_ops = {
static const struct rfkill_ops hp_wmi_rfkill_ops = {
@@ -363,11 +361,12 @@ static int hp_wmi_rfkill2_set_block(void *data, bool blocked)
{
{
	int rfkill_id = (int)(long)data;
	int rfkill_id = (int)(long)data;
	char buffer[4] = { 0x01, 0x00, rfkill_id, !blocked };
	char buffer[4] = { 0x01, 0x00, rfkill_id, !blocked };
	int ret;


	if (hp_wmi_perform_query(HPWMI_WIRELESS2_QUERY, HPWMI_WRITE,
	ret = hp_wmi_perform_query(HPWMI_WIRELESS2_QUERY, HPWMI_WRITE,
				   buffer, sizeof(buffer), 0))
				   buffer, sizeof(buffer), 0);
		return -EINVAL;

	return 0;
	return ret <= 0 ? ret : -EINVAL;
}
}


static const struct rfkill_ops hp_wmi_rfkill2_ops = {
static const struct rfkill_ops hp_wmi_rfkill2_ops = {
@@ -478,13 +477,17 @@ static ssize_t postcode_store(struct device *dev, struct device_attribute *attr,
	u32 tmp;
	u32 tmp;


	ret = kstrtoul(buf, 10, &tmp2);
	ret = kstrtoul(buf, 10, &tmp2);
	if (ret || tmp2 != 1)
	if (!ret && tmp2 != 1)
		return -EINVAL;
		ret = -EINVAL;
	if (ret)
		goto out;


	/* Clear the POST error code. It is kept until until cleared. */
	/* Clear the POST error code. It is kept until until cleared. */
	tmp = (u32) tmp2;
	tmp = (u32) tmp2;
	ret = hp_wmi_perform_query(HPWMI_POSTCODEERROR_QUERY, HPWMI_WRITE, &tmp,
	ret = hp_wmi_perform_query(HPWMI_POSTCODEERROR_QUERY, HPWMI_WRITE, &tmp,
				       sizeof(tmp), sizeof(tmp));
				       sizeof(tmp), sizeof(tmp));

out:
	if (ret)
	if (ret)
		return ret < 0 ? ret : -EINVAL;
		return ret < 0 ? ret : -EINVAL;


@@ -689,7 +692,7 @@ static int __init hp_wmi_rfkill_setup(struct platform_device *device)
	int err, wireless;
	int err, wireless;


	wireless = hp_wmi_read_int(HPWMI_WIRELESS_QUERY);
	wireless = hp_wmi_read_int(HPWMI_WIRELESS_QUERY);
	if (wireless)
	if (wireless < 0)
		return wireless;
		return wireless;


	err = hp_wmi_perform_query(HPWMI_WIRELESS_QUERY, HPWMI_WRITE, &wireless,
	err = hp_wmi_perform_query(HPWMI_WIRELESS_QUERY, HPWMI_WRITE, &wireless,
@@ -775,7 +778,7 @@ static int __init hp_wmi_rfkill2_setup(struct platform_device *device)
	err = hp_wmi_perform_query(HPWMI_WIRELESS2_QUERY, HPWMI_READ, &state,
	err = hp_wmi_perform_query(HPWMI_WIRELESS2_QUERY, HPWMI_READ, &state,
				   0, sizeof(state));
				   0, sizeof(state));
	if (err)
	if (err)
		return err;
		return err < 0 ? err : -EINVAL;


	if (state.count > HPWMI_MAX_RFKILL2_DEVICES) {
	if (state.count > HPWMI_MAX_RFKILL2_DEVICES) {
		pr_warn("unable to parse 0x1b query output\n");
		pr_warn("unable to parse 0x1b query output\n");