diff options
Diffstat (limited to 'ots_pat9126/pat9126.c')
-rw-r--r-- | ots_pat9126/pat9126.c | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/ots_pat9126/pat9126.c b/ots_pat9126/pat9126.c index a0e7c35..996e098 100644 --- a/ots_pat9126/pat9126.c +++ b/ots_pat9126/pat9126.c @@ -535,6 +535,50 @@ static ssize_t pat9126_sleep_level_store(struct device *dev, return count; } +static ssize_t pat9126_pd_store(struct device *dev, + struct device_attribute *attr, + const char *buf, + size_t count) { + u8 config, tmp; + + struct pixart_pat9126_data *data = + (struct pixart_pat9126_data *) dev_get_drvdata(dev); + struct i2c_client *client = data->client; + + pat9126_read(client, PIXART_PAT9126_CONFIG_REG, &config); + config &= ~POWER_DOWN_ENABLE_BIT; + + if (!kstrtou8(buf, 0, &tmp)) { + if (tmp) { + config |= POWER_DOWN_ENABLE_BIT; + } + + dev_dbg(dev, "power down: %d\n", (tmp ? 1 : 0)); + pat9126_write(client, PIXART_PAT9126_CONFIG_REG, config); + } else { + dev_warn(dev, "failed to parse sysfs arg: '%s'\n", buf); + } + + return count; +} + +static ssize_t pat9126_pd_show(struct device *dev, + struct device_attribute *attr, + char *buf) { + int count = 0; + uint8_t tmp; + + struct pixart_pat9126_data *data = + (struct pixart_pat9126_data *) dev_get_drvdata(dev); + struct i2c_client *client = data->client; + + pat9126_read(client, PIXART_PAT9126_CONFIG_REG, &tmp); + tmp = ((POWER_DOWN_ENABLE_BIT & tmp) ? 1 : 0); + count += sprintf(buf, "0x%x\n", tmp); + + return count; +} + static DEVICE_ATTR (crown_sensitivity, S_IRUGO | S_IWUSR | S_IWGRP, pat9126_sensitivity_show, pat9126_sensitivity_store); @@ -547,11 +591,15 @@ static DEVICE_ATTR static DEVICE_ATTR (sleep_level, S_IWUSR | S_IWGRP, NULL, pat9126_sleep_level_store); +static DEVICE_ATTR + (pd, S_IRUGO | S_IWUSR | S_IWGRP, pat9126_pd_show, pat9126_pd_store); + static struct attribute *pat9126_attr_list[] = { &dev_attr_crown_sensitivity.attr, &dev_attr_id.attr, &dev_attr_max_sleep_level.attr, &dev_attr_sleep_level.attr, + &dev_attr_pd.attr, NULL, }; |