aboutsummaryrefslogtreecommitdiffstats
path: root/fs/debugfs
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2012-06-09 20:28:22 -0400
committerAl Viro <viro@zeniv.linux.org.uk>2012-07-14 08:35:19 -0400
commitc3b1a350846a11dd1054cb7832e098aa37025deb (patch)
tree0915cd01d07b4b41c2133e307d7b74cb34a94a43 /fs/debugfs
parentee3efa91e240f513898050ef305a49a653c8ed90 (diff)
debugfs: make sure that debugfs_create_file() gets used only for regulars
It, debugfs_create_dir() and debugfs_create_link() use the common helper now. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/debugfs')
-rw-r--r--fs/debugfs/inode.c56
1 files changed, 34 insertions, 22 deletions
diff --git a/fs/debugfs/inode.c b/fs/debugfs/inode.c
index b80bc846a15a..d423b966bc79 100644
--- a/fs/debugfs/inode.c
+++ b/fs/debugfs/inode.c
@@ -335,6 +335,30 @@ static int debugfs_create_by_name(const char *name, umode_t mode,
335 return error; 335 return error;
336} 336}
337 337
338struct dentry *__create_file(const char *name, umode_t mode,
339 struct dentry *parent, void *data,
340 const struct file_operations *fops)
341{
342 struct dentry *dentry = NULL;
343 int error;
344
345 pr_debug("debugfs: creating file '%s'\n",name);
346
347 error = simple_pin_fs(&debug_fs_type, &debugfs_mount,
348 &debugfs_mount_count);
349 if (error)
350 goto exit;
351
352 error = debugfs_create_by_name(name, mode, parent, &dentry,
353 data, fops);
354 if (error) {
355 dentry = NULL;
356 simple_release_fs(&debugfs_mount, &debugfs_mount_count);
357 }
358exit:
359 return dentry;
360}
361
338/** 362/**
339 * debugfs_create_file - create a file in the debugfs filesystem 363 * debugfs_create_file - create a file in the debugfs filesystem
340 * @name: a pointer to a string containing the name of the file to create. 364 * @name: a pointer to a string containing the name of the file to create.
@@ -365,25 +389,15 @@ struct dentry *debugfs_create_file(const char *name, umode_t mode,
365 struct dentry *parent, void *data, 389 struct dentry *parent, void *data,
366 const struct file_operations *fops) 390 const struct file_operations *fops)
367{ 391{
368 struct dentry *dentry = NULL; 392 switch (mode & S_IFMT) {
369 int error; 393 case S_IFREG:
370 394 case 0:
371 pr_debug("debugfs: creating file '%s'\n",name); 395 break;
372 396 default:
373 error = simple_pin_fs(&debug_fs_type, &debugfs_mount, 397 BUG();
374 &debugfs_mount_count);
375 if (error)
376 goto exit;
377
378 error = debugfs_create_by_name(name, mode, parent, &dentry,
379 data, fops);
380 if (error) {
381 dentry = NULL;
382 simple_release_fs(&debugfs_mount, &debugfs_mount_count);
383 goto exit;
384 } 398 }
385exit: 399
386 return dentry; 400 return __create_file(name, mode, parent, data, fops);
387} 401}
388EXPORT_SYMBOL_GPL(debugfs_create_file); 402EXPORT_SYMBOL_GPL(debugfs_create_file);
389 403
@@ -407,8 +421,7 @@ EXPORT_SYMBOL_GPL(debugfs_create_file);
407 */ 421 */
408struct dentry *debugfs_create_dir(const char *name, struct dentry *parent) 422struct dentry *debugfs_create_dir(const char *name, struct dentry *parent)
409{ 423{
410 return debugfs_create_file(name, 424 return __create_file(name, S_IFDIR | S_IRWXU | S_IRUGO | S_IXUGO,
411 S_IFDIR | S_IRWXU | S_IRUGO | S_IXUGO,
412 parent, NULL, NULL); 425 parent, NULL, NULL);
413} 426}
414EXPORT_SYMBOL_GPL(debugfs_create_dir); 427EXPORT_SYMBOL_GPL(debugfs_create_dir);
@@ -446,8 +459,7 @@ struct dentry *debugfs_create_symlink(const char *name, struct dentry *parent,
446 if (!link) 459 if (!link)
447 return NULL; 460 return NULL;
448 461
449 result = debugfs_create_file(name, S_IFLNK | S_IRWXUGO, parent, link, 462 result = __create_file(name, S_IFLNK | S_IRWXUGO, parent, link, NULL);
450 NULL);
451 if (!result) 463 if (!result)
452 kfree(link); 464 kfree(link);
453 return result; 465 return result;