]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
platform/x86: think-lmi: Allow empty admin password
authorMark Pearson <mpearson-lenovo@squebb.ca>
Thu, 24 Oct 2024 19:55:23 +0000 (15:55 -0400)
committerIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Tue, 29 Oct 2024 11:54:32 +0000 (13:54 +0200)
SVP = BIOS Supervisor/Admin password
SMP = BIOS System password

If SMP ACL is enabled in the BIOS then the system allows you to set the
SMP without a SVP password configured. Change code to allow this.
BIOS will return permissions error if SVP is required.

Signed-off-by: Mark Pearson <mpearson-lenovo@squebb.ca>
Link: https://lore.kernel.org/r/20241024195536.6992-3-mpearson-lenovo@squebb.ca
Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
drivers/platform/x86/think-lmi.c

index 46ab82fb2898913b81bf3c532d8108af4c5a7455..c316b1b592d610af6a0fc7805a9cd1a3c064a473 100644 (file)
@@ -469,7 +469,12 @@ static ssize_t new_password_store(struct kobject *kobj,
                if (ret)
                        goto out;
 
-               if (tlmi_priv.pwd_admin->pwd_enabled) {
+               /*
+                * Note admin password is not always required if SMPControl enabled in BIOS,
+                * So only set if it's configured.
+                * Let BIOS figure it out - we'll get an error if operation is not permitted
+                */
+               if (tlmi_priv.pwd_admin->pwd_enabled && strlen(tlmi_priv.pwd_admin->password)) {
                        ret = tlmi_opcode_setting("WmiOpcodePasswordAdmin",
                                        tlmi_priv.pwd_admin->password);
                        if (ret)