diff options
Diffstat (limited to 'drivers/pci/pci-sysfs.c')
-rw-r--r-- | drivers/pci/pci-sysfs.c | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/drivers/pci/pci-sysfs.c b/drivers/pci/pci-sysfs.c index f8deb3e380a2..7bcf12adced7 100644 --- a/drivers/pci/pci-sysfs.c +++ b/drivers/pci/pci-sysfs.c | |||
@@ -108,6 +108,40 @@ static ssize_t local_cpulist_show(struct device *dev, | |||
108 | return len; | 108 | return len; |
109 | } | 109 | } |
110 | 110 | ||
111 | /* | ||
112 | * PCI Bus Class Devices | ||
113 | */ | ||
114 | static ssize_t pci_bus_show_cpuaffinity(struct device *dev, | ||
115 | int type, | ||
116 | struct device_attribute *attr, | ||
117 | char *buf) | ||
118 | { | ||
119 | int ret; | ||
120 | const struct cpumask *cpumask; | ||
121 | |||
122 | cpumask = cpumask_of_pcibus(to_pci_bus(dev)); | ||
123 | ret = type ? | ||
124 | cpulist_scnprintf(buf, PAGE_SIZE-2, cpumask) : | ||
125 | cpumask_scnprintf(buf, PAGE_SIZE-2, cpumask); | ||
126 | buf[ret++] = '\n'; | ||
127 | buf[ret] = '\0'; | ||
128 | return ret; | ||
129 | } | ||
130 | |||
131 | static inline ssize_t pci_bus_show_cpumaskaffinity(struct device *dev, | ||
132 | struct device_attribute *attr, | ||
133 | char *buf) | ||
134 | { | ||
135 | return pci_bus_show_cpuaffinity(dev, 0, attr, buf); | ||
136 | } | ||
137 | |||
138 | static inline ssize_t pci_bus_show_cpulistaffinity(struct device *dev, | ||
139 | struct device_attribute *attr, | ||
140 | char *buf) | ||
141 | { | ||
142 | return pci_bus_show_cpuaffinity(dev, 1, attr, buf); | ||
143 | } | ||
144 | |||
111 | /* show resources */ | 145 | /* show resources */ |
112 | static ssize_t | 146 | static ssize_t |
113 | resource_show(struct device * dev, struct device_attribute *attr, char * buf) | 147 | resource_show(struct device * dev, struct device_attribute *attr, char * buf) |
@@ -318,6 +352,25 @@ remove_store(struct device *dev, struct device_attribute *dummy, | |||
318 | count = ret; | 352 | count = ret; |
319 | return count; | 353 | return count; |
320 | } | 354 | } |
355 | |||
356 | static ssize_t | ||
357 | dev_bus_rescan_store(struct device *dev, struct device_attribute *attr, | ||
358 | const char *buf, size_t count) | ||
359 | { | ||
360 | unsigned long val; | ||
361 | struct pci_bus *bus = to_pci_bus(dev); | ||
362 | |||
363 | if (strict_strtoul(buf, 0, &val) < 0) | ||
364 | return -EINVAL; | ||
365 | |||
366 | if (val) { | ||
367 | mutex_lock(&pci_remove_rescan_mutex); | ||
368 | pci_rescan_bus(bus); | ||
369 | mutex_unlock(&pci_remove_rescan_mutex); | ||
370 | } | ||
371 | return count; | ||
372 | } | ||
373 | |||
321 | #endif | 374 | #endif |
322 | 375 | ||
323 | struct device_attribute pci_dev_attrs[] = { | 376 | struct device_attribute pci_dev_attrs[] = { |
@@ -347,6 +400,15 @@ struct device_attribute pci_dev_attrs[] = { | |||
347 | __ATTR_NULL, | 400 | __ATTR_NULL, |
348 | }; | 401 | }; |
349 | 402 | ||
403 | struct device_attribute pcibus_dev_attrs[] = { | ||
404 | #ifdef CONFIG_HOTPLUG | ||
405 | __ATTR(rescan, (S_IWUSR|S_IWGRP), NULL, dev_bus_rescan_store), | ||
406 | #endif | ||
407 | __ATTR(cpuaffinity, S_IRUGO, pci_bus_show_cpumaskaffinity, NULL), | ||
408 | __ATTR(cpulistaffinity, S_IRUGO, pci_bus_show_cpulistaffinity, NULL), | ||
409 | __ATTR_NULL, | ||
410 | }; | ||
411 | |||
350 | static ssize_t | 412 | static ssize_t |
351 | boot_vga_show(struct device *dev, struct device_attribute *attr, char *buf) | 413 | boot_vga_show(struct device *dev, struct device_attribute *attr, char *buf) |
352 | { | 414 | { |