diff options
| author | Seth Jennings <sjenning@linux.vnet.ibm.com> | 2013-06-03 16:33:02 -0400 |
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2013-06-03 16:55:01 -0400 |
| commit | 3a76e5e09fbb51e756b4e732e3e65446f4984cf5 (patch) | |
| tree | b08061613e352317bc3189abff31609279c0f2fa | |
| parent | 4993632218e2202d4f110c8e83ae819ca26e6845 (diff) | |
debugfs: add get/set for atomic types
debugfs currently lack the ability to create attributes
that set/get atomic_t values.
This patch adds support for this through a new
debugfs_create_atomic_t() function.
Signed-off-by: Seth Jennings <sjenning@linux.vnet.ibm.com>
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Acked-by: Mel Gorman <mgorman@suse.de>
Acked-by: Rik van Riel <riel@redhat.com>
Acked-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
| -rw-r--r-- | fs/debugfs/file.c | 42 | ||||
| -rw-r--r-- | include/linux/debugfs.h | 2 | ||||
| -rw-r--r-- | lib/fault-inject.c | 21 |
3 files changed, 44 insertions, 21 deletions
diff --git a/fs/debugfs/file.c b/fs/debugfs/file.c index c5ca6ae5a30c..ff64bcd5b8fb 100644 --- a/fs/debugfs/file.c +++ b/fs/debugfs/file.c | |||
| @@ -21,6 +21,7 @@ | |||
| 21 | #include <linux/debugfs.h> | 21 | #include <linux/debugfs.h> |
| 22 | #include <linux/io.h> | 22 | #include <linux/io.h> |
| 23 | #include <linux/slab.h> | 23 | #include <linux/slab.h> |
| 24 | #include <linux/atomic.h> | ||
| 24 | 25 | ||
| 25 | static ssize_t default_read_file(struct file *file, char __user *buf, | 26 | static ssize_t default_read_file(struct file *file, char __user *buf, |
| 26 | size_t count, loff_t *ppos) | 27 | size_t count, loff_t *ppos) |
| @@ -403,6 +404,47 @@ struct dentry *debugfs_create_size_t(const char *name, umode_t mode, | |||
| 403 | } | 404 | } |
| 404 | EXPORT_SYMBOL_GPL(debugfs_create_size_t); | 405 | EXPORT_SYMBOL_GPL(debugfs_create_size_t); |
| 405 | 406 | ||
| 407 | static int debugfs_atomic_t_set(void *data, u64 val) | ||
| 408 | { | ||
| 409 | atomic_set((atomic_t *)data, val); | ||
| 410 | return 0; | ||
| 411 | } | ||
| 412 | static int debugfs_atomic_t_get(void *data, u64 *val) | ||
| 413 | { | ||
| 414 | *val = atomic_read((atomic_t *)data); | ||
| 415 | return 0; | ||
| 416 | } | ||
| 417 | DEFINE_SIMPLE_ATTRIBUTE(fops_atomic_t, debugfs_atomic_t_get, | ||
| 418 | debugfs_atomic_t_set, "%lld\n"); | ||
| 419 | DEFINE_SIMPLE_ATTRIBUTE(fops_atomic_t_ro, debugfs_atomic_t_get, NULL, "%lld\n"); | ||
| 420 | DEFINE_SIMPLE_ATTRIBUTE(fops_atomic_t_wo, NULL, debugfs_atomic_t_set, "%lld\n"); | ||
| 421 | |||
| 422 | /** | ||
| 423 | * debugfs_create_atomic_t - create a debugfs file that is used to read and | ||
| 424 | * write an atomic_t value | ||
| 425 | * @name: a pointer to a string containing the name of the file to create. | ||
| 426 | * @mode: the permission that the file should have | ||
| 427 | * @parent: a pointer to the parent dentry for this file. This should be a | ||
| 428 | * directory dentry if set. If this parameter is %NULL, then the | ||
| 429 | * file will be created in the root of the debugfs filesystem. | ||
| 430 | * @value: a pointer to the variable that the file should read to and write | ||
| 431 | * from. | ||
| 432 | */ | ||
| 433 | struct dentry *debugfs_create_atomic_t(const char *name, umode_t mode, | ||
| 434 | struct dentry *parent, atomic_t *value) | ||
| 435 | { | ||
| 436 | /* if there are no write bits set, make read only */ | ||
| 437 | if (!(mode & S_IWUGO)) | ||
| 438 | return debugfs_create_file(name, mode, parent, value, | ||
| 439 | &fops_atomic_t_ro); | ||
| 440 | /* if there are no read bits set, make write only */ | ||
| 441 | if (!(mode & S_IRUGO)) | ||
| 442 | return debugfs_create_file(name, mode, parent, value, | ||
| 443 | &fops_atomic_t_wo); | ||
| 444 | |||
| 445 | return debugfs_create_file(name, mode, parent, value, &fops_atomic_t); | ||
| 446 | } | ||
| 447 | EXPORT_SYMBOL_GPL(debugfs_create_atomic_t); | ||
| 406 | 448 | ||
| 407 | static ssize_t read_file_bool(struct file *file, char __user *user_buf, | 449 | static ssize_t read_file_bool(struct file *file, char __user *user_buf, |
| 408 | size_t count, loff_t *ppos) | 450 | size_t count, loff_t *ppos) |
diff --git a/include/linux/debugfs.h b/include/linux/debugfs.h index 63f2465807d4..d68b4ea7343c 100644 --- a/include/linux/debugfs.h +++ b/include/linux/debugfs.h | |||
| @@ -79,6 +79,8 @@ struct dentry *debugfs_create_x64(const char *name, umode_t mode, | |||
| 79 | struct dentry *parent, u64 *value); | 79 | struct dentry *parent, u64 *value); |
| 80 | struct dentry *debugfs_create_size_t(const char *name, umode_t mode, | 80 | struct dentry *debugfs_create_size_t(const char *name, umode_t mode, |
| 81 | struct dentry *parent, size_t *value); | 81 | struct dentry *parent, size_t *value); |
| 82 | struct dentry *debugfs_create_atomic_t(const char *name, umode_t mode, | ||
| 83 | struct dentry *parent, atomic_t *value); | ||
| 82 | struct dentry *debugfs_create_bool(const char *name, umode_t mode, | 84 | struct dentry *debugfs_create_bool(const char *name, umode_t mode, |
| 83 | struct dentry *parent, u32 *value); | 85 | struct dentry *parent, u32 *value); |
| 84 | 86 | ||
diff --git a/lib/fault-inject.c b/lib/fault-inject.c index c5c7a762b850..d7d501ea856d 100644 --- a/lib/fault-inject.c +++ b/lib/fault-inject.c | |||
| @@ -182,27 +182,6 @@ static struct dentry *debugfs_create_stacktrace_depth( | |||
| 182 | 182 | ||
| 183 | #endif /* CONFIG_FAULT_INJECTION_STACKTRACE_FILTER */ | 183 | #endif /* CONFIG_FAULT_INJECTION_STACKTRACE_FILTER */ |
| 184 | 184 | ||
| 185 | static int debugfs_atomic_t_set(void *data, u64 val) | ||
| 186 | { | ||
| 187 | atomic_set((atomic_t *)data, val); | ||
| 188 | return 0; | ||
| 189 | } | ||
| 190 | |||
| 191 | static int debugfs_atomic_t_get(void *data, u64 *val) | ||
| 192 | { | ||
| 193 | *val = atomic_read((atomic_t *)data); | ||
| 194 | return 0; | ||
| 195 | } | ||
| 196 | |||
| 197 | DEFINE_SIMPLE_ATTRIBUTE(fops_atomic_t, debugfs_atomic_t_get, | ||
| 198 | debugfs_atomic_t_set, "%lld\n"); | ||
| 199 | |||
| 200 | static struct dentry *debugfs_create_atomic_t(const char *name, umode_t mode, | ||
| 201 | struct dentry *parent, atomic_t *value) | ||
| 202 | { | ||
| 203 | return debugfs_create_file(name, mode, parent, value, &fops_atomic_t); | ||
| 204 | } | ||
| 205 | |||
| 206 | struct dentry *fault_create_debugfs_attr(const char *name, | 185 | struct dentry *fault_create_debugfs_attr(const char *name, |
| 207 | struct dentry *parent, struct fault_attr *attr) | 186 | struct dentry *parent, struct fault_attr *attr) |
| 208 | { | 187 | { |
