mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-28 06:34:12 +08:00
platform-drivers-x86 for v6.11-7
Fixes: - asus-wmi: Disable OOBE that interferes with backlight control - panasonic-laptop: Two fixes to SINF array handling The following is an automated shortlog grouped by driver: asus-wmi: - Disable OOBE experience on Zenbook S 16 panasonic-laptop: - Allocate 1 entry extra in the sinf array - Fix SINF array out of bounds accesses -----BEGIN PGP SIGNATURE----- iHUEABYIAB0WIQSCSUwRdwTNL2MhaBlZrE9hU+XOMQUCZuKxBgAKCRBZrE9hU+XO MZWtAP9CFIg02ZzY8ZadQMhV3CmOfojLp9S8mYN9BS91iO9eYwD/deECQ1hG+UHp wRjs+8BA9jUtWT3iLyFcA2ZnAdZPCwA= =rCeo -----END PGP SIGNATURE----- Merge tag 'platform-drivers-x86-v6.11-7' of git://git.kernel.org/pub/scm/linux/kernel/git/pdx86/platform-drivers-x86 Pull x86 platform driver fixes from Ilpo Järvinen: - asus-wmi: Disable OOBE that interferes with backlight control - panasonic-laptop: Two fixes to SINF array handling * tag 'platform-drivers-x86-v6.11-7' of git://git.kernel.org/pub/scm/linux/kernel/git/pdx86/platform-drivers-x86: platform/x86: asus-wmi: Disable OOBE experience on Zenbook S 16 platform/x86: panasonic-laptop: Allocate 1 entry extra in the sinf array platform/x86: panasonic-laptop: Fix SINF array out of bounds accesses
This commit is contained in:
commit
42c5b51949
@ -1793,6 +1793,16 @@ static int asus_wmi_led_init(struct asus_wmi *asus)
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (asus_wmi_dev_is_present(asus, ASUS_WMI_DEVID_OOBE)) {
|
||||
/*
|
||||
* Disable OOBE state, so that e.g. the keyboard backlight
|
||||
* works.
|
||||
*/
|
||||
rv = asus_wmi_set_devstate(ASUS_WMI_DEVID_OOBE, 1, NULL);
|
||||
if (rv)
|
||||
goto error;
|
||||
}
|
||||
|
||||
error:
|
||||
if (rv)
|
||||
asus_wmi_led_exit(asus);
|
||||
|
@ -337,7 +337,8 @@ static int acpi_pcc_retrieve_biosdata(struct pcc_acpi *pcc)
|
||||
}
|
||||
|
||||
if (pcc->num_sifr < hkey->package.count) {
|
||||
pr_err("SQTY reports bad SINF length\n");
|
||||
pr_err("SQTY reports bad SINF length SQTY: %lu SINF-pkg-count: %u\n",
|
||||
pcc->num_sifr, hkey->package.count);
|
||||
status = AE_ERROR;
|
||||
goto end;
|
||||
}
|
||||
@ -773,6 +774,24 @@ static DEVICE_ATTR_RW(dc_brightness);
|
||||
static DEVICE_ATTR_RW(current_brightness);
|
||||
static DEVICE_ATTR_RW(cdpower);
|
||||
|
||||
static umode_t pcc_sysfs_is_visible(struct kobject *kobj, struct attribute *attr, int idx)
|
||||
{
|
||||
struct device *dev = kobj_to_dev(kobj);
|
||||
struct acpi_device *acpi = to_acpi_device(dev);
|
||||
struct pcc_acpi *pcc = acpi_driver_data(acpi);
|
||||
|
||||
if (attr == &dev_attr_mute.attr)
|
||||
return (pcc->num_sifr > SINF_MUTE) ? attr->mode : 0;
|
||||
|
||||
if (attr == &dev_attr_eco_mode.attr)
|
||||
return (pcc->num_sifr > SINF_ECO_MODE) ? attr->mode : 0;
|
||||
|
||||
if (attr == &dev_attr_current_brightness.attr)
|
||||
return (pcc->num_sifr > SINF_CUR_BRIGHT) ? attr->mode : 0;
|
||||
|
||||
return attr->mode;
|
||||
}
|
||||
|
||||
static struct attribute *pcc_sysfs_entries[] = {
|
||||
&dev_attr_numbatt.attr,
|
||||
&dev_attr_lcdtype.attr,
|
||||
@ -787,8 +806,9 @@ static struct attribute *pcc_sysfs_entries[] = {
|
||||
};
|
||||
|
||||
static const struct attribute_group pcc_attr_group = {
|
||||
.name = NULL, /* put in device directory */
|
||||
.attrs = pcc_sysfs_entries,
|
||||
.name = NULL, /* put in device directory */
|
||||
.attrs = pcc_sysfs_entries,
|
||||
.is_visible = pcc_sysfs_is_visible,
|
||||
};
|
||||
|
||||
|
||||
@ -941,12 +961,15 @@ static int acpi_pcc_hotkey_resume(struct device *dev)
|
||||
if (!pcc)
|
||||
return -EINVAL;
|
||||
|
||||
acpi_pcc_write_sset(pcc, SINF_MUTE, pcc->mute);
|
||||
acpi_pcc_write_sset(pcc, SINF_ECO_MODE, pcc->eco_mode);
|
||||
if (pcc->num_sifr > SINF_MUTE)
|
||||
acpi_pcc_write_sset(pcc, SINF_MUTE, pcc->mute);
|
||||
if (pcc->num_sifr > SINF_ECO_MODE)
|
||||
acpi_pcc_write_sset(pcc, SINF_ECO_MODE, pcc->eco_mode);
|
||||
acpi_pcc_write_sset(pcc, SINF_STICKY_KEY, pcc->sticky_key);
|
||||
acpi_pcc_write_sset(pcc, SINF_AC_CUR_BRIGHT, pcc->ac_brightness);
|
||||
acpi_pcc_write_sset(pcc, SINF_DC_CUR_BRIGHT, pcc->dc_brightness);
|
||||
acpi_pcc_write_sset(pcc, SINF_CUR_BRIGHT, pcc->current_brightness);
|
||||
if (pcc->num_sifr > SINF_CUR_BRIGHT)
|
||||
acpi_pcc_write_sset(pcc, SINF_CUR_BRIGHT, pcc->current_brightness);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -963,11 +986,21 @@ static int acpi_pcc_hotkey_add(struct acpi_device *device)
|
||||
|
||||
num_sifr = acpi_pcc_get_sqty(device);
|
||||
|
||||
if (num_sifr < 0 || num_sifr > 255) {
|
||||
pr_err("num_sifr out of range");
|
||||
/*
|
||||
* pcc->sinf is expected to at least have the AC+DC brightness entries.
|
||||
* Accesses to higher SINF entries are checked against num_sifr.
|
||||
*/
|
||||
if (num_sifr <= SINF_DC_CUR_BRIGHT || num_sifr > 255) {
|
||||
pr_err("num_sifr %d out of range %d - 255\n", num_sifr, SINF_DC_CUR_BRIGHT + 1);
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
/*
|
||||
* Some DSDT-s have an off-by-one bug where the SINF package count is
|
||||
* one higher than the SQTY reported value, allocate 1 entry extra.
|
||||
*/
|
||||
num_sifr++;
|
||||
|
||||
pcc = kzalloc(sizeof(struct pcc_acpi), GFP_KERNEL);
|
||||
if (!pcc) {
|
||||
pr_err("Couldn't allocate mem for pcc");
|
||||
@ -1020,11 +1053,14 @@ static int acpi_pcc_hotkey_add(struct acpi_device *device)
|
||||
acpi_pcc_write_sset(pcc, SINF_STICKY_KEY, 0);
|
||||
pcc->sticky_key = 0;
|
||||
|
||||
pcc->eco_mode = pcc->sinf[SINF_ECO_MODE];
|
||||
pcc->mute = pcc->sinf[SINF_MUTE];
|
||||
pcc->ac_brightness = pcc->sinf[SINF_AC_CUR_BRIGHT];
|
||||
pcc->dc_brightness = pcc->sinf[SINF_DC_CUR_BRIGHT];
|
||||
pcc->current_brightness = pcc->sinf[SINF_CUR_BRIGHT];
|
||||
if (pcc->num_sifr > SINF_MUTE)
|
||||
pcc->mute = pcc->sinf[SINF_MUTE];
|
||||
if (pcc->num_sifr > SINF_ECO_MODE)
|
||||
pcc->eco_mode = pcc->sinf[SINF_ECO_MODE];
|
||||
if (pcc->num_sifr > SINF_CUR_BRIGHT)
|
||||
pcc->current_brightness = pcc->sinf[SINF_CUR_BRIGHT];
|
||||
|
||||
/* add sysfs attributes */
|
||||
result = sysfs_create_group(&device->dev.kobj, &pcc_attr_group);
|
||||
|
@ -62,6 +62,7 @@
|
||||
#define ASUS_WMI_DEVID_KBD_BACKLIGHT 0x00050021
|
||||
#define ASUS_WMI_DEVID_LIGHT_SENSOR 0x00050022 /* ?? */
|
||||
#define ASUS_WMI_DEVID_LIGHTBAR 0x00050025
|
||||
#define ASUS_WMI_DEVID_OOBE 0x0005002F
|
||||
/* This can only be used to disable the screen, not re-enable */
|
||||
#define ASUS_WMI_DEVID_SCREENPAD_POWER 0x00050031
|
||||
/* Writing a brightness re-enables the screen if disabled */
|
||||
|
Loading…
Reference in New Issue
Block a user