Commit 9af0e0fb authored by Anssi Hannula's avatar Anssi Hannula Committed by Matthew Garrett

hp-wmi: check query return value in hp_wmi_perform_query

Check BIOS provided return value code in hp_wmi_perform_query and print
a warning on error. Printing is suppressed for HPWMI_RET_UNKNOWN_CMDTYPE
which is returned when the command type is unsupported.
Signed-off-by: default avatarAnssi Hannula <anssi.hannula@iki.fi>
Signed-off-by: default avatarMatthew Garrett <mjg@redhat.com>
parent 7751ab8e
...@@ -89,6 +89,13 @@ struct bios_return { ...@@ -89,6 +89,13 @@ struct bios_return {
u32 value; u32 value;
}; };
enum hp_return_value {
HPWMI_RET_WRONG_SIGNATURE = 0x02,
HPWMI_RET_UNKNOWN_COMMAND = 0x03,
HPWMI_RET_UNKNOWN_CMDTYPE = 0x04,
HPWMI_RET_INVALID_PARAMETERS = 0x05,
};
static const struct key_entry hp_wmi_keymap[] = { static const struct key_entry hp_wmi_keymap[] = {
{ KE_KEY, 0x02, { KEY_BRIGHTNESSUP } }, { KE_KEY, 0x02, { KEY_BRIGHTNESSUP } },
{ KE_KEY, 0x03, { KEY_BRIGHTNESSDOWN } }, { KE_KEY, 0x03, { KEY_BRIGHTNESSDOWN } },
...@@ -171,6 +178,15 @@ static int hp_wmi_perform_query(int query, int write, u32 *buffer, ...@@ -171,6 +178,15 @@ static int hp_wmi_perform_query(int query, int write, u32 *buffer,
bios_return = *((struct bios_return *)obj->buffer.pointer); bios_return = *((struct bios_return *)obj->buffer.pointer);
if (bios_return.return_code) {
if (bios_return.return_code != HPWMI_RET_UNKNOWN_CMDTYPE)
printk(KERN_WARNING PREFIX "query 0x%x returned "
"error 0x%x\n",
query, bios_return.return_code);
kfree(obj);
return bios_return.return_code;
}
memcpy(buffer, &bios_return.value, sizeof(bios_return.value)); memcpy(buffer, &bios_return.value, sizeof(bios_return.value));
kfree(obj); kfree(obj);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment