Commit 6f7d0f5f authored by Mark Pearson's avatar Mark Pearson Committed by Hans de Goede

platform/x86: think-lmi: Fix password opcode ordering for workstations

The Lenovo workstations require the password opcode to be run before
the attribute value is changed (if Admin password is enabled).

Tested on some Thinkpads to confirm they are OK with this order too.
Signed-off-by: default avatarMark Pearson <mpearson-lenovo@squebb.ca>
Fixes: 640a5fa5 ("platform/x86: think-lmi: Opcode support")
Reviewed-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Link: https://lore.kernel.org/r/20240209152359.528919-1-mpearson-lenovo@squebb.caReviewed-by: default avatarHans de Goede <hdegoede@redhat.com>
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
parent 1abdf288
...@@ -1009,7 +1009,16 @@ static ssize_t current_value_store(struct kobject *kobj, ...@@ -1009,7 +1009,16 @@ static ssize_t current_value_store(struct kobject *kobj,
* Note - this sets the variable and then the password as separate * Note - this sets the variable and then the password as separate
* WMI calls. Function tlmi_save_bios_settings will error if the * WMI calls. Function tlmi_save_bios_settings will error if the
* password is incorrect. * password is incorrect.
* Workstation's require the opcode to be set before changing the
* attribute.
*/ */
if (tlmi_priv.pwd_admin->valid && tlmi_priv.pwd_admin->password[0]) {
ret = tlmi_opcode_setting("WmiOpcodePasswordAdmin",
tlmi_priv.pwd_admin->password);
if (ret)
goto out;
}
set_str = kasprintf(GFP_KERNEL, "%s,%s;", setting->display_name, set_str = kasprintf(GFP_KERNEL, "%s,%s;", setting->display_name,
new_setting); new_setting);
if (!set_str) { if (!set_str) {
...@@ -1021,17 +1030,10 @@ static ssize_t current_value_store(struct kobject *kobj, ...@@ -1021,17 +1030,10 @@ static ssize_t current_value_store(struct kobject *kobj,
if (ret) if (ret)
goto out; goto out;
if (tlmi_priv.save_mode == TLMI_SAVE_BULK) { if (tlmi_priv.save_mode == TLMI_SAVE_BULK)
tlmi_priv.save_required = true; tlmi_priv.save_required = true;
} else { else
if (tlmi_priv.pwd_admin->valid && tlmi_priv.pwd_admin->password[0]) {
ret = tlmi_opcode_setting("WmiOpcodePasswordAdmin",
tlmi_priv.pwd_admin->password);
if (ret)
goto out;
}
ret = tlmi_save_bios_settings(""); ret = tlmi_save_bios_settings("");
}
} else { /* old non-opcode based authentication method (deprecated) */ } else { /* old non-opcode based authentication method (deprecated) */
if (tlmi_priv.pwd_admin->valid && tlmi_priv.pwd_admin->password[0]) { if (tlmi_priv.pwd_admin->valid && tlmi_priv.pwd_admin->password[0]) {
auth_str = kasprintf(GFP_KERNEL, "%s,%s,%s;", auth_str = kasprintf(GFP_KERNEL, "%s,%s,%s;",
......
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