11da177e4SLinus Torvalds /* 21da177e4SLinus Torvalds * debugfs.h - a tiny little debug file system 31da177e4SLinus Torvalds * 41da177e4SLinus Torvalds * Copyright (C) 2004 Greg Kroah-Hartman <[email protected]> 51da177e4SLinus Torvalds * Copyright (C) 2004 IBM Inc. 61da177e4SLinus Torvalds * 71da177e4SLinus Torvalds * This program is free software; you can redistribute it and/or 81da177e4SLinus Torvalds * modify it under the terms of the GNU General Public License version 91da177e4SLinus Torvalds * 2 as published by the Free Software Foundation. 101da177e4SLinus Torvalds * 111da177e4SLinus Torvalds * debugfs is for people to use instead of /proc or /sys. 12*55dff495SRandy Dunlap * See Documentation/DocBook/filesystems for more details. 131da177e4SLinus Torvalds */ 141da177e4SLinus Torvalds 151da177e4SLinus Torvalds #ifndef _DEBUGFS_H_ 161da177e4SLinus Torvalds #define _DEBUGFS_H_ 171da177e4SLinus Torvalds 181da177e4SLinus Torvalds #include <linux/fs.h> 191da177e4SLinus Torvalds 20a7a76cefSRoland Dreier #include <linux/types.h> 21a7a76cefSRoland Dreier 22a7a76cefSRoland Dreier struct file_operations; 23a7a76cefSRoland Dreier 24dd308bc3SMichael Ellerman struct debugfs_blob_wrapper { 25dd308bc3SMichael Ellerman void *data; 26dd308bc3SMichael Ellerman unsigned long size; 27dd308bc3SMichael Ellerman }; 28dd308bc3SMichael Ellerman 29ae79cdaaS[email protected] extern struct dentry *arch_debugfs_dir; 30ae79cdaaS[email protected] 311da177e4SLinus Torvalds #if defined(CONFIG_DEBUG_FS) 323634634eSHarvey Harrison 333634634eSHarvey Harrison /* declared over in file.c */ 343634634eSHarvey Harrison extern const struct file_operations debugfs_file_operations; 353634634eSHarvey Harrison extern const struct inode_operations debugfs_link_operations; 363634634eSHarvey Harrison 371da177e4SLinus Torvalds struct dentry *debugfs_create_file(const char *name, mode_t mode, 381da177e4SLinus Torvalds struct dentry *parent, void *data, 3999ac48f5SArjan van de Ven const struct file_operations *fops); 401da177e4SLinus Torvalds 411da177e4SLinus Torvalds struct dentry *debugfs_create_dir(const char *name, struct dentry *parent); 421da177e4SLinus Torvalds 4366f54963SPeter Oberparleiter struct dentry *debugfs_create_symlink(const char *name, struct dentry *parent, 4466f54963SPeter Oberparleiter const char *dest); 4566f54963SPeter Oberparleiter 461da177e4SLinus Torvalds void debugfs_remove(struct dentry *dentry); 479505e637SHaavard Skinnemoen void debugfs_remove_recursive(struct dentry *dentry); 481da177e4SLinus Torvalds 49cfc94cdfSJan Kara struct dentry *debugfs_rename(struct dentry *old_dir, struct dentry *old_dentry, 50cfc94cdfSJan Kara struct dentry *new_dir, const char *new_name); 51cfc94cdfSJan Kara 521da177e4SLinus Torvalds struct dentry *debugfs_create_u8(const char *name, mode_t mode, 531da177e4SLinus Torvalds struct dentry *parent, u8 *value); 541da177e4SLinus Torvalds struct dentry *debugfs_create_u16(const char *name, mode_t mode, 551da177e4SLinus Torvalds struct dentry *parent, u16 *value); 561da177e4SLinus Torvalds struct dentry *debugfs_create_u32(const char *name, mode_t mode, 571da177e4SLinus Torvalds struct dentry *parent, u32 *value); 588447891fSMichael Ellerman struct dentry *debugfs_create_u64(const char *name, mode_t mode, 598447891fSMichael Ellerman struct dentry *parent, u64 *value); 602ebefc50SRobin Getz struct dentry *debugfs_create_x8(const char *name, mode_t mode, 612ebefc50SRobin Getz struct dentry *parent, u8 *value); 622ebefc50SRobin Getz struct dentry *debugfs_create_x16(const char *name, mode_t mode, 632ebefc50SRobin Getz struct dentry *parent, u16 *value); 642ebefc50SRobin Getz struct dentry *debugfs_create_x32(const char *name, mode_t mode, 652ebefc50SRobin Getz struct dentry *parent, u32 *value); 665e078787SInaky Perez-Gonzalez struct dentry *debugfs_create_size_t(const char *name, mode_t mode, 675e078787SInaky Perez-Gonzalez struct dentry *parent, size_t *value); 681da177e4SLinus Torvalds struct dentry *debugfs_create_bool(const char *name, mode_t mode, 691da177e4SLinus Torvalds struct dentry *parent, u32 *value); 701da177e4SLinus Torvalds 71dd308bc3SMichael Ellerman struct dentry *debugfs_create_blob(const char *name, mode_t mode, 72dd308bc3SMichael Ellerman struct dentry *parent, 73dd308bc3SMichael Ellerman struct debugfs_blob_wrapper *blob); 74c0f92ba9SFrederic Weisbecker 75c0f92ba9SFrederic Weisbecker bool debugfs_initialized(void); 76c0f92ba9SFrederic Weisbecker 771da177e4SLinus Torvalds #else 78a7a76cefSRoland Dreier 79a7a76cefSRoland Dreier #include <linux/err.h> 80a7a76cefSRoland Dreier 811da177e4SLinus Torvalds /* 821da177e4SLinus Torvalds * We do not return NULL from these functions if CONFIG_DEBUG_FS is not enabled 831da177e4SLinus Torvalds * so users have a chance to detect if there was a real error or not. We don't 841da177e4SLinus Torvalds * want to duplicate the design decision mistakes of procfs and devfs again. 851da177e4SLinus Torvalds */ 861da177e4SLinus Torvalds 871da177e4SLinus Torvalds static inline struct dentry *debugfs_create_file(const char *name, mode_t mode, 88bde11d79SJean Delvare struct dentry *parent, void *data, 89bde11d79SJean Delvare const struct file_operations *fops) 901da177e4SLinus Torvalds { 911da177e4SLinus Torvalds return ERR_PTR(-ENODEV); 921da177e4SLinus Torvalds } 931da177e4SLinus Torvalds 941da177e4SLinus Torvalds static inline struct dentry *debugfs_create_dir(const char *name, 951da177e4SLinus Torvalds struct dentry *parent) 961da177e4SLinus Torvalds { 971da177e4SLinus Torvalds return ERR_PTR(-ENODEV); 981da177e4SLinus Torvalds } 991da177e4SLinus Torvalds 10066f54963SPeter Oberparleiter static inline struct dentry *debugfs_create_symlink(const char *name, 10166f54963SPeter Oberparleiter struct dentry *parent, 10266f54963SPeter Oberparleiter const char *dest) 10366f54963SPeter Oberparleiter { 10466f54963SPeter Oberparleiter return ERR_PTR(-ENODEV); 10566f54963SPeter Oberparleiter } 10666f54963SPeter Oberparleiter 1071da177e4SLinus Torvalds static inline void debugfs_remove(struct dentry *dentry) 1081da177e4SLinus Torvalds { } 1091da177e4SLinus Torvalds 1109505e637SHaavard Skinnemoen static inline void debugfs_remove_recursive(struct dentry *dentry) 1119505e637SHaavard Skinnemoen { } 1129505e637SHaavard Skinnemoen 113cfc94cdfSJan Kara static inline struct dentry *debugfs_rename(struct dentry *old_dir, struct dentry *old_dentry, 114cfc94cdfSJan Kara struct dentry *new_dir, char *new_name) 115cfc94cdfSJan Kara { 116cfc94cdfSJan Kara return ERR_PTR(-ENODEV); 117cfc94cdfSJan Kara } 118cfc94cdfSJan Kara 1191da177e4SLinus Torvalds static inline struct dentry *debugfs_create_u8(const char *name, mode_t mode, 1201da177e4SLinus Torvalds struct dentry *parent, 1211da177e4SLinus Torvalds u8 *value) 1221da177e4SLinus Torvalds { 1231da177e4SLinus Torvalds return ERR_PTR(-ENODEV); 1241da177e4SLinus Torvalds } 1251da177e4SLinus Torvalds 1261da177e4SLinus Torvalds static inline struct dentry *debugfs_create_u16(const char *name, mode_t mode, 1271da177e4SLinus Torvalds struct dentry *parent, 1287b558637SMichal Ostrowski u16 *value) 1291da177e4SLinus Torvalds { 1301da177e4SLinus Torvalds return ERR_PTR(-ENODEV); 1311da177e4SLinus Torvalds } 1321da177e4SLinus Torvalds 1331da177e4SLinus Torvalds static inline struct dentry *debugfs_create_u32(const char *name, mode_t mode, 1341da177e4SLinus Torvalds struct dentry *parent, 1357b558637SMichal Ostrowski u32 *value) 1361da177e4SLinus Torvalds { 1371da177e4SLinus Torvalds return ERR_PTR(-ENODEV); 1381da177e4SLinus Torvalds } 1391da177e4SLinus Torvalds 1408447891fSMichael Ellerman static inline struct dentry *debugfs_create_u64(const char *name, mode_t mode, 1418447891fSMichael Ellerman struct dentry *parent, 1428447891fSMichael Ellerman u64 *value) 1438447891fSMichael Ellerman { 1448447891fSMichael Ellerman return ERR_PTR(-ENODEV); 1458447891fSMichael Ellerman } 1468447891fSMichael Ellerman 1472ebefc50SRobin Getz static inline struct dentry *debugfs_create_x8(const char *name, mode_t mode, 1482ebefc50SRobin Getz struct dentry *parent, 1492ebefc50SRobin Getz u8 *value) 1502ebefc50SRobin Getz { 1512ebefc50SRobin Getz return ERR_PTR(-ENODEV); 1522ebefc50SRobin Getz } 1532ebefc50SRobin Getz 1542ebefc50SRobin Getz static inline struct dentry *debugfs_create_x16(const char *name, mode_t mode, 1552ebefc50SRobin Getz struct dentry *parent, 1562ebefc50SRobin Getz u16 *value) 1572ebefc50SRobin Getz { 1582ebefc50SRobin Getz return ERR_PTR(-ENODEV); 1592ebefc50SRobin Getz } 1602ebefc50SRobin Getz 1612ebefc50SRobin Getz static inline struct dentry *debugfs_create_x32(const char *name, mode_t mode, 1622ebefc50SRobin Getz struct dentry *parent, 1632ebefc50SRobin Getz u32 *value) 1642ebefc50SRobin Getz { 1652ebefc50SRobin Getz return ERR_PTR(-ENODEV); 1662ebefc50SRobin Getz } 1672ebefc50SRobin Getz 1685ee81007SLinus Torvalds static inline struct dentry *debugfs_create_size_t(const char *name, mode_t mode, 1698adb711fSInaky Perez-Gonzalez struct dentry *parent, 1708adb711fSInaky Perez-Gonzalez size_t *value) 1718adb711fSInaky Perez-Gonzalez { 1728adb711fSInaky Perez-Gonzalez return ERR_PTR(-ENODEV); 1738adb711fSInaky Perez-Gonzalez } 1748adb711fSInaky Perez-Gonzalez 1751da177e4SLinus Torvalds static inline struct dentry *debugfs_create_bool(const char *name, mode_t mode, 1761da177e4SLinus Torvalds struct dentry *parent, 1777b558637SMichal Ostrowski u32 *value) 1781da177e4SLinus Torvalds { 1791da177e4SLinus Torvalds return ERR_PTR(-ENODEV); 1801da177e4SLinus Torvalds } 1811da177e4SLinus Torvalds 182dd308bc3SMichael Ellerman static inline struct dentry *debugfs_create_blob(const char *name, mode_t mode, 183dd308bc3SMichael Ellerman struct dentry *parent, 184dd308bc3SMichael Ellerman struct debugfs_blob_wrapper *blob) 185dd308bc3SMichael Ellerman { 186dd308bc3SMichael Ellerman return ERR_PTR(-ENODEV); 187dd308bc3SMichael Ellerman } 188dd308bc3SMichael Ellerman 189c0f92ba9SFrederic Weisbecker static inline bool debugfs_initialized(void) 190c0f92ba9SFrederic Weisbecker { 191c0f92ba9SFrederic Weisbecker return false; 192c0f92ba9SFrederic Weisbecker } 193c0f92ba9SFrederic Weisbecker 1941da177e4SLinus Torvalds #endif 1951da177e4SLinus Torvalds 1961da177e4SLinus Torvalds #endif 197