Linux 6.13
[linux.git] / drivers / platform / x86 / think-lmi.h
blobf267d8b46957e6bdc75e534e5fd18c94e6379208
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
3 #ifndef _THINK_LMI_H_
4 #define _THINK_LMI_H_
6 #include <linux/types.h>
8 #define TLMI_SETTINGS_COUNT 256
9 #define TLMI_SETTINGS_MAXLEN 512
10 #define TLMI_PWD_BUFSIZE 129
11 #define TLMI_LANG_MAXLEN 4
12 #define TLMI_INDEX_MAX 32
14 /* Possible error values */
15 struct tlmi_err_codes {
16 const char *err_str;
17 int err_code;
20 enum encoding_option {
21 TLMI_ENCODING_ASCII,
22 TLMI_ENCODING_SCANCODE,
25 enum level_option {
26 TLMI_LEVEL_USER,
27 TLMI_LEVEL_MASTER,
31 * There are a limit on the number of WMI operations you can do if you use
32 * the default implementation of saving on every set. This is due to a
33 * limitation in EFI variable space used.
34 * Have a 'bulk save' mode where you can manually trigger the save, and can
35 * therefore set unlimited variables - for users that need it.
37 enum save_mode {
38 TLMI_SAVE_SINGLE,
39 TLMI_SAVE_BULK,
40 TLMI_SAVE_SAVE,
43 /* password configuration details */
44 #define TLMI_PWDCFG_MODE_LEGACY 0
45 #define TLMI_PWDCFG_MODE_PASSWORD 1
46 #define TLMI_PWDCFG_MODE_MULTICERT 3
48 struct tlmi_pwdcfg_core {
49 uint32_t password_mode;
50 uint32_t password_state;
51 uint32_t min_length;
52 uint32_t max_length;
53 uint32_t supported_encodings;
54 uint32_t supported_keyboard;
57 struct tlmi_pwdcfg_ext {
58 uint32_t hdd_user_password;
59 uint32_t hdd_master_password;
60 uint32_t nvme_user_password;
61 uint32_t nvme_master_password;
64 struct tlmi_pwdcfg {
65 struct tlmi_pwdcfg_core core;
66 struct tlmi_pwdcfg_ext ext;
69 /* password setting details */
70 struct tlmi_pwd_setting {
71 struct kobject kobj;
72 bool pwd_enabled;
73 char password[TLMI_PWD_BUFSIZE];
74 const char *pwd_type;
75 const char *role;
76 int minlen;
77 int maxlen;
78 enum encoding_option encoding;
79 char kbdlang[TLMI_LANG_MAXLEN];
80 int index; /*Used for HDD and NVME auth */
81 enum level_option level;
82 bool cert_installed;
83 char *signature;
84 char *save_signature;
87 /* Attribute setting details */
88 struct tlmi_attr_setting {
89 struct kobject kobj;
90 int index;
91 char display_name[TLMI_SETTINGS_MAXLEN];
92 char *possible_values;
95 struct think_lmi {
96 struct wmi_device *wmi_device;
98 bool can_set_bios_settings;
99 bool can_get_bios_selections;
100 bool can_set_bios_password;
101 bool can_get_password_settings;
102 bool pending_changes;
103 bool can_debug_cmd;
104 bool opcode_support;
105 bool certificate_support;
106 enum save_mode save_mode;
107 bool save_required;
108 bool reboot_required;
110 struct tlmi_attr_setting *setting[TLMI_SETTINGS_COUNT];
111 struct device *class_dev;
112 struct kset *attribute_kset;
113 struct kset *authentication_kset;
115 struct tlmi_pwdcfg pwdcfg;
116 struct tlmi_pwd_setting *pwd_admin;
117 struct tlmi_pwd_setting *pwd_power;
118 struct tlmi_pwd_setting *pwd_system;
119 struct tlmi_pwd_setting *pwd_hdd;
120 struct tlmi_pwd_setting *pwd_nvme;
123 #endif /* !_THINK_LMI_H_ */