Source
62
62
63
63
/*
64
64
* Data structures and manipulation thereof
65
65
*/
66
66
67
67
struct nct7802_data {
68
68
struct regmap *regmap;
69
69
struct mutex access_lock; /* for multi-byte read and write operations */
70
70
};
71
71
72
-
static ssize_t show_temp_type(struct device *dev, struct device_attribute *attr,
73
-
char *buf)
72
+
static ssize_t temp_type_show(struct device *dev,
73
+
struct device_attribute *attr, char *buf)
74
74
{
75
75
struct nct7802_data *data = dev_get_drvdata(dev);
76
76
struct sensor_device_attribute *sattr = to_sensor_dev_attr(attr);
77
77
unsigned int mode;
78
78
int ret;
79
79
80
80
ret = regmap_read(data->regmap, REG_MODE, &mode);
81
81
if (ret < 0)
82
82
return ret;
83
83
84
84
return sprintf(buf, "%u\n", (mode >> (2 * sattr->index) & 3) + 2);
85
85
}
86
86
87
-
static ssize_t store_temp_type(struct device *dev,
88
-
struct device_attribute *attr,
89
-
const char *buf, size_t count)
87
+
static ssize_t temp_type_store(struct device *dev,
88
+
struct device_attribute *attr, const char *buf,
89
+
size_t count)
90
90
{
91
91
struct nct7802_data *data = dev_get_drvdata(dev);
92
92
struct sensor_device_attribute *sattr = to_sensor_dev_attr(attr);
93
93
unsigned int type;
94
94
int err;
95
95
96
96
err = kstrtouint(buf, 0, &type);
97
97
if (err < 0)
98
98
return err;
99
99
if (sattr->index == 2 && type != 4) /* RD3 */
100
100
return -EINVAL;
101
101
if (type < 3 || type > 4)
102
102
return -EINVAL;
103
103
err = regmap_update_bits(data->regmap, REG_MODE,
104
104
3 << 2 * sattr->index, (type - 2) << 2 * sattr->index);
105
105
return err ? : count;
106
106
}
107
107
108
-
static ssize_t show_pwm_mode(struct device *dev, struct device_attribute *attr,
109
-
char *buf)
108
+
static ssize_t pwm_mode_show(struct device *dev,
109
+
struct device_attribute *attr, char *buf)
110
110
{
111
111
struct sensor_device_attribute *sattr = to_sensor_dev_attr(attr);
112
112
struct nct7802_data *data = dev_get_drvdata(dev);
113
113
unsigned int regval;
114
114
int ret;
115
115
116
116
if (sattr->index > 1)
117
117
return sprintf(buf, "1\n");
118
118
119
119
ret = regmap_read(data->regmap, 0x5E, ®val);
120
120
if (ret < 0)
121
121
return ret;
122
122
123
123
return sprintf(buf, "%u\n", !(regval & (1 << sattr->index)));
124
124
}
125
125
126
-
static ssize_t show_pwm(struct device *dev, struct device_attribute *devattr,
126
+
static ssize_t pwm_show(struct device *dev, struct device_attribute *devattr,
127
127
char *buf)
128
128
{
129
129
struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
130
130
struct nct7802_data *data = dev_get_drvdata(dev);
131
131
unsigned int val;
132
132
int ret;
133
133
134
134
if (!attr->index)
135
135
return sprintf(buf, "255\n");
136
136
137
137
ret = regmap_read(data->regmap, attr->index, &val);
138
138
if (ret < 0)
139
139
return ret;
140
140
141
141
return sprintf(buf, "%d\n", val);
142
142
}
143
143
144
-
static ssize_t store_pwm(struct device *dev, struct device_attribute *devattr,
144
+
static ssize_t pwm_store(struct device *dev, struct device_attribute *devattr,
145
145
const char *buf, size_t count)
146
146
{
147
147
struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
148
148
struct nct7802_data *data = dev_get_drvdata(dev);
149
149
int err;
150
150
u8 val;
151
151
152
152
err = kstrtou8(buf, 0, &val);
153
153
if (err < 0)
154
154
return err;
155
155
156
156
err = regmap_write(data->regmap, attr->index, val);
157
157
return err ? : count;
158
158
}
159
159
160
-
static ssize_t show_pwm_enable(struct device *dev,
160
+
static ssize_t pwm_enable_show(struct device *dev,
161
161
struct device_attribute *attr, char *buf)
162
162
{
163
163
struct nct7802_data *data = dev_get_drvdata(dev);
164
164
struct sensor_device_attribute *sattr = to_sensor_dev_attr(attr);
165
165
unsigned int reg, enabled;
166
166
int ret;
167
167
168
168
ret = regmap_read(data->regmap, REG_SMARTFAN_EN(sattr->index), ®);
169
169
if (ret < 0)
170
170
return ret;
171
171
enabled = reg >> SMARTFAN_EN_SHIFT(sattr->index) & 1;
172
172
return sprintf(buf, "%u\n", enabled + 1);
173
173
}
174
174
175
-
static ssize_t store_pwm_enable(struct device *dev,
175
+
static ssize_t pwm_enable_store(struct device *dev,
176
176
struct device_attribute *attr,
177
177
const char *buf, size_t count)
178
178
{
179
179
struct nct7802_data *data = dev_get_drvdata(dev);
180
180
struct sensor_device_attribute *sattr = to_sensor_dev_attr(attr);
181
181
u8 val;
182
182
int ret;
183
183
184
184
ret = kstrtou8(buf, 0, &val);
185
185
if (ret < 0)
338
338
if (err < 0)
339
339
goto abort;
340
340
341
341
err = regmap_update_bits(data->regmap, REG_VOLTAGE_LIMIT_MSB[nr],
342
342
0x0300 >> shift, (voltage & 0x0300) >> shift);
343
343
abort:
344
344
mutex_unlock(&data->access_lock);
345
345
return err;
346
346
}
347
347
348
-
static ssize_t show_in(struct device *dev, struct device_attribute *attr,
348
+
static ssize_t in_show(struct device *dev, struct device_attribute *attr,
349
349
char *buf)
350
350
{
351
351
struct sensor_device_attribute_2 *sattr = to_sensor_dev_attr_2(attr);
352
352
struct nct7802_data *data = dev_get_drvdata(dev);
353
353
int voltage;
354
354
355
355
voltage = nct7802_read_voltage(data, sattr->nr, sattr->index);
356
356
if (voltage < 0)
357
357
return voltage;
358
358
359
359
return sprintf(buf, "%d\n", voltage);
360
360
}
361
361
362
-
static ssize_t store_in(struct device *dev, struct device_attribute *attr,
362
+
static ssize_t in_store(struct device *dev, struct device_attribute *attr,
363
363
const char *buf, size_t count)
364
364
{
365
365
struct sensor_device_attribute_2 *sattr = to_sensor_dev_attr_2(attr);
366
366
struct nct7802_data *data = dev_get_drvdata(dev);
367
367
int index = sattr->index;
368
368
int nr = sattr->nr;
369
369
unsigned long val;
370
370
int err;
371
371
372
372
err = kstrtoul(buf, 10, &val);
373
373
if (err < 0)
374
374
return err;
375
375
376
376
err = nct7802_write_voltage(data, nr, index, val);
377
377
return err ? : count;
378
378
}
379
379
380
-
static ssize_t show_temp(struct device *dev, struct device_attribute *attr,
380
+
static ssize_t temp_show(struct device *dev, struct device_attribute *attr,
381
381
char *buf)
382
382
{
383
383
struct nct7802_data *data = dev_get_drvdata(dev);
384
384
struct sensor_device_attribute_2 *sattr = to_sensor_dev_attr_2(attr);
385
385
int err, temp;
386
386
387
387
err = nct7802_read_temp(data, sattr->nr, sattr->index, &temp);
388
388
if (err < 0)
389
389
return err;
390
390
391
391
return sprintf(buf, "%d\n", temp);
392
392
}
393
393
394
-
static ssize_t store_temp(struct device *dev, struct device_attribute *attr,
394
+
static ssize_t temp_store(struct device *dev, struct device_attribute *attr,
395
395
const char *buf, size_t count)
396
396
{
397
397
struct sensor_device_attribute_2 *sattr = to_sensor_dev_attr_2(attr);
398
398
struct nct7802_data *data = dev_get_drvdata(dev);
399
399
int nr = sattr->nr;
400
400
long val;
401
401
int err;
402
402
403
403
err = kstrtol(buf, 10, &val);
404
404
if (err < 0)
405
405
return err;
406
406
407
407
val = DIV_ROUND_CLOSEST(clamp_val(val, -128000, 127000), 1000);
408
408
409
409
err = regmap_write(data->regmap, nr, val & 0xff);
410
410
return err ? : count;
411
411
}
412
412
413
-
static ssize_t show_fan(struct device *dev, struct device_attribute *attr,
413
+
static ssize_t fan_show(struct device *dev, struct device_attribute *attr,
414
414
char *buf)
415
415
{
416
416
struct sensor_device_attribute *sattr = to_sensor_dev_attr(attr);
417
417
struct nct7802_data *data = dev_get_drvdata(dev);
418
418
int speed;
419
419
420
420
speed = nct7802_read_fan(data, sattr->index);
421
421
if (speed < 0)
422
422
return speed;
423
423
424
424
return sprintf(buf, "%d\n", speed);
425
425
}
426
426
427
-
static ssize_t show_fan_min(struct device *dev, struct device_attribute *attr,
427
+
static ssize_t fan_min_show(struct device *dev, struct device_attribute *attr,
428
428
char *buf)
429
429
{
430
430
struct sensor_device_attribute_2 *sattr = to_sensor_dev_attr_2(attr);
431
431
struct nct7802_data *data = dev_get_drvdata(dev);
432
432
int speed;
433
433
434
434
speed = nct7802_read_fan_min(data, sattr->nr, sattr->index);
435
435
if (speed < 0)
436
436
return speed;
437
437
438
438
return sprintf(buf, "%d\n", speed);
439
439
}
440
440
441
-
static ssize_t store_fan_min(struct device *dev, struct device_attribute *attr,
442
-
const char *buf, size_t count)
441
+
static ssize_t fan_min_store(struct device *dev,
442
+
struct device_attribute *attr, const char *buf,
443
+
size_t count)
443
444
{
444
445
struct sensor_device_attribute_2 *sattr = to_sensor_dev_attr_2(attr);
445
446
struct nct7802_data *data = dev_get_drvdata(dev);
446
447
unsigned long val;
447
448
int err;
448
449
449
450
err = kstrtoul(buf, 10, &val);
450
451
if (err < 0)
451
452
return err;
452
453
453
454
err = nct7802_write_fan_min(data, sattr->nr, sattr->index, val);
454
455
return err ? : count;
455
456
}
456
457
457
-
static ssize_t show_alarm(struct device *dev, struct device_attribute *attr,
458
+
static ssize_t alarm_show(struct device *dev, struct device_attribute *attr,
458
459
char *buf)
459
460
{
460
461
struct nct7802_data *data = dev_get_drvdata(dev);
461
462
struct sensor_device_attribute_2 *sattr = to_sensor_dev_attr_2(attr);
462
463
int bit = sattr->index;
463
464
unsigned int val;
464
465
int ret;
465
466
466
467
ret = regmap_read(data->regmap, sattr->nr, &val);
467
468
if (ret < 0)
468
469
return ret;
469
470
470
471
return sprintf(buf, "%u\n", !!(val & (1 << bit)));
471
472
}
472
473
473
474
static ssize_t
474
-
show_beep(struct device *dev, struct device_attribute *attr, char *buf)
475
+
beep_show(struct device *dev, struct device_attribute *attr, char *buf)
475
476
{
476
477
struct sensor_device_attribute_2 *sattr = to_sensor_dev_attr_2(attr);
477
478
struct nct7802_data *data = dev_get_drvdata(dev);
478
479
unsigned int regval;
479
480
int err;
480
481
481
482
err = regmap_read(data->regmap, sattr->nr, ®val);
482
483
if (err)
483
484
return err;
484
485
485
486
return sprintf(buf, "%u\n", !!(regval & (1 << sattr->index)));
486
487
}
487
488
488
489
static ssize_t
489
-
store_beep(struct device *dev, struct device_attribute *attr, const char *buf,
490
+
beep_store(struct device *dev, struct device_attribute *attr, const char *buf,
490
491
size_t count)
491
492
{
492
493
struct sensor_device_attribute_2 *sattr = to_sensor_dev_attr_2(attr);
493
494
struct nct7802_data *data = dev_get_drvdata(dev);
494
495
unsigned long val;
495
496
int err;
496
497
497
498
err = kstrtoul(buf, 10, &val);
498
499
if (err < 0)
499
500
return err;
500
501
if (val > 1)
501
502
return -EINVAL;
502
503
503
504
err = regmap_update_bits(data->regmap, sattr->nr, 1 << sattr->index,
504
505
val ? 1 << sattr->index : 0);
505
506
return err ? : count;
506
507
}
507
508
508
-
static SENSOR_DEVICE_ATTR(temp1_type, S_IRUGO | S_IWUSR,
509
-
show_temp_type, store_temp_type, 0);
510
-
static SENSOR_DEVICE_ATTR_2(temp1_input, S_IRUGO, show_temp, NULL, 0x01,
511
-
REG_TEMP_LSB);
512
-
static SENSOR_DEVICE_ATTR_2(temp1_min, S_IRUGO | S_IWUSR, show_temp,
513
-
store_temp, 0x31, 0);
514
-
static SENSOR_DEVICE_ATTR_2(temp1_max, S_IRUGO | S_IWUSR, show_temp,
515
-
store_temp, 0x30, 0);
516
-
static SENSOR_DEVICE_ATTR_2(temp1_crit, S_IRUGO | S_IWUSR, show_temp,
517
-
store_temp, 0x3a, 0);
518
-
519
-
static SENSOR_DEVICE_ATTR(temp2_type, S_IRUGO | S_IWUSR,
520
-
show_temp_type, store_temp_type, 1);
521
-
static SENSOR_DEVICE_ATTR_2(temp2_input, S_IRUGO, show_temp, NULL, 0x02,
522
-
REG_TEMP_LSB);
523
-
static SENSOR_DEVICE_ATTR_2(temp2_min, S_IRUGO | S_IWUSR, show_temp,
524
-
store_temp, 0x33, 0);
525
-
static SENSOR_DEVICE_ATTR_2(temp2_max, S_IRUGO | S_IWUSR, show_temp,
526
-
store_temp, 0x32, 0);
527
-
static SENSOR_DEVICE_ATTR_2(temp2_crit, S_IRUGO | S_IWUSR, show_temp,
528
-
store_temp, 0x3b, 0);
529
-
530
-
static SENSOR_DEVICE_ATTR(temp3_type, S_IRUGO | S_IWUSR,
531
-
show_temp_type, store_temp_type, 2);
532
-
static SENSOR_DEVICE_ATTR_2(temp3_input, S_IRUGO, show_temp, NULL, 0x03,
533
-
REG_TEMP_LSB);
534
-
static SENSOR_DEVICE_ATTR_2(temp3_min, S_IRUGO | S_IWUSR, show_temp,
535
-
store_temp, 0x35, 0);
536
-
static SENSOR_DEVICE_ATTR_2(temp3_max, S_IRUGO | S_IWUSR, show_temp,
537
-
store_temp, 0x34, 0);
538
-
static SENSOR_DEVICE_ATTR_2(temp3_crit, S_IRUGO | S_IWUSR, show_temp,
539
-
store_temp, 0x3c, 0);
540
-
541
-
static SENSOR_DEVICE_ATTR_2(temp4_input, S_IRUGO, show_temp, NULL, 0x04, 0);
542
-
static SENSOR_DEVICE_ATTR_2(temp4_min, S_IRUGO | S_IWUSR, show_temp,
543
-
store_temp, 0x37, 0);
544
-
static SENSOR_DEVICE_ATTR_2(temp4_max, S_IRUGO | S_IWUSR, show_temp,
545
-
store_temp, 0x36, 0);
546
-
static SENSOR_DEVICE_ATTR_2(temp4_crit, S_IRUGO | S_IWUSR, show_temp,
547
-
store_temp, 0x3d, 0);
548
-
549
-
static SENSOR_DEVICE_ATTR_2(temp5_input, S_IRUGO, show_temp, NULL, 0x06,
550
-
REG_TEMP_PECI_LSB);
551
-
static SENSOR_DEVICE_ATTR_2(temp5_min, S_IRUGO | S_IWUSR, show_temp,
552
-
store_temp, 0x39, 0);
553
-
static SENSOR_DEVICE_ATTR_2(temp5_max, S_IRUGO | S_IWUSR, show_temp,
554
-
store_temp, 0x38, 0);
555
-
static SENSOR_DEVICE_ATTR_2(temp5_crit, S_IRUGO | S_IWUSR, show_temp,
556
-
store_temp, 0x3e, 0);
557
-
558
-
static SENSOR_DEVICE_ATTR_2(temp6_input, S_IRUGO, show_temp, NULL, 0x07,
559
-
REG_TEMP_PECI_LSB);
560
-
561
-
static SENSOR_DEVICE_ATTR_2(temp1_min_alarm, S_IRUGO, show_alarm, NULL,
562
-
0x18, 0);
563
-
static SENSOR_DEVICE_ATTR_2(temp2_min_alarm, S_IRUGO, show_alarm, NULL,
564
-
0x18, 1);
565
-
static SENSOR_DEVICE_ATTR_2(temp3_min_alarm, S_IRUGO, show_alarm, NULL,
566
-
0x18, 2);
567
-
static SENSOR_DEVICE_ATTR_2(temp4_min_alarm, S_IRUGO, show_alarm, NULL,
568
-
0x18, 3);
569
-
static SENSOR_DEVICE_ATTR_2(temp5_min_alarm, S_IRUGO, show_alarm, NULL,
570
-
0x18, 4);
571
-
572
-
static SENSOR_DEVICE_ATTR_2(temp1_max_alarm, S_IRUGO, show_alarm, NULL,
573
-
0x19, 0);
574
-
static SENSOR_DEVICE_ATTR_2(temp2_max_alarm, S_IRUGO, show_alarm, NULL,
575
-
0x19, 1);
576
-
static SENSOR_DEVICE_ATTR_2(temp3_max_alarm, S_IRUGO, show_alarm, NULL,
577
-
0x19, 2);
578
-
static SENSOR_DEVICE_ATTR_2(temp4_max_alarm, S_IRUGO, show_alarm, NULL,
579
-
0x19, 3);
580
-
static SENSOR_DEVICE_ATTR_2(temp5_max_alarm, S_IRUGO, show_alarm, NULL,
581
-
0x19, 4);
582
-
583
-
static SENSOR_DEVICE_ATTR_2(temp1_crit_alarm, S_IRUGO, show_alarm, NULL,
584
-
0x1b, 0);
585
-
static SENSOR_DEVICE_ATTR_2(temp2_crit_alarm, S_IRUGO, show_alarm, NULL,
586
-
0x1b, 1);
587
-
static SENSOR_DEVICE_ATTR_2(temp3_crit_alarm, S_IRUGO, show_alarm, NULL,
588
-
0x1b, 2);
589
-
static SENSOR_DEVICE_ATTR_2(temp4_crit_alarm, S_IRUGO, show_alarm, NULL,
590
-
0x1b, 3);
591
-
static SENSOR_DEVICE_ATTR_2(temp5_crit_alarm, S_IRUGO, show_alarm, NULL,
592
-
0x1b, 4);
593
-
594
-
static SENSOR_DEVICE_ATTR_2(temp1_fault, S_IRUGO, show_alarm, NULL, 0x17, 0);
595
-
static SENSOR_DEVICE_ATTR_2(temp2_fault, S_IRUGO, show_alarm, NULL, 0x17, 1);
596
-
static SENSOR_DEVICE_ATTR_2(temp3_fault, S_IRUGO, show_alarm, NULL, 0x17, 2);
597
-
598
-
static SENSOR_DEVICE_ATTR_2(temp1_beep, S_IRUGO | S_IWUSR, show_beep,
599
-
store_beep, 0x5c, 0);
600
-
static SENSOR_DEVICE_ATTR_2(temp2_beep, S_IRUGO | S_IWUSR, show_beep,
601
-
store_beep, 0x5c, 1);
602
-
static SENSOR_DEVICE_ATTR_2(temp3_beep, S_IRUGO | S_IWUSR, show_beep,
603
-
store_beep, 0x5c, 2);
604
-
static SENSOR_DEVICE_ATTR_2(temp4_beep, S_IRUGO | S_IWUSR, show_beep,
605
-
store_beep, 0x5c, 3);
606
-
static SENSOR_DEVICE_ATTR_2(temp5_beep, S_IRUGO | S_IWUSR, show_beep,
607
-
store_beep, 0x5c, 4);
608
-
static SENSOR_DEVICE_ATTR_2(temp6_beep, S_IRUGO | S_IWUSR, show_beep,
609
-
store_beep, 0x5c, 5);
509
+
static SENSOR_DEVICE_ATTR_RW(temp1_type, temp_type, 0);
510
+
static SENSOR_DEVICE_ATTR_2_RO(temp1_input, temp, 0x01, REG_TEMP_LSB);
511
+
static SENSOR_DEVICE_ATTR_2_RW(temp1_min, temp, 0x31, 0);
512
+
static SENSOR_DEVICE_ATTR_2_RW(temp1_max, temp, 0x30, 0);
513
+
static SENSOR_DEVICE_ATTR_2_RW(temp1_crit, temp, 0x3a, 0);
514
+
515
+
static SENSOR_DEVICE_ATTR_RW(temp2_type, temp_type, 1);
516
+
static SENSOR_DEVICE_ATTR_2_RO(temp2_input, temp, 0x02, REG_TEMP_LSB);
517
+
static SENSOR_DEVICE_ATTR_2_RW(temp2_min, temp, 0x33, 0);
518
+
static SENSOR_DEVICE_ATTR_2_RW(temp2_max, temp, 0x32, 0);
519
+
static SENSOR_DEVICE_ATTR_2_RW(temp2_crit, temp, 0x3b, 0);
520
+
521
+
static SENSOR_DEVICE_ATTR_RW(temp3_type, temp_type, 2);
522
+
static SENSOR_DEVICE_ATTR_2_RO(temp3_input, temp, 0x03, REG_TEMP_LSB);
523
+
static SENSOR_DEVICE_ATTR_2_RW(temp3_min, temp, 0x35, 0);
524
+
static SENSOR_DEVICE_ATTR_2_RW(temp3_max, temp, 0x34, 0);
525
+
static SENSOR_DEVICE_ATTR_2_RW(temp3_crit, temp, 0x3c, 0);
526
+
527
+
static SENSOR_DEVICE_ATTR_2_RO(temp4_input, temp, 0x04, 0);
528
+
static SENSOR_DEVICE_ATTR_2_RW(temp4_min, temp, 0x37, 0);
529
+
static SENSOR_DEVICE_ATTR_2_RW(temp4_max, temp, 0x36, 0);
530
+
static SENSOR_DEVICE_ATTR_2_RW(temp4_crit, temp, 0x3d, 0);
531
+
532
+
static SENSOR_DEVICE_ATTR_2_RO(temp5_input, temp, 0x06, REG_TEMP_PECI_LSB);
533
+
static SENSOR_DEVICE_ATTR_2_RW(temp5_min, temp, 0x39, 0);
534
+
static SENSOR_DEVICE_ATTR_2_RW(temp5_max, temp, 0x38, 0);
535
+
static SENSOR_DEVICE_ATTR_2_RW(temp5_crit, temp, 0x3e, 0);
536
+
537
+
static SENSOR_DEVICE_ATTR_2_RO(temp6_input, temp, 0x07, REG_TEMP_PECI_LSB);
538
+
539
+
static SENSOR_DEVICE_ATTR_2_RO(temp1_min_alarm, alarm, 0x18, 0);
540
+
static SENSOR_DEVICE_ATTR_2_RO(temp2_min_alarm, alarm, 0x18, 1);
541
+
static SENSOR_DEVICE_ATTR_2_RO(temp3_min_alarm, alarm, 0x18, 2);
542
+
static SENSOR_DEVICE_ATTR_2_RO(temp4_min_alarm, alarm, 0x18, 3);
543
+
static SENSOR_DEVICE_ATTR_2_RO(temp5_min_alarm, alarm, 0x18, 4);
544
+
545
+
static SENSOR_DEVICE_ATTR_2_RO(temp1_max_alarm, alarm, 0x19, 0);
546
+
static SENSOR_DEVICE_ATTR_2_RO(temp2_max_alarm, alarm, 0x19, 1);
547
+
static SENSOR_DEVICE_ATTR_2_RO(temp3_max_alarm, alarm, 0x19, 2);
548
+
static SENSOR_DEVICE_ATTR_2_RO(temp4_max_alarm, alarm, 0x19, 3);
549
+
static SENSOR_DEVICE_ATTR_2_RO(temp5_max_alarm, alarm, 0x19, 4);
550
+
551
+
static SENSOR_DEVICE_ATTR_2_RO(temp1_crit_alarm, alarm, 0x1b, 0);
552
+
static SENSOR_DEVICE_ATTR_2_RO(temp2_crit_alarm, alarm, 0x1b, 1);
553
+
static SENSOR_DEVICE_ATTR_2_RO(temp3_crit_alarm, alarm, 0x1b, 2);
554
+
static SENSOR_DEVICE_ATTR_2_RO(temp4_crit_alarm, alarm, 0x1b, 3);
555
+
static SENSOR_DEVICE_ATTR_2_RO(temp5_crit_alarm, alarm, 0x1b, 4);
556
+
557
+
static SENSOR_DEVICE_ATTR_2_RO(temp1_fault, alarm, 0x17, 0);
558
+
static SENSOR_DEVICE_ATTR_2_RO(temp2_fault, alarm, 0x17, 1);
559
+
static SENSOR_DEVICE_ATTR_2_RO(temp3_fault, alarm, 0x17, 2);
560
+
561
+
static SENSOR_DEVICE_ATTR_2_RW(temp1_beep, beep, 0x5c, 0);
562
+
static SENSOR_DEVICE_ATTR_2_RW(temp2_beep, beep, 0x5c, 1);
563
+
static SENSOR_DEVICE_ATTR_2_RW(temp3_beep, beep, 0x5c, 2);
564
+
static SENSOR_DEVICE_ATTR_2_RW(temp4_beep, beep, 0x5c, 3);
565
+
static SENSOR_DEVICE_ATTR_2_RW(temp5_beep, beep, 0x5c, 4);
566
+
static SENSOR_DEVICE_ATTR_2_RW(temp6_beep, beep, 0x5c, 5);
610
567
611
568
static struct attribute *nct7802_temp_attrs[] = {
612
569
&sensor_dev_attr_temp1_type.dev_attr.attr,
613
570
&sensor_dev_attr_temp1_input.dev_attr.attr,
614
571
&sensor_dev_attr_temp1_min.dev_attr.attr,
615
572
&sensor_dev_attr_temp1_max.dev_attr.attr,
616
573
&sensor_dev_attr_temp1_crit.dev_attr.attr,
617
574
&sensor_dev_attr_temp1_min_alarm.dev_attr.attr,
618
575
&sensor_dev_attr_temp1_max_alarm.dev_attr.attr,
619
576
&sensor_dev_attr_temp1_crit_alarm.dev_attr.attr,
702
659
return 0;
703
660
704
661
return attr->mode;
705
662
}
706
663
707
664
static const struct attribute_group nct7802_temp_group = {
708
665
.attrs = nct7802_temp_attrs,
709
666
.is_visible = nct7802_temp_is_visible,
710
667
};
711
668
712
-
static SENSOR_DEVICE_ATTR_2(in0_input, S_IRUGO, show_in, NULL, 0, 0);
713
-
static SENSOR_DEVICE_ATTR_2(in0_min, S_IRUGO | S_IWUSR, show_in, store_in,
714
-
0, 1);
715
-
static SENSOR_DEVICE_ATTR_2(in0_max, S_IRUGO | S_IWUSR, show_in, store_in,
716
-
0, 2);
717
-
static SENSOR_DEVICE_ATTR_2(in0_alarm, S_IRUGO, show_alarm, NULL, 0x1e, 3);
718
-
static SENSOR_DEVICE_ATTR_2(in0_beep, S_IRUGO | S_IWUSR, show_beep, store_beep,
719
-
0x5a, 3);
720
-
721
-
static SENSOR_DEVICE_ATTR_2(in1_input, S_IRUGO, show_in, NULL, 1, 0);
722
-
723
-
static SENSOR_DEVICE_ATTR_2(in2_input, S_IRUGO, show_in, NULL, 2, 0);
724
-
static SENSOR_DEVICE_ATTR_2(in2_min, S_IRUGO | S_IWUSR, show_in, store_in,
725
-
2, 1);
726
-
static SENSOR_DEVICE_ATTR_2(in2_max, S_IRUGO | S_IWUSR, show_in, store_in,
727
-
2, 2);
728
-
static SENSOR_DEVICE_ATTR_2(in2_alarm, S_IRUGO, show_alarm, NULL, 0x1e, 0);
729
-
static SENSOR_DEVICE_ATTR_2(in2_beep, S_IRUGO | S_IWUSR, show_beep, store_beep,
730
-
0x5a, 0);
731
-
732
-
static SENSOR_DEVICE_ATTR_2(in3_input, S_IRUGO, show_in, NULL, 3, 0);
733
-
static SENSOR_DEVICE_ATTR_2(in3_min, S_IRUGO | S_IWUSR, show_in, store_in,
734
-
3, 1);
735
-
static SENSOR_DEVICE_ATTR_2(in3_max, S_IRUGO | S_IWUSR, show_in, store_in,
736
-
3, 2);
737
-
static SENSOR_DEVICE_ATTR_2(in3_alarm, S_IRUGO, show_alarm, NULL, 0x1e, 1);
738
-
static SENSOR_DEVICE_ATTR_2(in3_beep, S_IRUGO | S_IWUSR, show_beep, store_beep,
739
-
0x5a, 1);
740
-
741
-
static SENSOR_DEVICE_ATTR_2(in4_input, S_IRUGO, show_in, NULL, 4, 0);
742
-
static SENSOR_DEVICE_ATTR_2(in4_min, S_IRUGO | S_IWUSR, show_in, store_in,
743
-
4, 1);
744
-
static SENSOR_DEVICE_ATTR_2(in4_max, S_IRUGO | S_IWUSR, show_in, store_in,
745
-
4, 2);
746
-
static SENSOR_DEVICE_ATTR_2(in4_alarm, S_IRUGO, show_alarm, NULL, 0x1e, 2);
747
-
static SENSOR_DEVICE_ATTR_2(in4_beep, S_IRUGO | S_IWUSR, show_beep, store_beep,
748
-
0x5a, 2);
669
+
static SENSOR_DEVICE_ATTR_2_RO(in0_input, in, 0, 0);
670
+
static SENSOR_DEVICE_ATTR_2_RW(in0_min, in, 0, 1);
671
+
static SENSOR_DEVICE_ATTR_2_RW(in0_max, in, 0, 2);
672
+
static SENSOR_DEVICE_ATTR_2_RO(in0_alarm, alarm, 0x1e, 3);
673
+
static SENSOR_DEVICE_ATTR_2_RW(in0_beep, beep, 0x5a, 3);
674
+
675
+
static SENSOR_DEVICE_ATTR_2_RO(in1_input, in, 1, 0);
676
+
677
+
static SENSOR_DEVICE_ATTR_2_RO(in2_input, in, 2, 0);
678
+
static SENSOR_DEVICE_ATTR_2_RW(in2_min, in, 2, 1);
679
+
static SENSOR_DEVICE_ATTR_2_RW(in2_max, in, 2, 2);
680
+
static SENSOR_DEVICE_ATTR_2_RO(in2_alarm, alarm, 0x1e, 0);
681
+
static SENSOR_DEVICE_ATTR_2_RW(in2_beep, beep, 0x5a, 0);
682
+
683
+
static SENSOR_DEVICE_ATTR_2_RO(in3_input, in, 3, 0);
684
+
static SENSOR_DEVICE_ATTR_2_RW(in3_min, in, 3, 1);
685
+
static SENSOR_DEVICE_ATTR_2_RW(in3_max, in, 3, 2);
686
+
static SENSOR_DEVICE_ATTR_2_RO(in3_alarm, alarm, 0x1e, 1);
687
+
static SENSOR_DEVICE_ATTR_2_RW(in3_beep, beep, 0x5a, 1);
688
+
689
+
static SENSOR_DEVICE_ATTR_2_RO(in4_input, in, 4, 0);
690
+
static SENSOR_DEVICE_ATTR_2_RW(in4_min, in, 4, 1);
691
+
static SENSOR_DEVICE_ATTR_2_RW(in4_max, in, 4, 2);
692
+
static SENSOR_DEVICE_ATTR_2_RO(in4_alarm, alarm, 0x1e, 2);
693
+
static SENSOR_DEVICE_ATTR_2_RW(in4_beep, beep, 0x5a, 2);
749
694
750
695
static struct attribute *nct7802_in_attrs[] = {
751
696
&sensor_dev_attr_in0_input.dev_attr.attr,
752
697
&sensor_dev_attr_in0_min.dev_attr.attr,
753
698
&sensor_dev_attr_in0_max.dev_attr.attr,
754
699
&sensor_dev_attr_in0_alarm.dev_attr.attr,
755
700
&sensor_dev_attr_in0_beep.dev_attr.attr,
756
701
757
702
&sensor_dev_attr_in1_input.dev_attr.attr, /* 5 */
758
703
800
745
return 0;
801
746
802
747
return attr->mode;
803
748
}
804
749
805
750
static const struct attribute_group nct7802_in_group = {
806
751
.attrs = nct7802_in_attrs,
807
752
.is_visible = nct7802_in_is_visible,
808
753
};
809
754
810
-
static SENSOR_DEVICE_ATTR(fan1_input, S_IRUGO, show_fan, NULL, 0x10);
811
-
static SENSOR_DEVICE_ATTR_2(fan1_min, S_IRUGO | S_IWUSR, show_fan_min,
812
-
store_fan_min, 0x49, 0x4c);
813
-
static SENSOR_DEVICE_ATTR_2(fan1_alarm, S_IRUGO, show_alarm, NULL, 0x1a, 0);
814
-
static SENSOR_DEVICE_ATTR_2(fan1_beep, S_IRUGO | S_IWUSR, show_beep, store_beep,
815
-
0x5b, 0);
816
-
static SENSOR_DEVICE_ATTR(fan2_input, S_IRUGO, show_fan, NULL, 0x11);
817
-
static SENSOR_DEVICE_ATTR_2(fan2_min, S_IRUGO | S_IWUSR, show_fan_min,
818
-
store_fan_min, 0x4a, 0x4d);
819
-
static SENSOR_DEVICE_ATTR_2(fan2_alarm, S_IRUGO, show_alarm, NULL, 0x1a, 1);
820
-
static SENSOR_DEVICE_ATTR_2(fan2_beep, S_IRUGO | S_IWUSR, show_beep, store_beep,
821
-
0x5b, 1);
822
-
static SENSOR_DEVICE_ATTR(fan3_input, S_IRUGO, show_fan, NULL, 0x12);
823
-
static SENSOR_DEVICE_ATTR_2(fan3_min, S_IRUGO | S_IWUSR, show_fan_min,
824
-
store_fan_min, 0x4b, 0x4e);
825
-
static SENSOR_DEVICE_ATTR_2(fan3_alarm, S_IRUGO, show_alarm, NULL, 0x1a, 2);
826
-
static SENSOR_DEVICE_ATTR_2(fan3_beep, S_IRUGO | S_IWUSR, show_beep, store_beep,
827
-
0x5b, 2);
755
+
static SENSOR_DEVICE_ATTR_RO(fan1_input, fan, 0x10);
756
+
static SENSOR_DEVICE_ATTR_2_RW(fan1_min, fan_min, 0x49, 0x4c);
757
+
static SENSOR_DEVICE_ATTR_2_RO(fan1_alarm, alarm, 0x1a, 0);
758
+
static SENSOR_DEVICE_ATTR_2_RW(fan1_beep, beep, 0x5b, 0);
759
+
static SENSOR_DEVICE_ATTR_RO(fan2_input, fan, 0x11);
760
+
static SENSOR_DEVICE_ATTR_2_RW(fan2_min, fan_min, 0x4a, 0x4d);
761
+
static SENSOR_DEVICE_ATTR_2_RO(fan2_alarm, alarm, 0x1a, 1);
762
+
static SENSOR_DEVICE_ATTR_2_RW(fan2_beep, beep, 0x5b, 1);
763
+
static SENSOR_DEVICE_ATTR_RO(fan3_input, fan, 0x12);
764
+
static SENSOR_DEVICE_ATTR_2_RW(fan3_min, fan_min, 0x4b, 0x4e);
765
+
static SENSOR_DEVICE_ATTR_2_RO(fan3_alarm, alarm, 0x1a, 2);
766
+
static SENSOR_DEVICE_ATTR_2_RW(fan3_beep, beep, 0x5b, 2);
828
767
829
768
/* 7.2.89 Fan Control Output Type */
830
-
static SENSOR_DEVICE_ATTR(pwm1_mode, S_IRUGO, show_pwm_mode, NULL, 0);
831
-
static SENSOR_DEVICE_ATTR(pwm2_mode, S_IRUGO, show_pwm_mode, NULL, 1);
832
-
static SENSOR_DEVICE_ATTR(pwm3_mode, S_IRUGO, show_pwm_mode, NULL, 2);
769
+
static SENSOR_DEVICE_ATTR_RO(pwm1_mode, pwm_mode, 0);
770
+
static SENSOR_DEVICE_ATTR_RO(pwm2_mode, pwm_mode, 1);
771
+
static SENSOR_DEVICE_ATTR_RO(pwm3_mode, pwm_mode, 2);
833
772
834
773
/* 7.2.91... Fan Control Output Value */
835
-
static SENSOR_DEVICE_ATTR(pwm1, S_IRUGO | S_IWUSR, show_pwm, store_pwm,
836
-
REG_PWM(0));
837
-
static SENSOR_DEVICE_ATTR(pwm2, S_IRUGO | S_IWUSR, show_pwm, store_pwm,
838
-
REG_PWM(1));
839
-
static SENSOR_DEVICE_ATTR(pwm3, S_IRUGO | S_IWUSR, show_pwm, store_pwm,
840
-
REG_PWM(2));
774
+
static SENSOR_DEVICE_ATTR_RW(pwm1, pwm, REG_PWM(0));
775
+
static SENSOR_DEVICE_ATTR_RW(pwm2, pwm, REG_PWM(1));
776
+
static SENSOR_DEVICE_ATTR_RW(pwm3, pwm, REG_PWM(2));
841
777
842
778
/* 7.2.95... Temperature to Fan mapping Relationships Register */
843
-
static SENSOR_DEVICE_ATTR(pwm1_enable, S_IRUGO | S_IWUSR, show_pwm_enable,
844
-
store_pwm_enable, 0);
845
-
static SENSOR_DEVICE_ATTR(pwm2_enable, S_IRUGO | S_IWUSR, show_pwm_enable,
846
-
store_pwm_enable, 1);
847
-
static SENSOR_DEVICE_ATTR(pwm3_enable, S_IRUGO | S_IWUSR, show_pwm_enable,
848
-
store_pwm_enable, 2);
779
+
static SENSOR_DEVICE_ATTR_RW(pwm1_enable, pwm_enable, 0);
780
+
static SENSOR_DEVICE_ATTR_RW(pwm2_enable, pwm_enable, 1);
781
+
static SENSOR_DEVICE_ATTR_RW(pwm3_enable, pwm_enable, 2);
849
782
850
783
static struct attribute *nct7802_fan_attrs[] = {
851
784
&sensor_dev_attr_fan1_input.dev_attr.attr,
852
785
&sensor_dev_attr_fan1_min.dev_attr.attr,
853
786
&sensor_dev_attr_fan1_alarm.dev_attr.attr,
854
787
&sensor_dev_attr_fan1_beep.dev_attr.attr,
855
788
&sensor_dev_attr_fan2_input.dev_attr.attr,
856
789
&sensor_dev_attr_fan2_min.dev_attr.attr,
857
790
&sensor_dev_attr_fan2_alarm.dev_attr.attr,
858
791
&sensor_dev_attr_fan2_beep.dev_attr.attr,
896
829
&sensor_dev_attr_pwm3_mode.dev_attr.attr,
897
830
&sensor_dev_attr_pwm3.dev_attr.attr,
898
831
NULL
899
832
};
900
833
901
834
static const struct attribute_group nct7802_pwm_group = {
902
835
.attrs = nct7802_pwm_attrs,
903
836
};
904
837
905
838
/* 7.2.115... 0x80-0x83, 0x84 Temperature (X-axis) transition */
906
-
static SENSOR_DEVICE_ATTR_2(pwm1_auto_point1_temp, S_IRUGO | S_IWUSR,
907
-
show_temp, store_temp, 0x80, 0);
908
-
static SENSOR_DEVICE_ATTR_2(pwm1_auto_point2_temp, S_IRUGO | S_IWUSR,
909
-
show_temp, store_temp, 0x81, 0);
910
-
static SENSOR_DEVICE_ATTR_2(pwm1_auto_point3_temp, S_IRUGO | S_IWUSR,
911
-
show_temp, store_temp, 0x82, 0);
912
-
static SENSOR_DEVICE_ATTR_2(pwm1_auto_point4_temp, S_IRUGO | S_IWUSR,
913
-
show_temp, store_temp, 0x83, 0);
914
-
static SENSOR_DEVICE_ATTR_2(pwm1_auto_point5_temp, S_IRUGO | S_IWUSR,
915
-
show_temp, store_temp, 0x84, 0);
839
+
static SENSOR_DEVICE_ATTR_2_RW(pwm1_auto_point1_temp, temp, 0x80, 0);
840
+
static SENSOR_DEVICE_ATTR_2_RW(pwm1_auto_point2_temp, temp, 0x81, 0);
841
+
static SENSOR_DEVICE_ATTR_2_RW(pwm1_auto_point3_temp, temp, 0x82, 0);
842
+
static SENSOR_DEVICE_ATTR_2_RW(pwm1_auto_point4_temp, temp, 0x83, 0);
843
+
static SENSOR_DEVICE_ATTR_2_RW(pwm1_auto_point5_temp, temp, 0x84, 0);
916
844
917
845
/* 7.2.120... 0x85-0x88 PWM (Y-axis) transition */
918
-
static SENSOR_DEVICE_ATTR(pwm1_auto_point1_pwm, S_IRUGO | S_IWUSR,
919
-
show_pwm, store_pwm, 0x85);
920
-
static SENSOR_DEVICE_ATTR(pwm1_auto_point2_pwm, S_IRUGO | S_IWUSR,
921
-
show_pwm, store_pwm, 0x86);
922
-
static SENSOR_DEVICE_ATTR(pwm1_auto_point3_pwm, S_IRUGO | S_IWUSR,
923
-
show_pwm, store_pwm, 0x87);
924
-
static SENSOR_DEVICE_ATTR(pwm1_auto_point4_pwm, S_IRUGO | S_IWUSR,
925
-
show_pwm, store_pwm, 0x88);
926
-
static SENSOR_DEVICE_ATTR(pwm1_auto_point5_pwm, S_IRUGO, show_pwm, NULL, 0);
846
+
static SENSOR_DEVICE_ATTR_RW(pwm1_auto_point1_pwm, pwm, 0x85);
847
+
static SENSOR_DEVICE_ATTR_RW(pwm1_auto_point2_pwm, pwm, 0x86);
848
+
static SENSOR_DEVICE_ATTR_RW(pwm1_auto_point3_pwm, pwm, 0x87);
849
+
static SENSOR_DEVICE_ATTR_RW(pwm1_auto_point4_pwm, pwm, 0x88);
850
+
static SENSOR_DEVICE_ATTR_RO(pwm1_auto_point5_pwm, pwm, 0);
927
851
928
852
/* 7.2.124 Table 2 X-axis Transition Point 1 Register */
929
-
static SENSOR_DEVICE_ATTR_2(pwm2_auto_point1_temp, S_IRUGO | S_IWUSR,
930
-
show_temp, store_temp, 0x90, 0);
931
-
static SENSOR_DEVICE_ATTR_2(pwm2_auto_point2_temp, S_IRUGO | S_IWUSR,
932
-
show_temp, store_temp, 0x91, 0);
933
-
static SENSOR_DEVICE_ATTR_2(pwm2_auto_point3_temp, S_IRUGO | S_IWUSR,
934
-
show_temp, store_temp, 0x92, 0);
935
-
static SENSOR_DEVICE_ATTR_2(pwm2_auto_point4_temp, S_IRUGO | S_IWUSR,
936
-
show_temp, store_temp, 0x93, 0);
937
-
static SENSOR_DEVICE_ATTR_2(pwm2_auto_point5_temp, S_IRUGO | S_IWUSR,
938
-
show_temp, store_temp, 0x94, 0);
853
+
static SENSOR_DEVICE_ATTR_2_RW(pwm2_auto_point1_temp, temp, 0x90, 0);
854
+
static SENSOR_DEVICE_ATTR_2_RW(pwm2_auto_point2_temp, temp, 0x91, 0);
855
+
static SENSOR_DEVICE_ATTR_2_RW(pwm2_auto_point3_temp, temp, 0x92, 0);
856
+
static SENSOR_DEVICE_ATTR_2_RW(pwm2_auto_point4_temp, temp, 0x93, 0);
857
+
static SENSOR_DEVICE_ATTR_2_RW(pwm2_auto_point5_temp, temp, 0x94, 0);
939
858
940
859
/* 7.2.129 Table 2 Y-axis Transition Point 1 Register */
941
-
static SENSOR_DEVICE_ATTR(pwm2_auto_point1_pwm, S_IRUGO | S_IWUSR,
942
-
show_pwm, store_pwm, 0x95);
943
-
static SENSOR_DEVICE_ATTR(pwm2_auto_point2_pwm, S_IRUGO | S_IWUSR,
944
-
show_pwm, store_pwm, 0x96);
945
-
static SENSOR_DEVICE_ATTR(pwm2_auto_point3_pwm, S_IRUGO | S_IWUSR,
946
-
show_pwm, store_pwm, 0x97);
947
-
static SENSOR_DEVICE_ATTR(pwm2_auto_point4_pwm, S_IRUGO | S_IWUSR,
948
-
show_pwm, store_pwm, 0x98);
949
-
static SENSOR_DEVICE_ATTR(pwm2_auto_point5_pwm, S_IRUGO, show_pwm, NULL, 0);
860
+
static SENSOR_DEVICE_ATTR_RW(pwm2_auto_point1_pwm, pwm, 0x95);
861
+
static SENSOR_DEVICE_ATTR_RW(pwm2_auto_point2_pwm, pwm, 0x96);
862
+
static SENSOR_DEVICE_ATTR_RW(pwm2_auto_point3_pwm, pwm, 0x97);
863
+
static SENSOR_DEVICE_ATTR_RW(pwm2_auto_point4_pwm, pwm, 0x98);
864
+
static SENSOR_DEVICE_ATTR_RO(pwm2_auto_point5_pwm, pwm, 0);
950
865
951
866
/* 7.2.133 Table 3 X-axis Transition Point 1 Register */
952
-
static SENSOR_DEVICE_ATTR_2(pwm3_auto_point1_temp, S_IRUGO | S_IWUSR,
953
-
show_temp, store_temp, 0xA0, 0);
954
-
static SENSOR_DEVICE_ATTR_2(pwm3_auto_point2_temp, S_IRUGO | S_IWUSR,
955
-
show_temp, store_temp, 0xA1, 0);
956
-
static SENSOR_DEVICE_ATTR_2(pwm3_auto_point3_temp, S_IRUGO | S_IWUSR,
957
-
show_temp, store_temp, 0xA2, 0);
958
-
static SENSOR_DEVICE_ATTR_2(pwm3_auto_point4_temp, S_IRUGO | S_IWUSR,
959
-
show_temp, store_temp, 0xA3, 0);
960
-
static SENSOR_DEVICE_ATTR_2(pwm3_auto_point5_temp, S_IRUGO | S_IWUSR,
961
-
show_temp, store_temp, 0xA4, 0);
867
+
static SENSOR_DEVICE_ATTR_2_RW(pwm3_auto_point1_temp, temp, 0xA0, 0);
868
+
static SENSOR_DEVICE_ATTR_2_RW(pwm3_auto_point2_temp, temp, 0xA1, 0);
869
+
static SENSOR_DEVICE_ATTR_2_RW(pwm3_auto_point3_temp, temp, 0xA2, 0);
870
+
static SENSOR_DEVICE_ATTR_2_RW(pwm3_auto_point4_temp, temp, 0xA3, 0);
871
+
static SENSOR_DEVICE_ATTR_2_RW(pwm3_auto_point5_temp, temp, 0xA4, 0);
962
872
963
873
/* 7.2.138 Table 3 Y-axis Transition Point 1 Register */
964
-
static SENSOR_DEVICE_ATTR(pwm3_auto_point1_pwm, S_IRUGO | S_IWUSR,
965
-
show_pwm, store_pwm, 0xA5);
966
-
static SENSOR_DEVICE_ATTR(pwm3_auto_point2_pwm, S_IRUGO | S_IWUSR,
967
-
show_pwm, store_pwm, 0xA6);
968
-
static SENSOR_DEVICE_ATTR(pwm3_auto_point3_pwm, S_IRUGO | S_IWUSR,
969
-
show_pwm, store_pwm, 0xA7);
970
-
static SENSOR_DEVICE_ATTR(pwm3_auto_point4_pwm, S_IRUGO | S_IWUSR,
971
-
show_pwm, store_pwm, 0xA8);
972
-
static SENSOR_DEVICE_ATTR(pwm3_auto_point5_pwm, S_IRUGO, show_pwm, NULL, 0);
874
+
static SENSOR_DEVICE_ATTR_RW(pwm3_auto_point1_pwm, pwm, 0xA5);
875
+
static SENSOR_DEVICE_ATTR_RW(pwm3_auto_point2_pwm, pwm, 0xA6);
876
+
static SENSOR_DEVICE_ATTR_RW(pwm3_auto_point3_pwm, pwm, 0xA7);
877
+
static SENSOR_DEVICE_ATTR_RW(pwm3_auto_point4_pwm, pwm, 0xA8);
878
+
static SENSOR_DEVICE_ATTR_RO(pwm3_auto_point5_pwm, pwm, 0);
973
879
974
880
static struct attribute *nct7802_auto_point_attrs[] = {
975
881
&sensor_dev_attr_pwm1_auto_point1_temp.dev_attr.attr,
976
882
&sensor_dev_attr_pwm1_auto_point2_temp.dev_attr.attr,
977
883
&sensor_dev_attr_pwm1_auto_point3_temp.dev_attr.attr,
978
884
&sensor_dev_attr_pwm1_auto_point4_temp.dev_attr.attr,
979
885
&sensor_dev_attr_pwm1_auto_point5_temp.dev_attr.attr,
980
886
981
887
&sensor_dev_attr_pwm1_auto_point1_pwm.dev_attr.attr,
982
888
&sensor_dev_attr_pwm1_auto_point2_pwm.dev_attr.attr,