blob: 910e485b73335de429680272d4b988946bc45880 [file] [log] [blame]
Tejun Heoae6621b2013-11-28 14:54:31 -05001/*
2 * fs/kernfs/kernfs-internal.h - kernfs internal header file
3 *
4 * Copyright (c) 2001-3 Patrick Mochel
5 * Copyright (c) 2007 SUSE Linux Products GmbH
6 * Copyright (c) 2007, 2013 Tejun Heo <teheo@suse.de>
7 *
8 * This file is released under the GPLv2.
9 */
10
11#ifndef __KERNFS_INTERNAL_H
12#define __KERNFS_INTERNAL_H
13
14#include <linux/lockdep.h>
15#include <linux/fs.h>
Tejun Heofd7b9f72013-11-28 14:54:33 -050016#include <linux/mutex.h>
Tejun Heo23223922013-11-23 17:40:02 -050017#include <linux/xattr.h>
Tejun Heoae6621b2013-11-28 14:54:31 -050018
19#include <linux/kernfs.h>
20
Tejun Heoae6621b2013-11-28 14:54:31 -050021struct sysfs_inode_attrs {
Tejun Heo9a8049a2013-11-23 17:40:01 -050022 struct iattr ia_iattr;
23 void *ia_secdata;
24 u32 ia_secdata_len;
Tejun Heo23223922013-11-23 17:40:02 -050025
26 struct simple_xattrs xattrs;
Tejun Heoae6621b2013-11-28 14:54:31 -050027};
28
Tejun Heoae6621b2013-11-28 14:54:31 -050029#define SD_DEACTIVATED_BIAS INT_MIN
30
Tejun Heocf9e5a72013-11-29 17:18:32 -050031/* SYSFS_TYPE_MASK and types are defined in include/linux/kernfs.h */
Tejun Heoae6621b2013-11-28 14:54:31 -050032
Tejun Heoba7443b2013-11-28 14:54:40 -050033/**
34 * kernfs_root - find out the kernfs_root a sysfs_dirent belongs to
35 * @sd: sysfs_dirent of interest
36 *
37 * Return the kernfs_root @sd belongs to.
38 */
39static inline struct kernfs_root *kernfs_root(struct sysfs_dirent *sd)
40{
41 /* if parent exists, it's always a dir; otherwise, @sd is a dir */
42 if (sd->s_parent)
43 sd = sd->s_parent;
44 return sd->s_dir.root;
45}
46
Tejun Heoae6621b2013-11-28 14:54:31 -050047/*
48 * Context structure to be used while adding/removing nodes.
49 */
50struct sysfs_addrm_cxt {
51 struct sysfs_dirent *removed;
52};
53
Tejun Heoffed24e2013-11-28 14:54:32 -050054/*
Tejun Heofa736a92013-11-28 14:54:44 -050055 * mount.c
56 */
57struct sysfs_super_info {
58 /*
59 * The root associated with this super_block. Each super_block is
60 * identified by the root and ns it's associated with.
61 */
62 struct kernfs_root *root;
63
64 /*
65 * Each sb is associated with one namespace tag, currently the network
66 * namespace of the task which mounted this sysfs instance. If multiple
67 * tags become necessary, make the following an array and compare
68 * sysfs_dirent tag against every entry.
69 */
70 const void *ns;
71};
72#define sysfs_info(SB) ((struct sysfs_super_info *)(SB->s_fs_info))
73
74extern struct kmem_cache *sysfs_dir_cachep;
75
76/*
Tejun Heoffed24e2013-11-28 14:54:32 -050077 * inode.c
78 */
79struct inode *sysfs_get_inode(struct super_block *sb, struct sysfs_dirent *sd);
80void sysfs_evict_inode(struct inode *inode);
81int sysfs_permission(struct inode *inode, int mask);
82int sysfs_setattr(struct dentry *dentry, struct iattr *iattr);
83int sysfs_getattr(struct vfsmount *mnt, struct dentry *dentry,
84 struct kstat *stat);
85int sysfs_setxattr(struct dentry *dentry, const char *name, const void *value,
86 size_t size, int flags);
Tejun Heo23223922013-11-23 17:40:02 -050087int sysfs_removexattr(struct dentry *dentry, const char *name);
88ssize_t sysfs_getxattr(struct dentry *dentry, const char *name, void *buf,
89 size_t size);
90ssize_t sysfs_listxattr(struct dentry *dentry, char *buf, size_t size);
Tejun Heo4b93dc92013-11-28 14:54:43 -050091void sysfs_inode_init(void);
Tejun Heoffed24e2013-11-28 14:54:32 -050092
Tejun Heofd7b9f72013-11-28 14:54:33 -050093/*
94 * dir.c
95 */
96extern struct mutex sysfs_mutex;
97extern const struct dentry_operations sysfs_dentry_ops;
98extern const struct file_operations sysfs_dir_operations;
99extern const struct inode_operations sysfs_dir_inode_operations;
100
101struct sysfs_dirent *sysfs_get_active(struct sysfs_dirent *sd);
102void sysfs_put_active(struct sysfs_dirent *sd);
103void sysfs_addrm_start(struct sysfs_addrm_cxt *acxt);
104int sysfs_add_one(struct sysfs_addrm_cxt *acxt, struct sysfs_dirent *sd,
105 struct sysfs_dirent *parent_sd);
106void sysfs_addrm_finish(struct sysfs_addrm_cxt *acxt);
Tejun Heobc755552013-11-28 14:54:41 -0500107struct sysfs_dirent *sysfs_new_dirent(struct kernfs_root *root,
108 const char *name, umode_t mode, int type);
Tejun Heofd7b9f72013-11-28 14:54:33 -0500109
Tejun Heo414985a2013-11-28 14:54:34 -0500110/*
111 * file.c
112 */
113extern const struct file_operations kernfs_file_operations;
114
115void sysfs_unmap_bin_file(struct sysfs_dirent *sd);
116
Tejun Heo2072f1a2013-11-28 14:54:35 -0500117/*
118 * symlink.c
119 */
120extern const struct inode_operations sysfs_symlink_inode_operations;
121
Tejun Heoae6621b2013-11-28 14:54:31 -0500122#endif /* __KERNFS_INTERNAL_H */