From: Sergey Yanovich <ynvich@xxxxxxxxx> Sony laptops have a single hardware rfkill switch, which controls several wireless devices: wifi, bluetooth, wwan. The code to selectively control bluetooth and wwan is already present. This patch adds handling of wifi. Signed-off-by: Sergey Yanovich <ynvich@xxxxxxxxx> Signed-off-by: Mattia Dongili <malattia@xxxxxxxx> --- drivers/misc/sony-laptop.c | 41 +++++++++++++++++++++++++++++++++++++++++ 1 files changed, 41 insertions(+), 0 deletions(-) diff --git a/drivers/misc/sony-laptop.c b/drivers/misc/sony-laptop.c index 31f84ce..77fe584 100644 --- a/drivers/misc/sony-laptop.c +++ b/drivers/misc/sony-laptop.c @@ -1241,6 +1241,7 @@ struct sony_pic_dev { u8 camera_power; u8 bluetooth_power; u8 wwan_power; + u8 wifi_power; }; static struct sony_pic_dev spic_dev = { @@ -1806,6 +1807,44 @@ static ssize_t sony_pic_wwanpower_show(struct device *dev, return count; } +/* wifi power (TX series) */ +static void sony_pic_set_wifipower(u8 state) +{ + state = !!state; + mutex_lock(&spic_dev.lock); + if (spic_dev.wifi_power == state) { + mutex_unlock(&spic_dev.lock); + return; + } + sony_pic_call2(0x98, -state); + sony_pic_call1(0x82); + spic_dev.wifi_power = state; + mutex_unlock(&spic_dev.lock); +} + +static ssize_t sony_pic_wifipower_store(struct device *dev, + struct device_attribute *attr, + const char *buffer, size_t count) +{ + unsigned long value; + if (strict_strtoul(buffer, 10, &value)) + return -EINVAL; + + sony_pic_set_wifipower(value); + + return count; +} + +static ssize_t sony_pic_wifipower_show(struct device *dev, + struct device_attribute *attr, char *buffer) +{ + ssize_t count; + mutex_lock(&spic_dev.lock); + count = snprintf(buffer, PAGE_SIZE, "%d\n", spic_dev.wifi_power); + mutex_unlock(&spic_dev.lock); + return count; +} + /* bluetooth subsystem power state */ static void __sony_pic_set_bluetoothpower(u8 state) { @@ -1888,11 +1927,13 @@ struct device_attribute spic_attr_##_name = __ATTR(_name, \ static SPIC_ATTR(bluetoothpower, 0644); static SPIC_ATTR(wwanpower, 0644); +static SPIC_ATTR(wifipower, 0644); static SPIC_ATTR(fanspeed, 0644); static struct attribute *spic_attributes[] = { &spic_attr_bluetoothpower.attr, &spic_attr_wwanpower.attr, + &spic_attr_wifipower.attr, &spic_attr_fanspeed.attr, NULL }; -- 1.5.6.5 -- To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html