blob: cb26d02f52f3786bfb99723539347cad5905ca4f [file] [log] [blame]
Thomas Gleixner74ba9202019-05-20 09:19:02 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Yani Ioannou0a3e7ee2005-05-17 22:59:05 -04002/*
Jean Delvare10c08f82005-06-06 19:34:45 +02003 * hwmon-sysfs.h - hardware monitoring chip driver sysfs defines
Yani Ioannou0a3e7ee2005-05-17 22:59:05 -04004 *
5 * Copyright (C) 2005 Yani Ioannou <yani.ioannou@gmail.com>
Yani Ioannou0a3e7ee2005-05-17 22:59:05 -04006 */
Jean Delvare10c08f82005-06-06 19:34:45 +02007#ifndef _LINUX_HWMON_SYSFS_H
8#define _LINUX_HWMON_SYSFS_H
Yani Ioannou0a3e7ee2005-05-17 22:59:05 -04009
Paul Gortmaker313162d2012-01-30 11:46:54 -050010#include <linux/device.h>
11
Yani Ioannou0a3e7ee2005-05-17 22:59:05 -040012struct sensor_device_attribute{
13 struct device_attribute dev_attr;
14 int index;
15};
16#define to_sensor_dev_attr(_dev_attr) \
17 container_of(_dev_attr, struct sensor_device_attribute, dev_attr)
18
Jim Cromie42d3b83f2006-01-09 23:22:24 +010019#define SENSOR_ATTR(_name, _mode, _show, _store, _index) \
20 { .dev_attr = __ATTR(_name, _mode, _show, _store), \
21 .index = _index }
22
Guenter Roecka5c47c02016-12-27 15:28:19 -080023#define SENSOR_ATTR_RO(_name, _func, _index) \
24 SENSOR_ATTR(_name, 0444, _func##_show, NULL, _index)
25
26#define SENSOR_ATTR_RW(_name, _func, _index) \
27 SENSOR_ATTR(_name, 0644, _func##_show, _func##_store, _index)
28
29#define SENSOR_ATTR_WO(_name, _func, _index) \
30 SENSOR_ATTR(_name, 0200, NULL, _func##_store, _index)
31
Jim Cromie42d3b83f2006-01-09 23:22:24 +010032#define SENSOR_DEVICE_ATTR(_name, _mode, _show, _store, _index) \
33struct sensor_device_attribute sensor_dev_attr_##_name \
34 = SENSOR_ATTR(_name, _mode, _show, _store, _index)
Yani Ioannou0a3e7ee2005-05-17 22:59:05 -040035
Guenter Roecka5c47c02016-12-27 15:28:19 -080036#define SENSOR_DEVICE_ATTR_RO(_name, _func, _index) \
37 SENSOR_DEVICE_ATTR(_name, 0444, _func##_show, NULL, _index)
38
39#define SENSOR_DEVICE_ATTR_RW(_name, _func, _index) \
40 SENSOR_DEVICE_ATTR(_name, 0644, _func##_show, _func##_store, _index)
41
42#define SENSOR_DEVICE_ATTR_WO(_name, _func, _index) \
43 SENSOR_DEVICE_ATTR(_name, 0200, NULL, _func##_store, _index)
44
R.Marek@sh.cvut.cz5563e272005-07-27 11:43:47 +000045struct sensor_device_attribute_2 {
46 struct device_attribute dev_attr;
47 u8 index;
48 u8 nr;
49};
50#define to_sensor_dev_attr_2(_dev_attr) \
51 container_of(_dev_attr, struct sensor_device_attribute_2, dev_attr)
52
Jim Cromie70adca52006-01-18 23:10:49 +010053#define SENSOR_ATTR_2(_name, _mode, _show, _store, _nr, _index) \
54 { .dev_attr = __ATTR(_name, _mode, _show, _store), \
55 .index = _index, \
56 .nr = _nr }
57
Guenter Roecka5c47c02016-12-27 15:28:19 -080058#define SENSOR_ATTR_2_RO(_name, _func, _nr, _index) \
59 SENSOR_ATTR_2(_name, 0444, _func##_show, NULL, _nr, _index)
60
61#define SENSOR_ATTR_2_RW(_name, _func, _nr, _index) \
62 SENSOR_ATTR_2(_name, 0644, _func##_show, _func##_store, _nr, _index)
63
64#define SENSOR_ATTR_2_WO(_name, _func, _nr, _index) \
65 SENSOR_ATTR_2(_name, 0200, NULL, _func##_store, _nr, _index)
66
R.Marek@sh.cvut.cz5563e272005-07-27 11:43:47 +000067#define SENSOR_DEVICE_ATTR_2(_name,_mode,_show,_store,_nr,_index) \
Jim Cromie70adca52006-01-18 23:10:49 +010068struct sensor_device_attribute_2 sensor_dev_attr_##_name \
69 = SENSOR_ATTR_2(_name, _mode, _show, _store, _nr, _index)
R.Marek@sh.cvut.cz5563e272005-07-27 11:43:47 +000070
Guenter Roecka5c47c02016-12-27 15:28:19 -080071#define SENSOR_DEVICE_ATTR_2_RO(_name, _func, _nr, _index) \
72 SENSOR_DEVICE_ATTR_2(_name, 0444, _func##_show, NULL, \
73 _nr, _index)
74
75#define SENSOR_DEVICE_ATTR_2_RW(_name, _func, _nr, _index) \
76 SENSOR_DEVICE_ATTR_2(_name, 0644, _func##_show, _func##_store, \
77 _nr, _index)
78
79#define SENSOR_DEVICE_ATTR_2_WO(_name, _func, _nr, _index) \
80 SENSOR_DEVICE_ATTR_2(_name, 0200, NULL, _func##_store, \
81 _nr, _index)
82
Jean Delvare10c08f82005-06-06 19:34:45 +020083#endif /* _LINUX_HWMON_SYSFS_H */