sysdev: Pass the attribute to the low level sysdev show/store function

This allow to dynamically generate attributes and share show/store
functions between attributes. Right now most attributes are generated
by special macros and lots of duplicated code. With the attribute
passed it's instead possible to attach some data to the attribute
and then use that in shared low level functions to do different things.

I need this for the dynamically generated bank attributes in the x86
machine check code, but it'll allow some further cleanups.

I converted all users in tree to the new show/store prototype. It's a single
huge patch to avoid unbisectable sections.

Runtime tested: x86-32, x86-64
Compiled only: ia64, powerpc
Not compile tested/only grep converted: sh, arm, avr32

Signed-off-by: Andi Kleen <ak@linux.intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
Andi Kleen 2008-07-01 18:48:41 +02:00 committed by Greg Kroah-Hartman
parent 36ce6dad6e
commit 4a0b2b4dbe
24 changed files with 239 additions and 112 deletions

View file

@ -130,7 +130,9 @@ static const struct leds_evt_name evt_names[] = {
{ "red", led_red_on, led_red_off }, { "red", led_red_on, led_red_off },
}; };
static ssize_t leds_store(struct sys_device *dev, const char *buf, size_t size) static ssize_t leds_store(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t size)
{ {
int ret = -EINVAL, len = strcspn(buf, " "); int ret = -EINVAL, len = strcspn(buf, " ");

View file

@ -26,14 +26,16 @@ static DEFINE_PER_CPU(struct cpu, cpu_devices);
* XXX: If/when a SMP-capable implementation of AVR32 will ever be * XXX: If/when a SMP-capable implementation of AVR32 will ever be
* made, we must make sure that the code executes on the correct CPU. * made, we must make sure that the code executes on the correct CPU.
*/ */
static ssize_t show_pc0event(struct sys_device *dev, char *buf) static ssize_t show_pc0event(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
unsigned long pccr; unsigned long pccr;
pccr = sysreg_read(PCCR); pccr = sysreg_read(PCCR);
return sprintf(buf, "0x%lx\n", (pccr >> 12) & 0x3f); return sprintf(buf, "0x%lx\n", (pccr >> 12) & 0x3f);
} }
static ssize_t store_pc0event(struct sys_device *dev, const char *buf, static ssize_t store_pc0event(struct sys_device *dev,
struct sysdev_attribute *attr, const char *buf,
size_t count) size_t count)
{ {
unsigned long val; unsigned long val;
@ -46,15 +48,17 @@ static ssize_t store_pc0event(struct sys_device *dev, const char *buf,
sysreg_write(PCCR, val); sysreg_write(PCCR, val);
return count; return count;
} }
static ssize_t show_pc0count(struct sys_device *dev, char *buf) static ssize_t show_pc0count(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
unsigned long pcnt0; unsigned long pcnt0;
pcnt0 = sysreg_read(PCNT0); pcnt0 = sysreg_read(PCNT0);
return sprintf(buf, "%lu\n", pcnt0); return sprintf(buf, "%lu\n", pcnt0);
} }
static ssize_t store_pc0count(struct sys_device *dev, const char *buf, static ssize_t store_pc0count(struct sys_device *dev,
size_t count) struct sysdev_attribute *attr,
const char *buf, size_t count)
{ {
unsigned long val; unsigned long val;
char *endp; char *endp;
@ -67,14 +71,16 @@ static ssize_t store_pc0count(struct sys_device *dev, const char *buf,
return count; return count;
} }
static ssize_t show_pc1event(struct sys_device *dev, char *buf) static ssize_t show_pc1event(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
unsigned long pccr; unsigned long pccr;
pccr = sysreg_read(PCCR); pccr = sysreg_read(PCCR);
return sprintf(buf, "0x%lx\n", (pccr >> 18) & 0x3f); return sprintf(buf, "0x%lx\n", (pccr >> 18) & 0x3f);
} }
static ssize_t store_pc1event(struct sys_device *dev, const char *buf, static ssize_t store_pc1event(struct sys_device *dev,
struct sysdev_attribute *attr, const char *buf,
size_t count) size_t count)
{ {
unsigned long val; unsigned long val;
@ -87,14 +93,16 @@ static ssize_t store_pc1event(struct sys_device *dev, const char *buf,
sysreg_write(PCCR, val); sysreg_write(PCCR, val);
return count; return count;
} }
static ssize_t show_pc1count(struct sys_device *dev, char *buf) static ssize_t show_pc1count(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
unsigned long pcnt1; unsigned long pcnt1;
pcnt1 = sysreg_read(PCNT1); pcnt1 = sysreg_read(PCNT1);
return sprintf(buf, "%lu\n", pcnt1); return sprintf(buf, "%lu\n", pcnt1);
} }
static ssize_t store_pc1count(struct sys_device *dev, const char *buf, static ssize_t store_pc1count(struct sys_device *dev,
struct sysdev_attribute *attr, const char *buf,
size_t count) size_t count)
{ {
unsigned long val; unsigned long val;
@ -108,14 +116,16 @@ static ssize_t store_pc1count(struct sys_device *dev, const char *buf,
return count; return count;
} }
static ssize_t show_pccycles(struct sys_device *dev, char *buf) static ssize_t show_pccycles(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
unsigned long pccnt; unsigned long pccnt;
pccnt = sysreg_read(PCCNT); pccnt = sysreg_read(PCCNT);
return sprintf(buf, "%lu\n", pccnt); return sprintf(buf, "%lu\n", pccnt);
} }
static ssize_t store_pccycles(struct sys_device *dev, const char *buf, static ssize_t store_pccycles(struct sys_device *dev,
struct sysdev_attribute *attr, const char *buf,
size_t count) size_t count)
{ {
unsigned long val; unsigned long val;
@ -129,14 +139,16 @@ static ssize_t store_pccycles(struct sys_device *dev, const char *buf,
return count; return count;
} }
static ssize_t show_pcenable(struct sys_device *dev, char *buf) static ssize_t show_pcenable(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
unsigned long pccr; unsigned long pccr;
pccr = sysreg_read(PCCR); pccr = sysreg_read(PCCR);
return sprintf(buf, "%c\n", (pccr & 1)?'1':'0'); return sprintf(buf, "%c\n", (pccr & 1)?'1':'0');
} }
static ssize_t store_pcenable(struct sys_device *dev, const char *buf, static ssize_t store_pcenable(struct sys_device *dev,
struct sysdev_attribute *attr, const char *buf,
size_t count) size_t count)
{ {
unsigned long pccr, val; unsigned long pccr, val;

View file

@ -55,7 +55,8 @@ static u64 resources[NR_CPUS];
#define show(name) \ #define show(name) \
static ssize_t \ static ssize_t \
show_##name(struct sys_device *dev, char *buf) \ show_##name(struct sys_device *dev, struct sysdev_attribute *attr, \
char *buf) \
{ \ { \
u32 cpu=dev->id; \ u32 cpu=dev->id; \
return sprintf(buf, "%lx\n", name[cpu]); \ return sprintf(buf, "%lx\n", name[cpu]); \
@ -63,7 +64,8 @@ show_##name(struct sys_device *dev, char *buf) \
#define store(name) \ #define store(name) \
static ssize_t \ static ssize_t \
store_##name(struct sys_device *dev, const char *buf, size_t size) \ store_##name(struct sys_device *dev, struct sysdev_attribute *attr, \
const char *buf, size_t size) \
{ \ { \
unsigned int cpu=dev->id; \ unsigned int cpu=dev->id; \
name[cpu] = simple_strtoull(buf, NULL, 16); \ name[cpu] = simple_strtoull(buf, NULL, 16); \
@ -76,7 +78,8 @@ show(call_start)
* processor. The cpu number in driver is only used for storing data. * processor. The cpu number in driver is only used for storing data.
*/ */
static ssize_t static ssize_t
store_call_start(struct sys_device *dev, const char *buf, size_t size) store_call_start(struct sys_device *dev, struct sysdev_attribute *attr,
const char *buf, size_t size)
{ {
unsigned int cpu=dev->id; unsigned int cpu=dev->id;
unsigned long call_start = simple_strtoull(buf, NULL, 16); unsigned long call_start = simple_strtoull(buf, NULL, 16);
@ -124,14 +127,16 @@ show(err_type_info)
store(err_type_info) store(err_type_info)
static ssize_t static ssize_t
show_virtual_to_phys(struct sys_device *dev, char *buf) show_virtual_to_phys(struct sys_device *dev, struct sysdev_attribute *attr,
char *buf)
{ {
unsigned int cpu=dev->id; unsigned int cpu=dev->id;
return sprintf(buf, "%lx\n", phys_addr[cpu]); return sprintf(buf, "%lx\n", phys_addr[cpu]);
} }
static ssize_t static ssize_t
store_virtual_to_phys(struct sys_device *dev, const char *buf, size_t size) store_virtual_to_phys(struct sys_device *dev, struct sysdev_attribute *attr,
const char *buf, size_t size)
{ {
unsigned int cpu=dev->id; unsigned int cpu=dev->id;
u64 virt_addr=simple_strtoull(buf, NULL, 16); u64 virt_addr=simple_strtoull(buf, NULL, 16);
@ -154,7 +159,8 @@ show(err_struct_info)
store(err_struct_info) store(err_struct_info)
static ssize_t static ssize_t
show_err_data_buffer(struct sys_device *dev, char *buf) show_err_data_buffer(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
unsigned int cpu=dev->id; unsigned int cpu=dev->id;
@ -165,7 +171,9 @@ show_err_data_buffer(struct sys_device *dev, char *buf)
} }
static ssize_t static ssize_t
store_err_data_buffer(struct sys_device *dev, const char *buf, size_t size) store_err_data_buffer(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t size)
{ {
unsigned int cpu=dev->id; unsigned int cpu=dev->id;
int ret; int ret;

View file

@ -28,7 +28,9 @@ static DEFINE_PER_CPU(struct cpu, cpu_devices);
/* Time in microseconds we delay before sleeping in the idle loop */ /* Time in microseconds we delay before sleeping in the idle loop */
DEFINE_PER_CPU(unsigned long, smt_snooze_delay) = { 100 }; DEFINE_PER_CPU(unsigned long, smt_snooze_delay) = { 100 };
static ssize_t store_smt_snooze_delay(struct sys_device *dev, const char *buf, static ssize_t store_smt_snooze_delay(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf,
size_t count) size_t count)
{ {
struct cpu *cpu = container_of(dev, struct cpu, sysdev); struct cpu *cpu = container_of(dev, struct cpu, sysdev);
@ -44,7 +46,9 @@ static ssize_t store_smt_snooze_delay(struct sys_device *dev, const char *buf,
return count; return count;
} }
static ssize_t show_smt_snooze_delay(struct sys_device *dev, char *buf) static ssize_t show_smt_snooze_delay(struct sys_device *dev,
struct sysdev_attribute *attr,
char *buf)
{ {
struct cpu *cpu = container_of(dev, struct cpu, sysdev); struct cpu *cpu = container_of(dev, struct cpu, sysdev);
@ -152,14 +156,17 @@ static unsigned long write_##NAME(unsigned long val) \
mtspr(ADDRESS, val); \ mtspr(ADDRESS, val); \
return 0; \ return 0; \
} \ } \
static ssize_t show_##NAME(struct sys_device *dev, char *buf) \ static ssize_t show_##NAME(struct sys_device *dev, \
struct sysdev_attribute *attr, \
char *buf) \
{ \ { \
struct cpu *cpu = container_of(dev, struct cpu, sysdev); \ struct cpu *cpu = container_of(dev, struct cpu, sysdev); \
unsigned long val = run_on_cpu(cpu->sysdev.id, read_##NAME, 0); \ unsigned long val = run_on_cpu(cpu->sysdev.id, read_##NAME, 0); \
return sprintf(buf, "%lx\n", val); \ return sprintf(buf, "%lx\n", val); \
} \ } \
static ssize_t __used \ static ssize_t __used \
store_##NAME(struct sys_device *dev, const char *buf, size_t count) \ store_##NAME(struct sys_device *dev, struct sysdev_attribute *attr, \
const char *buf, size_t count) \
{ \ { \
struct cpu *cpu = container_of(dev, struct cpu, sysdev); \ struct cpu *cpu = container_of(dev, struct cpu, sysdev); \
unsigned long val; \ unsigned long val; \

View file

@ -97,7 +97,8 @@ static u8 spu_read_register_value(struct sys_device *sysdev, union spe_reg __iom
return value.spe[spu->spe_id]; return value.spe[spu->spe_id];
} }
static ssize_t spu_show_temp(struct sys_device *sysdev, char *buf) static ssize_t spu_show_temp(struct sys_device *sysdev, struct sysdev_attribute *attr,
char *buf)
{ {
u8 value; u8 value;
struct cbe_pmd_regs __iomem *pmd_regs; struct cbe_pmd_regs __iomem *pmd_regs;
@ -146,32 +147,38 @@ static ssize_t store_throttle(struct cbe_pmd_regs __iomem *pmd_regs, const char
return size; return size;
} }
static ssize_t spu_show_throttle_end(struct sys_device *sysdev, char *buf) static ssize_t spu_show_throttle_end(struct sys_device *sysdev,
struct sysdev_attribute *attr, char *buf)
{ {
return show_throttle(get_pmd_regs(sysdev), buf, 0); return show_throttle(get_pmd_regs(sysdev), buf, 0);
} }
static ssize_t spu_show_throttle_begin(struct sys_device *sysdev, char *buf) static ssize_t spu_show_throttle_begin(struct sys_device *sysdev,
struct sysdev_attribute *attr, char *buf)
{ {
return show_throttle(get_pmd_regs(sysdev), buf, 8); return show_throttle(get_pmd_regs(sysdev), buf, 8);
} }
static ssize_t spu_show_throttle_full_stop(struct sys_device *sysdev, char *buf) static ssize_t spu_show_throttle_full_stop(struct sys_device *sysdev,
struct sysdev_attribute *attr, char *buf)
{ {
return show_throttle(get_pmd_regs(sysdev), buf, 16); return show_throttle(get_pmd_regs(sysdev), buf, 16);
} }
static ssize_t spu_store_throttle_end(struct sys_device *sysdev, const char *buf, size_t size) static ssize_t spu_store_throttle_end(struct sys_device *sysdev,
struct sysdev_attribute *attr, const char *buf, size_t size)
{ {
return store_throttle(get_pmd_regs(sysdev), buf, size, 0); return store_throttle(get_pmd_regs(sysdev), buf, size, 0);
} }
static ssize_t spu_store_throttle_begin(struct sys_device *sysdev, const char *buf, size_t size) static ssize_t spu_store_throttle_begin(struct sys_device *sysdev,
struct sysdev_attribute *attr, const char *buf, size_t size)
{ {
return store_throttle(get_pmd_regs(sysdev), buf, size, 8); return store_throttle(get_pmd_regs(sysdev), buf, size, 8);
} }
static ssize_t spu_store_throttle_full_stop(struct sys_device *sysdev, const char *buf, size_t size) static ssize_t spu_store_throttle_full_stop(struct sys_device *sysdev,
struct sysdev_attribute *attr, const char *buf, size_t size)
{ {
return store_throttle(get_pmd_regs(sysdev), buf, size, 16); return store_throttle(get_pmd_regs(sysdev), buf, size, 16);
} }
@ -192,43 +199,51 @@ static ssize_t ppe_show_temp(struct sys_device *sysdev, char *buf, int pos)
/* shows the temperature of the DTS on the PPE, /* shows the temperature of the DTS on the PPE,
* located near the linear thermal sensor */ * located near the linear thermal sensor */
static ssize_t ppe_show_temp0(struct sys_device *sysdev, char *buf) static ssize_t ppe_show_temp0(struct sys_device *sysdev,
struct sysdev_attribute *attr, char *buf)
{ {
return ppe_show_temp(sysdev, buf, 32); return ppe_show_temp(sysdev, buf, 32);
} }
/* shows the temperature of the second DTS on the PPE */ /* shows the temperature of the second DTS on the PPE */
static ssize_t ppe_show_temp1(struct sys_device *sysdev, char *buf) static ssize_t ppe_show_temp1(struct sys_device *sysdev,
struct sysdev_attribute *attr, char *buf)
{ {
return ppe_show_temp(sysdev, buf, 0); return ppe_show_temp(sysdev, buf, 0);
} }
static ssize_t ppe_show_throttle_end(struct sys_device *sysdev, char *buf) static ssize_t ppe_show_throttle_end(struct sys_device *sysdev,
struct sysdev_attribute *attr, char *buf)
{ {
return show_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, 32); return show_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, 32);
} }
static ssize_t ppe_show_throttle_begin(struct sys_device *sysdev, char *buf) static ssize_t ppe_show_throttle_begin(struct sys_device *sysdev,
struct sysdev_attribute *attr, char *buf)
{ {
return show_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, 40); return show_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, 40);
} }
static ssize_t ppe_show_throttle_full_stop(struct sys_device *sysdev, char *buf) static ssize_t ppe_show_throttle_full_stop(struct sys_device *sysdev,
struct sysdev_attribute *attr, char *buf)
{ {
return show_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, 48); return show_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, 48);
} }
static ssize_t ppe_store_throttle_end(struct sys_device *sysdev, const char *buf, size_t size) static ssize_t ppe_store_throttle_end(struct sys_device *sysdev,
struct sysdev_attribute *attr, const char *buf, size_t size)
{ {
return store_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, size, 32); return store_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, size, 32);
} }
static ssize_t ppe_store_throttle_begin(struct sys_device *sysdev, const char *buf, size_t size) static ssize_t ppe_store_throttle_begin(struct sys_device *sysdev,
struct sysdev_attribute *attr, const char *buf, size_t size)
{ {
return store_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, size, 40); return store_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, size, 40);
} }
static ssize_t ppe_store_throttle_full_stop(struct sys_device *sysdev, const char *buf, size_t size) static ssize_t ppe_store_throttle_full_stop(struct sys_device *sysdev,
struct sysdev_attribute *attr, const char *buf, size_t size)
{ {
return store_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, size, 48); return store_throttle(cbe_get_cpu_pmd_regs(sysdev->id), buf, size, 48);
} }

View file

@ -703,7 +703,8 @@ static unsigned long long spu_acct_time(struct spu *spu,
} }
static ssize_t spu_stat_show(struct sys_device *sysdev, char *buf) static ssize_t spu_stat_show(struct sys_device *sysdev,
struct sysdev_attribute *attr, char *buf)
{ {
struct spu *spu = container_of(sysdev, struct spu, sysdev); struct spu *spu = container_of(sysdev, struct spu, sysdev);

View file

@ -864,7 +864,8 @@ int setup_profiling_timer(unsigned int multiplier)
} }
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
static ssize_t cpu_configure_show(struct sys_device *dev, char *buf) static ssize_t cpu_configure_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
ssize_t count; ssize_t count;
@ -874,8 +875,9 @@ static ssize_t cpu_configure_show(struct sys_device *dev, char *buf)
return count; return count;
} }
static ssize_t cpu_configure_store(struct sys_device *dev, const char *buf, static ssize_t cpu_configure_store(struct sys_device *dev,
size_t count) struct sysdev_attribute *attr,
const char *buf, size_t count)
{ {
int cpu = dev->id; int cpu = dev->id;
int val, rc; int val, rc;
@ -922,7 +924,8 @@ out:
static SYSDEV_ATTR(configure, 0644, cpu_configure_show, cpu_configure_store); static SYSDEV_ATTR(configure, 0644, cpu_configure_show, cpu_configure_store);
#endif /* CONFIG_HOTPLUG_CPU */ #endif /* CONFIG_HOTPLUG_CPU */
static ssize_t cpu_polarization_show(struct sys_device *dev, char *buf) static ssize_t cpu_polarization_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
int cpu = dev->id; int cpu = dev->id;
ssize_t count; ssize_t count;
@ -950,7 +953,8 @@ static ssize_t cpu_polarization_show(struct sys_device *dev, char *buf)
} }
static SYSDEV_ATTR(polarization, 0444, cpu_polarization_show, NULL); static SYSDEV_ATTR(polarization, 0444, cpu_polarization_show, NULL);
static ssize_t show_cpu_address(struct sys_device *dev, char *buf) static ssize_t show_cpu_address(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
return sprintf(buf, "%d\n", __cpu_logical_map[dev->id]); return sprintf(buf, "%d\n", __cpu_logical_map[dev->id]);
} }
@ -970,7 +974,8 @@ static struct attribute_group cpu_common_attr_group = {
.attrs = cpu_common_attrs, .attrs = cpu_common_attrs,
}; };
static ssize_t show_capability(struct sys_device *dev, char *buf) static ssize_t show_capability(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
unsigned int capability; unsigned int capability;
int rc; int rc;
@ -982,7 +987,8 @@ static ssize_t show_capability(struct sys_device *dev, char *buf)
} }
static SYSDEV_ATTR(capability, 0444, show_capability, NULL); static SYSDEV_ATTR(capability, 0444, show_capability, NULL);
static ssize_t show_idle_count(struct sys_device *dev, char *buf) static ssize_t show_idle_count(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct s390_idle_data *idle; struct s390_idle_data *idle;
unsigned long long idle_count; unsigned long long idle_count;
@ -995,7 +1001,8 @@ static ssize_t show_idle_count(struct sys_device *dev, char *buf)
} }
static SYSDEV_ATTR(idle_count, 0444, show_idle_count, NULL); static SYSDEV_ATTR(idle_count, 0444, show_idle_count, NULL);
static ssize_t show_idle_time(struct sys_device *dev, char *buf) static ssize_t show_idle_time(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct s390_idle_data *idle; struct s390_idle_data *idle;
unsigned long long new_time; unsigned long long new_time;
@ -1112,7 +1119,9 @@ out:
return rc; return rc;
} }
static ssize_t __ref rescan_store(struct sys_device *dev, const char *buf, static ssize_t __ref rescan_store(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf,
size_t count) size_t count)
{ {
int rc; int rc;
@ -1123,7 +1132,9 @@ static ssize_t __ref rescan_store(struct sys_device *dev, const char *buf,
static SYSDEV_ATTR(rescan, 0200, NULL, rescan_store); static SYSDEV_ATTR(rescan, 0200, NULL, rescan_store);
#endif /* CONFIG_HOTPLUG_CPU */ #endif /* CONFIG_HOTPLUG_CPU */
static ssize_t dispatching_show(struct sys_device *dev, char *buf) static ssize_t dispatching_show(struct sys_device *dev,
struct sysdev_attribute *attr,
char *buf)
{ {
ssize_t count; ssize_t count;
@ -1133,8 +1144,9 @@ static ssize_t dispatching_show(struct sys_device *dev, char *buf)
return count; return count;
} }
static ssize_t dispatching_store(struct sys_device *dev, const char *buf, static ssize_t dispatching_store(struct sys_device *dev,
size_t count) struct sysdev_attribute *attr,
const char *buf, size_t count)
{ {
int val, rc; int val, rc;
char delim; char delim;

View file

@ -1100,7 +1100,9 @@ static inline struct etr_aib *etr_aib_from_dev(struct sys_device *dev)
return etr_port1_online ? &etr_port1 : NULL; return etr_port1_online ? &etr_port1 : NULL;
} }
static ssize_t etr_online_show(struct sys_device *dev, char *buf) static ssize_t etr_online_show(struct sys_device *dev,
struct sysdev_attribute *attr,
char *buf)
{ {
unsigned int online; unsigned int online;
@ -1109,7 +1111,8 @@ static ssize_t etr_online_show(struct sys_device *dev, char *buf)
} }
static ssize_t etr_online_store(struct sys_device *dev, static ssize_t etr_online_store(struct sys_device *dev,
const char *buf, size_t count) struct sysdev_attribute *attr,
const char *buf, size_t count)
{ {
unsigned int value; unsigned int value;
@ -1136,7 +1139,9 @@ static ssize_t etr_online_store(struct sys_device *dev,
static SYSDEV_ATTR(online, 0600, etr_online_show, etr_online_store); static SYSDEV_ATTR(online, 0600, etr_online_show, etr_online_store);
static ssize_t etr_stepping_control_show(struct sys_device *dev, char *buf) static ssize_t etr_stepping_control_show(struct sys_device *dev,
struct sysdev_attribute *attr,
char *buf)
{ {
return sprintf(buf, "%i\n", (dev == &etr_port0_dev) ? return sprintf(buf, "%i\n", (dev == &etr_port0_dev) ?
etr_eacr.e0 : etr_eacr.e1); etr_eacr.e0 : etr_eacr.e1);
@ -1144,7 +1149,8 @@ static ssize_t etr_stepping_control_show(struct sys_device *dev, char *buf)
static SYSDEV_ATTR(stepping_control, 0400, etr_stepping_control_show, NULL); static SYSDEV_ATTR(stepping_control, 0400, etr_stepping_control_show, NULL);
static ssize_t etr_mode_code_show(struct sys_device *dev, char *buf) static ssize_t etr_mode_code_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
if (!etr_port0_online && !etr_port1_online) if (!etr_port0_online && !etr_port1_online)
/* Status word is not uptodate if both ports are offline. */ /* Status word is not uptodate if both ports are offline. */
@ -1155,7 +1161,8 @@ static ssize_t etr_mode_code_show(struct sys_device *dev, char *buf)
static SYSDEV_ATTR(state_code, 0400, etr_mode_code_show, NULL); static SYSDEV_ATTR(state_code, 0400, etr_mode_code_show, NULL);
static ssize_t etr_untuned_show(struct sys_device *dev, char *buf) static ssize_t etr_untuned_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct etr_aib *aib = etr_aib_from_dev(dev); struct etr_aib *aib = etr_aib_from_dev(dev);
@ -1166,7 +1173,8 @@ static ssize_t etr_untuned_show(struct sys_device *dev, char *buf)
static SYSDEV_ATTR(untuned, 0400, etr_untuned_show, NULL); static SYSDEV_ATTR(untuned, 0400, etr_untuned_show, NULL);
static ssize_t etr_network_id_show(struct sys_device *dev, char *buf) static ssize_t etr_network_id_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct etr_aib *aib = etr_aib_from_dev(dev); struct etr_aib *aib = etr_aib_from_dev(dev);
@ -1177,7 +1185,8 @@ static ssize_t etr_network_id_show(struct sys_device *dev, char *buf)
static SYSDEV_ATTR(network, 0400, etr_network_id_show, NULL); static SYSDEV_ATTR(network, 0400, etr_network_id_show, NULL);
static ssize_t etr_id_show(struct sys_device *dev, char *buf) static ssize_t etr_id_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct etr_aib *aib = etr_aib_from_dev(dev); struct etr_aib *aib = etr_aib_from_dev(dev);
@ -1188,7 +1197,8 @@ static ssize_t etr_id_show(struct sys_device *dev, char *buf)
static SYSDEV_ATTR(id, 0400, etr_id_show, NULL); static SYSDEV_ATTR(id, 0400, etr_id_show, NULL);
static ssize_t etr_port_number_show(struct sys_device *dev, char *buf) static ssize_t etr_port_number_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct etr_aib *aib = etr_aib_from_dev(dev); struct etr_aib *aib = etr_aib_from_dev(dev);
@ -1199,7 +1209,8 @@ static ssize_t etr_port_number_show(struct sys_device *dev, char *buf)
static SYSDEV_ATTR(port, 0400, etr_port_number_show, NULL); static SYSDEV_ATTR(port, 0400, etr_port_number_show, NULL);
static ssize_t etr_coupled_show(struct sys_device *dev, char *buf) static ssize_t etr_coupled_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct etr_aib *aib = etr_aib_from_dev(dev); struct etr_aib *aib = etr_aib_from_dev(dev);
@ -1210,7 +1221,8 @@ static ssize_t etr_coupled_show(struct sys_device *dev, char *buf)
static SYSDEV_ATTR(coupled, 0400, etr_coupled_show, NULL); static SYSDEV_ATTR(coupled, 0400, etr_coupled_show, NULL);
static ssize_t etr_local_time_show(struct sys_device *dev, char *buf) static ssize_t etr_local_time_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct etr_aib *aib = etr_aib_from_dev(dev); struct etr_aib *aib = etr_aib_from_dev(dev);
@ -1221,7 +1233,8 @@ static ssize_t etr_local_time_show(struct sys_device *dev, char *buf)
static SYSDEV_ATTR(local_time, 0400, etr_local_time_show, NULL); static SYSDEV_ATTR(local_time, 0400, etr_local_time_show, NULL);
static ssize_t etr_utc_offset_show(struct sys_device *dev, char *buf) static ssize_t etr_utc_offset_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct etr_aib *aib = etr_aib_from_dev(dev); struct etr_aib *aib = etr_aib_from_dev(dev);

View file

@ -23,7 +23,8 @@ static struct sysdev_class dma_sysclass = {
}; };
EXPORT_SYMBOL(dma_sysclass); EXPORT_SYMBOL(dma_sysclass);
static ssize_t dma_show_devices(struct sys_device *dev, char *buf) static ssize_t dma_show_devices(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
ssize_t len = 0; ssize_t len = 0;
int i; int i;
@ -57,13 +58,15 @@ static int __init dma_sysclass_init(void)
} }
postcore_initcall(dma_sysclass_init); postcore_initcall(dma_sysclass_init);
static ssize_t dma_show_dev_id(struct sys_device *dev, char *buf) static ssize_t dma_show_dev_id(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct dma_channel *channel = to_dma_channel(dev); struct dma_channel *channel = to_dma_channel(dev);
return sprintf(buf, "%s\n", channel->dev_id); return sprintf(buf, "%s\n", channel->dev_id);
} }
static ssize_t dma_store_dev_id(struct sys_device *dev, static ssize_t dma_store_dev_id(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t count) const char *buf, size_t count)
{ {
struct dma_channel *channel = to_dma_channel(dev); struct dma_channel *channel = to_dma_channel(dev);
@ -74,6 +77,7 @@ static ssize_t dma_store_dev_id(struct sys_device *dev,
static SYSDEV_ATTR(dev_id, S_IRUGO | S_IWUSR, dma_show_dev_id, dma_store_dev_id); static SYSDEV_ATTR(dev_id, S_IRUGO | S_IWUSR, dma_show_dev_id, dma_store_dev_id);
static ssize_t dma_store_config(struct sys_device *dev, static ssize_t dma_store_config(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t count) const char *buf, size_t count)
{ {
struct dma_channel *channel = to_dma_channel(dev); struct dma_channel *channel = to_dma_channel(dev);
@ -87,13 +91,15 @@ static ssize_t dma_store_config(struct sys_device *dev,
static SYSDEV_ATTR(config, S_IWUSR, NULL, dma_store_config); static SYSDEV_ATTR(config, S_IWUSR, NULL, dma_store_config);
static ssize_t dma_show_mode(struct sys_device *dev, char *buf) static ssize_t dma_show_mode(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct dma_channel *channel = to_dma_channel(dev); struct dma_channel *channel = to_dma_channel(dev);
return sprintf(buf, "0x%08x\n", channel->mode); return sprintf(buf, "0x%08x\n", channel->mode);
} }
static ssize_t dma_store_mode(struct sys_device *dev, static ssize_t dma_store_mode(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t count) const char *buf, size_t count)
{ {
struct dma_channel *channel = to_dma_channel(dev); struct dma_channel *channel = to_dma_channel(dev);
@ -104,7 +110,8 @@ static ssize_t dma_store_mode(struct sys_device *dev,
static SYSDEV_ATTR(mode, S_IRUGO | S_IWUSR, dma_show_mode, dma_store_mode); static SYSDEV_ATTR(mode, S_IRUGO | S_IWUSR, dma_show_mode, dma_store_mode);
#define dma_ro_attr(field, fmt) \ #define dma_ro_attr(field, fmt) \
static ssize_t dma_show_##field(struct sys_device *dev, char *buf) \ static ssize_t dma_show_##field(struct sys_device *dev, \
struct sysdev_attribute *attr, char *buf)\
{ \ { \
struct dma_channel *channel = to_dma_channel(dev); \ struct dma_channel *channel = to_dma_channel(dev); \
return sprintf(buf, fmt, channel->field); \ return sprintf(buf, fmt, channel->field); \

View file

@ -14,7 +14,8 @@
static DEFINE_PER_CPU(struct hv_mmu_statistics, mmu_stats) __attribute__((aligned(64))); static DEFINE_PER_CPU(struct hv_mmu_statistics, mmu_stats) __attribute__((aligned(64)));
#define SHOW_MMUSTAT_ULONG(NAME) \ #define SHOW_MMUSTAT_ULONG(NAME) \
static ssize_t show_##NAME(struct sys_device *dev, char *buf) \ static ssize_t show_##NAME(struct sys_device *dev, \
struct sysdev_attribute *attr, char *buf) \
{ \ { \
struct hv_mmu_statistics *p = &per_cpu(mmu_stats, dev->id); \ struct hv_mmu_statistics *p = &per_cpu(mmu_stats, dev->id); \
return sprintf(buf, "%lu\n", p->NAME); \ return sprintf(buf, "%lu\n", p->NAME); \
@ -135,13 +136,16 @@ static unsigned long write_mmustat_enable(unsigned long val)
return sun4v_mmustat_conf(ra, &orig_ra); return sun4v_mmustat_conf(ra, &orig_ra);
} }
static ssize_t show_mmustat_enable(struct sys_device *s, char *buf) static ssize_t show_mmustat_enable(struct sys_device *s,
struct sysdev_attribute *attr, char *buf)
{ {
unsigned long val = run_on_cpu(s->id, read_mmustat_enable, 0); unsigned long val = run_on_cpu(s->id, read_mmustat_enable, 0);
return sprintf(buf, "%lx\n", val); return sprintf(buf, "%lx\n", val);
} }
static ssize_t store_mmustat_enable(struct sys_device *s, const char *buf, size_t count) static ssize_t store_mmustat_enable(struct sys_device *s,
struct sysdev_attribute *attr, const char *buf,
size_t count)
{ {
unsigned long val, err; unsigned long val, err;
int ret = sscanf(buf, "%ld", &val); int ret = sscanf(buf, "%ld", &val);
@ -179,14 +183,16 @@ static void unregister_mmu_stats(struct sys_device *s)
#endif #endif
#define SHOW_CPUDATA_ULONG_NAME(NAME, MEMBER) \ #define SHOW_CPUDATA_ULONG_NAME(NAME, MEMBER) \
static ssize_t show_##NAME(struct sys_device *dev, char *buf) \ static ssize_t show_##NAME(struct sys_device *dev, \
struct sysdev_attribute *attr, char *buf) \
{ \ { \
cpuinfo_sparc *c = &cpu_data(dev->id); \ cpuinfo_sparc *c = &cpu_data(dev->id); \
return sprintf(buf, "%lu\n", c->MEMBER); \ return sprintf(buf, "%lu\n", c->MEMBER); \
} }
#define SHOW_CPUDATA_UINT_NAME(NAME, MEMBER) \ #define SHOW_CPUDATA_UINT_NAME(NAME, MEMBER) \
static ssize_t show_##NAME(struct sys_device *dev, char *buf) \ static ssize_t show_##NAME(struct sys_device *dev, \
struct sysdev_attribute *attr, char *buf) \
{ \ { \
cpuinfo_sparc *c = &cpu_data(dev->id); \ cpuinfo_sparc *c = &cpu_data(dev->id); \
return sprintf(buf, "%u\n", c->MEMBER); \ return sprintf(buf, "%u\n", c->MEMBER); \

View file

@ -762,10 +762,14 @@ DEFINE_PER_CPU(struct sys_device, device_mce);
/* Why are there no generic functions for this? */ /* Why are there no generic functions for this? */
#define ACCESSOR(name, var, start) \ #define ACCESSOR(name, var, start) \
static ssize_t show_ ## name(struct sys_device *s, char *buf) { \ static ssize_t show_ ## name(struct sys_device *s, \
struct sysdev_attribute *attr, \
char *buf) { \
return sprintf(buf, "%lx\n", (unsigned long)var); \ return sprintf(buf, "%lx\n", (unsigned long)var); \
} \ } \
static ssize_t set_ ## name(struct sys_device *s,const char *buf,size_t siz) { \ static ssize_t set_ ## name(struct sys_device *s, \
struct sysdev_attribute *attr, \
const char *buf, size_t siz) { \
char *end; \ char *end; \
unsigned long new = simple_strtoul(buf, &end, 0); \ unsigned long new = simple_strtoul(buf, &end, 0); \
if (end == buf) return -EINVAL; \ if (end == buf) return -EINVAL; \
@ -786,14 +790,16 @@ ACCESSOR(bank3ctl,bank[3],mce_restart())
ACCESSOR(bank4ctl,bank[4],mce_restart()) ACCESSOR(bank4ctl,bank[4],mce_restart())
ACCESSOR(bank5ctl,bank[5],mce_restart()) ACCESSOR(bank5ctl,bank[5],mce_restart())
static ssize_t show_trigger(struct sys_device *s, char *buf) static ssize_t show_trigger(struct sys_device *s, struct sysdev_attribute *attr,
char *buf)
{ {
strcpy(buf, trigger); strcpy(buf, trigger);
strcat(buf, "\n"); strcat(buf, "\n");
return strlen(trigger) + 1; return strlen(trigger) + 1;
} }
static ssize_t set_trigger(struct sys_device *s,const char *buf,size_t siz) static ssize_t set_trigger(struct sys_device *s, struct sysdev_attribute *attr,
const char *buf,size_t siz)
{ {
char *p; char *p;
int len; int len;

View file

@ -35,6 +35,7 @@ atomic_t therm_throt_en = ATOMIC_INIT(0);
#define define_therm_throt_sysdev_show_func(name) \ #define define_therm_throt_sysdev_show_func(name) \
static ssize_t therm_throt_sysdev_show_##name(struct sys_device *dev, \ static ssize_t therm_throt_sysdev_show_##name(struct sys_device *dev, \
struct sysdev_attribute *attr, \
char *buf) \ char *buf) \
{ \ { \
unsigned int cpu = dev->id; \ unsigned int cpu = dev->id; \

View file

@ -644,7 +644,9 @@ static void microcode_fini_cpu(int cpu)
mutex_unlock(&microcode_mutex); mutex_unlock(&microcode_mutex);
} }
static ssize_t reload_store(struct sys_device *dev, const char *buf, size_t sz) static ssize_t reload_store(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t sz)
{ {
struct ucode_cpu_info *uci = ucode_cpu_info + dev->id; struct ucode_cpu_info *uci = ucode_cpu_info + dev->id;
char *end; char *end;
@ -674,14 +676,16 @@ static ssize_t reload_store(struct sys_device *dev, const char *buf, size_t sz)
return sz; return sz;
} }
static ssize_t version_show(struct sys_device *dev, char *buf) static ssize_t version_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct ucode_cpu_info *uci = ucode_cpu_info + dev->id; struct ucode_cpu_info *uci = ucode_cpu_info + dev->id;
return sprintf(buf, "0x%x\n", uci->rev); return sprintf(buf, "0x%x\n", uci->rev);
} }
static ssize_t pf_show(struct sys_device *dev, char *buf) static ssize_t pf_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct ucode_cpu_info *uci = ucode_cpu_info + dev->id; struct ucode_cpu_info *uci = ucode_cpu_info + dev->id;

View file

@ -21,15 +21,16 @@ EXPORT_SYMBOL(cpu_sysdev_class);
static DEFINE_PER_CPU(struct sys_device *, cpu_sys_devices); static DEFINE_PER_CPU(struct sys_device *, cpu_sys_devices);
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
static ssize_t show_online(struct sys_device *dev, char *buf) static ssize_t show_online(struct sys_device *dev, struct sysdev_attribute *attr,
char *buf)
{ {
struct cpu *cpu = container_of(dev, struct cpu, sysdev); struct cpu *cpu = container_of(dev, struct cpu, sysdev);
return sprintf(buf, "%u\n", !!cpu_online(cpu->sysdev.id)); return sprintf(buf, "%u\n", !!cpu_online(cpu->sysdev.id));
} }
static ssize_t __ref store_online(struct sys_device *dev, const char *buf, static ssize_t __ref store_online(struct sys_device *dev, struct sysdev_attribute *attr,
size_t count) const char *buf, size_t count)
{ {
struct cpu *cpu = container_of(dev, struct cpu, sysdev); struct cpu *cpu = container_of(dev, struct cpu, sysdev);
ssize_t ret; ssize_t ret;
@ -80,7 +81,8 @@ static inline void register_cpu_control(struct cpu *cpu)
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC
#include <linux/kexec.h> #include <linux/kexec.h>
static ssize_t show_crash_notes(struct sys_device *dev, char *buf) static ssize_t show_crash_notes(struct sys_device *dev, struct sysdev_attribute *attr,
char *buf)
{ {
struct cpu *cpu = container_of(dev, struct cpu, sysdev); struct cpu *cpu = container_of(dev, struct cpu, sysdev);
ssize_t rc; ssize_t rc;

View file

@ -92,7 +92,8 @@ unregister_memory(struct memory_block *memory, struct mem_section *section)
* uses. * uses.
*/ */
static ssize_t show_mem_phys_index(struct sys_device *dev, char *buf) static ssize_t show_mem_phys_index(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct memory_block *mem = struct memory_block *mem =
container_of(dev, struct memory_block, sysdev); container_of(dev, struct memory_block, sysdev);
@ -102,7 +103,8 @@ static ssize_t show_mem_phys_index(struct sys_device *dev, char *buf)
/* /*
* online, offline, going offline, etc. * online, offline, going offline, etc.
*/ */
static ssize_t show_mem_state(struct sys_device *dev, char *buf) static ssize_t show_mem_state(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct memory_block *mem = struct memory_block *mem =
container_of(dev, struct memory_block, sysdev); container_of(dev, struct memory_block, sysdev);
@ -217,7 +219,8 @@ out:
} }
static ssize_t static ssize_t
store_mem_state(struct sys_device *dev, const char *buf, size_t count) store_mem_state(struct sys_device *dev,
struct sysdev_attribute *attr, const char *buf, size_t count)
{ {
struct memory_block *mem; struct memory_block *mem;
unsigned int phys_section_nr; unsigned int phys_section_nr;
@ -248,7 +251,8 @@ out:
* s.t. if I offline all of these sections I can then * s.t. if I offline all of these sections I can then
* remove the physical device? * remove the physical device?
*/ */
static ssize_t show_phys_device(struct sys_device *dev, char *buf) static ssize_t show_phys_device(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
struct memory_block *mem = struct memory_block *mem =
container_of(dev, struct memory_block, sysdev); container_of(dev, struct memory_block, sysdev);

View file

@ -36,11 +36,13 @@ static ssize_t node_read_cpumap(struct sys_device *dev, int type, char *buf)
return len; return len;
} }
static inline ssize_t node_read_cpumask(struct sys_device *dev, char *buf) static inline ssize_t node_read_cpumask(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
return node_read_cpumap(dev, 0, buf); return node_read_cpumap(dev, 0, buf);
} }
static inline ssize_t node_read_cpulist(struct sys_device *dev, char *buf) static inline ssize_t node_read_cpulist(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
return node_read_cpumap(dev, 1, buf); return node_read_cpumap(dev, 1, buf);
} }
@ -49,7 +51,8 @@ static SYSDEV_ATTR(cpumap, S_IRUGO, node_read_cpumask, NULL);
static SYSDEV_ATTR(cpulist, S_IRUGO, node_read_cpulist, NULL); static SYSDEV_ATTR(cpulist, S_IRUGO, node_read_cpulist, NULL);
#define K(x) ((x) << (PAGE_SHIFT - 10)) #define K(x) ((x) << (PAGE_SHIFT - 10))
static ssize_t node_read_meminfo(struct sys_device * dev, char * buf) static ssize_t node_read_meminfo(struct sys_device * dev,
struct sysdev_attribute *attr, char * buf)
{ {
int n; int n;
int nid = dev->id; int nid = dev->id;
@ -112,7 +115,8 @@ static ssize_t node_read_meminfo(struct sys_device * dev, char * buf)
#undef K #undef K
static SYSDEV_ATTR(meminfo, S_IRUGO, node_read_meminfo, NULL); static SYSDEV_ATTR(meminfo, S_IRUGO, node_read_meminfo, NULL);
static ssize_t node_read_numastat(struct sys_device * dev, char * buf) static ssize_t node_read_numastat(struct sys_device * dev,
struct sysdev_attribute *attr, char * buf)
{ {
return sprintf(buf, return sprintf(buf,
"numa_hit %lu\n" "numa_hit %lu\n"
@ -130,7 +134,8 @@ static ssize_t node_read_numastat(struct sys_device * dev, char * buf)
} }
static SYSDEV_ATTR(numastat, S_IRUGO, node_read_numastat, NULL); static SYSDEV_ATTR(numastat, S_IRUGO, node_read_numastat, NULL);
static ssize_t node_read_distance(struct sys_device * dev, char * buf) static ssize_t node_read_distance(struct sys_device * dev,
struct sysdev_attribute *attr, char * buf)
{ {
int nid = dev->id; int nid = dev->id;
int len = 0; int len = 0;

View file

@ -36,7 +36,7 @@ sysdev_show(struct kobject * kobj, struct attribute * attr, char * buffer)
struct sysdev_attribute * sysdev_attr = to_sysdev_attr(attr); struct sysdev_attribute * sysdev_attr = to_sysdev_attr(attr);
if (sysdev_attr->show) if (sysdev_attr->show)
return sysdev_attr->show(sysdev, buffer); return sysdev_attr->show(sysdev, sysdev_attr, buffer);
return -EIO; return -EIO;
} }
@ -49,7 +49,7 @@ sysdev_store(struct kobject * kobj, struct attribute * attr,
struct sysdev_attribute * sysdev_attr = to_sysdev_attr(attr); struct sysdev_attribute * sysdev_attr = to_sysdev_attr(attr);
if (sysdev_attr->store) if (sysdev_attr->store)
return sysdev_attr->store(sysdev, buffer, count); return sysdev_attr->store(sysdev, sysdev_attr, buffer, count);
return -EIO; return -EIO;
} }

View file

@ -34,7 +34,8 @@
static SYSDEV_ATTR(_name, 0444, show_##_name, NULL) static SYSDEV_ATTR(_name, 0444, show_##_name, NULL)
#define define_id_show_func(name) \ #define define_id_show_func(name) \
static ssize_t show_##name(struct sys_device *dev, char *buf) \ static ssize_t show_##name(struct sys_device *dev, \
struct sysdev_attribute *attr, char *buf) \
{ \ { \
unsigned int cpu = dev->id; \ unsigned int cpu = dev->id; \
return sprintf(buf, "%d\n", topology_##name(cpu)); \ return sprintf(buf, "%d\n", topology_##name(cpu)); \
@ -59,14 +60,17 @@ static ssize_t show_cpumap(int type, cpumask_t *mask, char *buf)
#ifdef arch_provides_topology_pointers #ifdef arch_provides_topology_pointers
#define define_siblings_show_map(name) \ #define define_siblings_show_map(name) \
static ssize_t show_##name(struct sys_device *dev, char *buf) \ static ssize_t show_##name(struct sys_device *dev, \
struct sysdev_attribute *attr, char *buf) \
{ \ { \
unsigned int cpu = dev->id; \ unsigned int cpu = dev->id; \
return show_cpumap(0, &(topology_##name(cpu)), buf); \ return show_cpumap(0, &(topology_##name(cpu)), buf); \
} }
#define define_siblings_show_list(name) \ #define define_siblings_show_list(name) \
static ssize_t show_##name##_list(struct sys_device *dev, char *buf) \ static ssize_t show_##name##_list(struct sys_device *dev, \
struct sysdev_attribute *attr, \
char *buf) \
{ \ { \
unsigned int cpu = dev->id; \ unsigned int cpu = dev->id; \
return show_cpumap(1, &(topology_##name(cpu)), buf); \ return show_cpumap(1, &(topology_##name(cpu)), buf); \
@ -74,7 +78,8 @@ static ssize_t show_##name##_list(struct sys_device *dev, char *buf) \
#else #else
#define define_siblings_show_map(name) \ #define define_siblings_show_map(name) \
static ssize_t show_##name(struct sys_device *dev, char *buf) \ static ssize_t show_##name(struct sys_device *dev, \
struct sysdev_attribute *attr, char *buf) \
{ \ { \
unsigned int cpu = dev->id; \ unsigned int cpu = dev->id; \
cpumask_t mask = topology_##name(cpu); \ cpumask_t mask = topology_##name(cpu); \
@ -82,7 +87,9 @@ static ssize_t show_##name(struct sys_device *dev, char *buf) \
} }
#define define_siblings_show_list(name) \ #define define_siblings_show_list(name) \
static ssize_t show_##name##_list(struct sys_device *dev, char *buf) \ static ssize_t show_##name##_list(struct sys_device *dev, \
struct sysdev_attribute *attr, \
char *buf) \
{ \ { \
unsigned int cpu = dev->id; \ unsigned int cpu = dev->id; \
cpumask_t mask = topology_##name(cpu); \ cpumask_t mask = topology_##name(cpu); \

View file

@ -21,7 +21,8 @@ static int __init cpuidle_sysfs_setup(char *unused)
} }
__setup("cpuidle_sysfs_switch", cpuidle_sysfs_setup); __setup("cpuidle_sysfs_switch", cpuidle_sysfs_setup);
static ssize_t show_available_governors(struct sys_device *dev, char *buf) static ssize_t show_available_governors(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
ssize_t i = 0; ssize_t i = 0;
struct cpuidle_governor *tmp; struct cpuidle_governor *tmp;
@ -39,7 +40,8 @@ out:
return i; return i;
} }
static ssize_t show_current_driver(struct sys_device *dev, char *buf) static ssize_t show_current_driver(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
ssize_t ret; ssize_t ret;
@ -53,7 +55,8 @@ static ssize_t show_current_driver(struct sys_device *dev, char *buf)
return ret; return ret;
} }
static ssize_t show_current_governor(struct sys_device *dev, char *buf) static ssize_t show_current_governor(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
ssize_t ret; ssize_t ret;
@ -68,6 +71,7 @@ static ssize_t show_current_governor(struct sys_device *dev, char *buf)
} }
static ssize_t store_current_governor(struct sys_device *dev, static ssize_t store_current_governor(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t count) const char *buf, size_t count)
{ {
char gov_name[CPUIDLE_NAME_LEN]; char gov_name[CPUIDLE_NAME_LEN];

View file

@ -610,6 +610,7 @@ static ssize_t show_target_kb(struct sys_device *dev, char *buf)
} }
static ssize_t store_target_kb(struct sys_device *dev, static ssize_t store_target_kb(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, const char *buf,
size_t count) size_t count)
{ {

View file

@ -99,8 +99,9 @@ extern void sysdev_unregister(struct sys_device *);
struct sysdev_attribute { struct sysdev_attribute {
struct attribute attr; struct attribute attr;
ssize_t (*show)(struct sys_device *, char *); ssize_t (*show)(struct sys_device *, struct sysdev_attribute *, char *);
ssize_t (*store)(struct sys_device *, const char *, size_t); ssize_t (*store)(struct sys_device *, struct sysdev_attribute *,
const char *, size_t);
}; };

View file

@ -297,8 +297,8 @@ static int test_func(void *data)
* *
* opcode:data * opcode:data
*/ */
static ssize_t sysfs_test_command(struct sys_device *dev, const char *buf, static ssize_t sysfs_test_command(struct sys_device *dev, struct sysdev_attribute *attr,
size_t count) const char *buf, size_t count)
{ {
struct sched_param schedpar; struct sched_param schedpar;
struct test_thread_data *td; struct test_thread_data *td;
@ -360,7 +360,8 @@ static ssize_t sysfs_test_command(struct sys_device *dev, const char *buf,
* @dev: thread to query * @dev: thread to query
* @buf: char buffer to be filled with thread status info * @buf: char buffer to be filled with thread status info
*/ */
static ssize_t sysfs_test_status(struct sys_device *dev, char *buf) static ssize_t sysfs_test_status(struct sys_device *dev, struct sysdev_attribute *attr,
char *buf)
{ {
struct test_thread_data *td; struct test_thread_data *td;
struct task_struct *tsk; struct task_struct *tsk;

View file

@ -7737,11 +7737,13 @@ static ssize_t sched_power_savings_store(const char *buf, size_t count, int smt)
} }
#ifdef CONFIG_SCHED_MC #ifdef CONFIG_SCHED_MC
static ssize_t sched_mc_power_savings_show(struct sys_device *dev, char *page) static ssize_t sched_mc_power_savings_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *page)
{ {
return sprintf(page, "%u\n", sched_mc_power_savings); return sprintf(page, "%u\n", sched_mc_power_savings);
} }
static ssize_t sched_mc_power_savings_store(struct sys_device *dev, static ssize_t sched_mc_power_savings_store(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t count) const char *buf, size_t count)
{ {
return sched_power_savings_store(buf, count, 0); return sched_power_savings_store(buf, count, 0);
@ -7751,11 +7753,13 @@ static SYSDEV_ATTR(sched_mc_power_savings, 0644, sched_mc_power_savings_show,
#endif #endif
#ifdef CONFIG_SCHED_SMT #ifdef CONFIG_SCHED_SMT
static ssize_t sched_smt_power_savings_show(struct sys_device *dev, char *page) static ssize_t sched_smt_power_savings_show(struct sys_device *dev,
struct sysdev_attribute *attr, char *page)
{ {
return sprintf(page, "%u\n", sched_smt_power_savings); return sprintf(page, "%u\n", sched_smt_power_savings);
} }
static ssize_t sched_smt_power_savings_store(struct sys_device *dev, static ssize_t sched_smt_power_savings_store(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t count) const char *buf, size_t count)
{ {
return sched_power_savings_store(buf, count, 1); return sched_power_savings_store(buf, count, 1);

View file

@ -376,7 +376,8 @@ void clocksource_unregister(struct clocksource *cs)
* Provides sysfs interface for listing current clocksource. * Provides sysfs interface for listing current clocksource.
*/ */
static ssize_t static ssize_t
sysfs_show_current_clocksources(struct sys_device *dev, char *buf) sysfs_show_current_clocksources(struct sys_device *dev,
struct sysdev_attribute *attr, char *buf)
{ {
ssize_t count = 0; ssize_t count = 0;
@ -397,6 +398,7 @@ sysfs_show_current_clocksources(struct sys_device *dev, char *buf)
* clocksource selction. * clocksource selction.
*/ */
static ssize_t sysfs_override_clocksource(struct sys_device *dev, static ssize_t sysfs_override_clocksource(struct sys_device *dev,
struct sysdev_attribute *attr,
const char *buf, size_t count) const char *buf, size_t count)
{ {
struct clocksource *ovr = NULL; struct clocksource *ovr = NULL;
@ -449,7 +451,9 @@ static ssize_t sysfs_override_clocksource(struct sys_device *dev,
* Provides sysfs interface for listing registered clocksources * Provides sysfs interface for listing registered clocksources
*/ */
static ssize_t static ssize_t
sysfs_show_available_clocksources(struct sys_device *dev, char *buf) sysfs_show_available_clocksources(struct sys_device *dev,
struct sysdev_attribute *attr,
char *buf)
{ {
struct clocksource *src; struct clocksource *src;
ssize_t count = 0; ssize_t count = 0;