diff options
author | Chris Metcalf <cmetcalf@tilera.com> | 2011-05-26 12:40:09 -0400 |
---|---|---|
committer | Chris Metcalf <cmetcalf@tilera.com> | 2011-05-27 10:39:05 -0400 |
commit | f133ecca9cbb31b5e6e9bda27cbe3034fbf656df (patch) | |
tree | 1887377b71ee9fc73d4e1226d1d9776ae5a5d7ad /fs/proc | |
parent | 7a0287df3e83a0012dfc496d4a8af9c1c5b126ef (diff) |
arch/tile: more /proc and /sys file support
This change introduces a few of the less controversial /proc and
/proc/sys interfaces for tile, along with sysfs attributes for
various things that were originally proposed as /proc/tile files.
It also adjusts the "hardwall" proc API.
Arnd Bergmann reviewed the initial arch/tile submission, which
included a complete set of all the /proc/tile and /proc/sys/tile
knobs that we had added in a somewhat ad hoc way during initial
development, and provided feedback on where most of them should go.
One knob turned out to be similar enough to the existing
/proc/sys/debug/exception-trace that it was re-implemented to use
that model instead.
Another knob was /proc/tile/grid, which reported the "grid" dimensions
of a tile chip (e.g. 8x8 processors = 64-core chip). Arnd suggested
looking at sysfs for that, so this change moves that information
to a pair of sysfs attributes (chip_width and chip_height) in the
/sys/devices/system/cpu directory. We also put the "chip_serial"
and "chip_revision" information from our old /proc/tile/board file
as attributes in /sys/devices/system/cpu.
Other information collected via hypervisor APIs is now placed in
/sys/hypervisor. We create a /sys/hypervisor/type file (holding the
constant string "tilera") to be parallel with the Xen use of
/sys/hypervisor/type holding "xen". We create three top-level files,
"version" (the hypervisor's own version), "config_version" (the
version of the configuration file), and "hvconfig" (the contents of
the configuration file). The remaining information from our old
/proc/tile/board and /proc/tile/switch files becomes an attribute
group appearing under /sys/hypervisor/board/.
Finally, after some feedback from Arnd Bergmann for the previous
version of this patch, the /proc/tile/hardwall file is split up into
two conceptual parts. First, a directory /proc/tile/hardwall/ which
contains one file per active hardwall, each file named after the
hardwall's ID and holding a cpulist that says which cpus are enclosed by
the hardwall. Second, a /proc/PID file "hardwall" that is either
empty (for non-hardwall-using processes) or contains the hardwall ID.
Finally, this change pushes the /proc/sys/tile/unaligned_fixup/
directory, with knobs controlling the kernel code for handling the
fixup of unaligned exceptions.
Reviewed-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Chris Metcalf <cmetcalf@tilera.com>
Diffstat (limited to 'fs/proc')
-rw-r--r-- | fs/proc/base.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/fs/proc/base.c b/fs/proc/base.c index dfa532730e55..3ad615fb8656 100644 --- a/fs/proc/base.c +++ b/fs/proc/base.c | |||
@@ -83,6 +83,9 @@ | |||
83 | #include <linux/pid_namespace.h> | 83 | #include <linux/pid_namespace.h> |
84 | #include <linux/fs_struct.h> | 84 | #include <linux/fs_struct.h> |
85 | #include <linux/slab.h> | 85 | #include <linux/slab.h> |
86 | #ifdef CONFIG_HARDWALL | ||
87 | #include <asm/hardwall.h> | ||
88 | #endif | ||
86 | #include "internal.h" | 89 | #include "internal.h" |
87 | 90 | ||
88 | /* NOTE: | 91 | /* NOTE: |
@@ -2894,6 +2897,9 @@ static const struct pid_entry tgid_base_stuff[] = { | |||
2894 | #ifdef CONFIG_TASK_IO_ACCOUNTING | 2897 | #ifdef CONFIG_TASK_IO_ACCOUNTING |
2895 | INF("io", S_IRUGO, proc_tgid_io_accounting), | 2898 | INF("io", S_IRUGO, proc_tgid_io_accounting), |
2896 | #endif | 2899 | #endif |
2900 | #ifdef CONFIG_HARDWALL | ||
2901 | INF("hardwall", S_IRUGO, proc_pid_hardwall), | ||
2902 | #endif | ||
2897 | }; | 2903 | }; |
2898 | 2904 | ||
2899 | static int proc_tgid_base_readdir(struct file * filp, | 2905 | static int proc_tgid_base_readdir(struct file * filp, |
@@ -3232,6 +3238,9 @@ static const struct pid_entry tid_base_stuff[] = { | |||
3232 | #ifdef CONFIG_TASK_IO_ACCOUNTING | 3238 | #ifdef CONFIG_TASK_IO_ACCOUNTING |
3233 | INF("io", S_IRUGO, proc_tid_io_accounting), | 3239 | INF("io", S_IRUGO, proc_tid_io_accounting), |
3234 | #endif | 3240 | #endif |
3241 | #ifdef CONFIG_HARDWALL | ||
3242 | INF("hardwall", S_IRUGO, proc_pid_hardwall), | ||
3243 | #endif | ||
3235 | }; | 3244 | }; |
3236 | 3245 | ||
3237 | static int proc_tid_base_readdir(struct file * filp, | 3246 | static int proc_tid_base_readdir(struct file * filp, |