Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 363039
b: refs/heads/master
c: 84d19d9
h: refs/heads/master
i:
  363037: 4e4f123
  363035: 66c01b6
  363031: 3be4e9b
  363023: e0cbdaa
  363007: 3ef5e26
v: v3
  • Loading branch information
Guenter Roeck committed Apr 8, 2013
1 parent 6b833e1 commit 6599a4d
Show file tree
Hide file tree
Showing 2 changed files with 87 additions and 1 deletion.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 47ece9645f288d46420d64dab90a182bde87bbbb
refs/heads/master: 84d19d92f78e10f8bdc1b3e1b5ddcaf5895edaf7
86 changes: 86 additions & 0 deletions trunk/drivers/hwmon/nct6775.c
Original file line number Diff line number Diff line change
Expand Up @@ -511,6 +511,12 @@ struct nct6775_data {
u16 have_temp;
u16 have_temp_fixed;
u16 have_in;
#ifdef CONFIG_PM
/* Remember extra register values over suspend/resume */
u8 vbat;
u8 fandiv1;
u8 fandiv2;
#endif
};

struct nct6775_sio_data {
Expand Down Expand Up @@ -2270,10 +2276,90 @@ static int nct6775_remove(struct platform_device *pdev)
return 0;
}

#ifdef CONFIG_PM
static int nct6775_suspend(struct device *dev)
{
struct nct6775_data *data = nct6775_update_device(dev);
struct nct6775_sio_data *sio_data = dev->platform_data;

mutex_lock(&data->update_lock);
data->vbat = nct6775_read_value(data, data->REG_VBAT);
if (sio_data->kind == nct6775) {
data->fandiv1 = nct6775_read_value(data, NCT6775_REG_FANDIV1);
data->fandiv2 = nct6775_read_value(data, NCT6775_REG_FANDIV2);
}
mutex_unlock(&data->update_lock);

return 0;
}

static int nct6775_resume(struct device *dev)
{
struct nct6775_data *data = dev_get_drvdata(dev);
struct nct6775_sio_data *sio_data = dev->platform_data;
int i, j;

mutex_lock(&data->update_lock);
data->bank = 0xff; /* Force initial bank selection */

/* Restore limits */
for (i = 0; i < data->in_num; i++) {
if (!(data->have_in & (1 << i)))
continue;

nct6775_write_value(data, data->REG_IN_MINMAX[0][i],
data->in[i][1]);
nct6775_write_value(data, data->REG_IN_MINMAX[1][i],
data->in[i][2]);
}

for (i = 0; i < 5; i++) {
if (!(data->has_fan_min & (1 << i)))
continue;

nct6775_write_value(data, data->REG_FAN_MIN[i],
data->fan_min[i]);
}

for (i = 0; i < NUM_TEMP; i++) {
if (!(data->have_temp & (1 << i)))
continue;

for (j = 1; j < 4; j++)
if (data->reg_temp[j][i])
nct6775_write_temp(data, data->reg_temp[j][i],
data->temp[j][i]);
}

/* Restore other settings */
nct6775_write_value(data, data->REG_VBAT, data->vbat);
if (sio_data->kind == nct6775) {
nct6775_write_value(data, NCT6775_REG_FANDIV1, data->fandiv1);
nct6775_write_value(data, NCT6775_REG_FANDIV2, data->fandiv2);
}

/* Force re-reading all values */
data->valid = false;
mutex_unlock(&data->update_lock);

return 0;
}

static const struct dev_pm_ops nct6775_dev_pm_ops = {
.suspend = nct6775_suspend,
.resume = nct6775_resume,
};

#define NCT6775_DEV_PM_OPS (&nct6775_dev_pm_ops)
#else
#define NCT6775_DEV_PM_OPS NULL
#endif /* CONFIG_PM */

static struct platform_driver nct6775_driver = {
.driver = {
.owner = THIS_MODULE,
.name = DRVNAME,
.pm = NCT6775_DEV_PM_OPS,
},
.probe = nct6775_probe,
.remove = nct6775_remove,
Expand Down

0 comments on commit 6599a4d

Please sign in to comment.