2006-09-24 23:13:19 +08:00
|
|
|
#ifndef __LINUX_MAGIC_H__
|
|
|
|
#define __LINUX_MAGIC_H__
|
|
|
|
|
|
|
|
#define ADFS_SUPER_MAGIC 0xadf5
|
|
|
|
#define AFFS_SUPER_MAGIC 0xadff
|
2007-01-06 08:36:17 +08:00
|
|
|
#define AFS_SUPER_MAGIC 0x5346414F
|
2006-09-24 23:13:19 +08:00
|
|
|
#define AUTOFS_SUPER_MAGIC 0x0187
|
|
|
|
#define CODA_SUPER_MAGIC 0x73757245
|
2009-05-26 17:45:04 +08:00
|
|
|
#define CRAMFS_MAGIC 0x28cd3d45 /* some random number */
|
|
|
|
#define CRAMFS_MAGIC_WEND 0x453dcd28 /* magic number with the wrong endianess */
|
2008-10-08 02:00:12 +08:00
|
|
|
#define DEBUGFS_MAGIC 0x64626720
|
|
|
|
#define SECURITYFS_MAGIC 0x73636673
|
2009-05-18 22:26:10 +08:00
|
|
|
#define SELINUX_MAGIC 0xf97cff8c
|
2012-11-06 16:17:49 +08:00
|
|
|
#define SMACK_MAGIC 0x43415d53 /* "SMAC" */
|
2009-09-23 07:45:53 +08:00
|
|
|
#define RAMFS_MAGIC 0x858458f6 /* some random number */
|
2008-10-08 02:00:12 +08:00
|
|
|
#define TMPFS_MAGIC 0x01021994
|
2009-09-23 07:43:33 +08:00
|
|
|
#define HUGETLBFS_MAGIC 0x958458f6 /* some random number */
|
2009-01-16 05:51:03 +08:00
|
|
|
#define SQUASHFS_MAGIC 0x73717368
|
2010-11-03 18:11:15 +08:00
|
|
|
#define ECRYPTFS_SUPER_MAGIC 0xf15f
|
2006-09-24 23:13:19 +08:00
|
|
|
#define EFS_SUPER_MAGIC 0x414A53
|
|
|
|
#define EXT2_SUPER_MAGIC 0xEF53
|
|
|
|
#define EXT3_SUPER_MAGIC 0xEF53
|
2009-01-08 10:07:11 +08:00
|
|
|
#define XENFS_SUPER_MAGIC 0xabba1974
|
2006-10-11 16:20:56 +08:00
|
|
|
#define EXT4_SUPER_MAGIC 0xEF53
|
2009-01-16 05:51:03 +08:00
|
|
|
#define BTRFS_SUPER_MAGIC 0x9123683E
|
2011-03-10 15:54:15 +08:00
|
|
|
#define NILFS_SUPER_MAGIC 0x3434
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
#define F2FS_SUPER_MAGIC 0xF2F52010
|
2006-09-24 23:13:19 +08:00
|
|
|
#define HPFS_SUPER_MAGIC 0xf995e849
|
|
|
|
#define ISOFS_SUPER_MAGIC 0x9660
|
|
|
|
#define JFFS2_SUPER_MAGIC 0x72b6
|
2010-12-29 06:25:21 +08:00
|
|
|
#define PSTOREFS_MAGIC 0x6165676C
|
2012-10-22 22:51:45 +08:00
|
|
|
#define EFIVARFS_MAGIC 0xde5e81e4
|
2013-03-27 18:47:13 +08:00
|
|
|
#define HOSTFS_SUPER_MAGIC 0x00c0ffee
|
2015-11-05 02:59:52 +08:00
|
|
|
#define OVERLAYFS_SUPER_MAGIC 0x794c7630
|
2006-09-24 23:13:19 +08:00
|
|
|
|
2011-11-03 04:37:58 +08:00
|
|
|
#define MINIX_SUPER_MAGIC 0x137F /* minix v1 fs, 14 char names */
|
|
|
|
#define MINIX_SUPER_MAGIC2 0x138F /* minix v1 fs, 30 char names */
|
|
|
|
#define MINIX2_SUPER_MAGIC 0x2468 /* minix v2 fs, 14 char names */
|
|
|
|
#define MINIX2_SUPER_MAGIC2 0x2478 /* minix v2 fs, 30 char names */
|
|
|
|
#define MINIX3_SUPER_MAGIC 0x4d5a /* minix v3 fs, 60 char names */
|
2006-09-24 23:13:19 +08:00
|
|
|
|
|
|
|
#define MSDOS_SUPER_MAGIC 0x4d44 /* MD */
|
|
|
|
#define NCP_SUPER_MAGIC 0x564c /* Guess, what 0x564c is :-) */
|
|
|
|
#define NFS_SUPER_MAGIC 0x6969
|
|
|
|
#define OPENPROM_SUPER_MAGIC 0x9fa1
|
|
|
|
#define QNX4_SUPER_MAGIC 0x002f /* qnx4 fs detection */
|
2012-02-17 12:59:20 +08:00
|
|
|
#define QNX6_SUPER_MAGIC 0x68191122 /* qnx6 fs detection */
|
2006-09-24 23:13:19 +08:00
|
|
|
|
|
|
|
#define REISERFS_SUPER_MAGIC 0x52654973 /* used by gcc */
|
|
|
|
/* used by file system utilities that
|
|
|
|
look at the superblock, etc. */
|
|
|
|
#define REISERFS_SUPER_MAGIC_STRING "ReIsErFs"
|
|
|
|
#define REISER2FS_SUPER_MAGIC_STRING "ReIsEr2Fs"
|
|
|
|
#define REISER2FS_JR_SUPER_MAGIC_STRING "ReIsEr3Fs"
|
|
|
|
|
|
|
|
#define SMB_SUPER_MAGIC 0x517B
|
Task Control Groups: basic task cgroup framework
Generic Process Control Groups
--------------------------
There have recently been various proposals floating around for
resource management/accounting and other task grouping subsystems in
the kernel, including ResGroups, User BeanCounters, NSProxy
cgroups, and others. These all need the basic abstraction of being
able to group together multiple processes in an aggregate, in order to
track/limit the resources permitted to those processes, or control
other behaviour of the processes, and all implement this grouping in
different ways.
This patchset provides a framework for tracking and grouping processes
into arbitrary "cgroups" and assigning arbitrary state to those
groupings, in order to control the behaviour of the cgroup as an
aggregate.
The intention is that the various resource management and
virtualization/cgroup efforts can also become task cgroup
clients, with the result that:
- the userspace APIs are (somewhat) normalised
- it's easier to test e.g. the ResGroups CPU controller in
conjunction with the BeanCounters memory controller, or use either of
them as the resource-control portion of a virtual server system.
- the additional kernel footprint of any of the competing resource
management systems is substantially reduced, since it doesn't need
to provide process grouping/containment, hence improving their
chances of getting into the kernel
This patch:
Add the main task cgroups framework - the cgroup filesystem, and the
basic structures for tracking membership and associating subsystem state
objects to tasks.
Signed-off-by: Paul Menage <menage@google.com>
Cc: Serge E. Hallyn <serue@us.ibm.com>
Cc: "Eric W. Biederman" <ebiederm@xmission.com>
Cc: Dave Hansen <haveblue@us.ibm.com>
Cc: Balbir Singh <balbir@in.ibm.com>
Cc: Paul Jackson <pj@sgi.com>
Cc: Kirill Korotaev <dev@openvz.org>
Cc: Herbert Poetzl <herbert@13thfloor.at>
Cc: Srivatsa Vaddagiri <vatsa@in.ibm.com>
Cc: Cedric Le Goater <clg@fr.ibm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-10-19 14:39:30 +08:00
|
|
|
#define CGROUP_SUPER_MAGIC 0x27e0eb
|
2015-11-17 00:13:34 +08:00
|
|
|
#define CGROUP2_SUPER_MAGIC 0x63677270
|
2006-09-24 23:13:19 +08:00
|
|
|
|
2007-10-17 14:30:13 +08:00
|
|
|
|
2008-04-23 05:38:23 +08:00
|
|
|
#define STACK_END_MAGIC 0x57AC6E9D
|
2009-09-23 07:43:33 +08:00
|
|
|
|
2015-01-21 00:36:55 +08:00
|
|
|
#define TRACEFS_MAGIC 0x74726163
|
|
|
|
|
2012-03-24 06:01:50 +08:00
|
|
|
#define V9FS_MAGIC 0x01021997
|
|
|
|
|
|
|
|
#define BDEVFS_MAGIC 0x62646576
|
|
|
|
#define BINFMTFS_MAGIC 0x42494e4d
|
2009-09-23 07:43:33 +08:00
|
|
|
#define DEVPTS_SUPER_MAGIC 0x1cd1
|
2012-03-24 06:01:50 +08:00
|
|
|
#define FUTEXFS_SUPER_MAGIC 0xBAD1DEA
|
|
|
|
#define PIPEFS_MAGIC 0x50495045
|
|
|
|
#define PROC_SUPER_MAGIC 0x9fa0
|
2009-09-23 07:43:33 +08:00
|
|
|
#define SOCKFS_MAGIC 0x534F434B
|
2012-03-24 06:01:50 +08:00
|
|
|
#define SYSFS_MAGIC 0x62656572
|
|
|
|
#define USBDEVICE_SUPER_MAGIC 0x9fa2
|
|
|
|
#define MTD_INODE_FS_MAGIC 0x11307854
|
|
|
|
#define ANON_INODE_FS_MAGIC 0x09041934
|
2013-10-10 00:00:56 +08:00
|
|
|
#define BTRFS_TEST_MAGIC 0x73727279
|
take the targets of /proc/*/ns/* symlinks to separate fs
New pseudo-filesystem: nsfs. Targets of /proc/*/ns/* live there now.
It's not mountable (not even registered, so it's not in /proc/filesystems,
etc.). Files on it *are* bindable - we explicitly permit that in do_loopback().
This stuff lives in fs/nsfs.c now; proc_ns_fget() moved there as well.
get_proc_ns() is a macro now (it's simply returning ->i_private; would
have been an inline, if not for header ordering headache).
proc_ns_inode() is an ex-parrot. The interface used in procfs is
ns_get_path(path, task, ops) and ns_get_name(buf, size, task, ops).
Dentries and inodes are never hashed; a non-counting reference to dentry
is stashed in ns_common (removed by ->d_prune()) and reused by ns_get_path()
if present. See ns_get_path()/ns_prune_dentry/nsfs_evict() for details
of that mechanism.
As the result, proc_ns_follow_link() has stopped poking in nd->path.mnt;
it does nd_jump_link() on a consistent <vfsmount,dentry> pair it gets
from ns_get_path().
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
2014-11-01 22:57:28 +08:00
|
|
|
#define NSFS_MAGIC 0x6e736673
|
2015-10-29 21:58:09 +08:00
|
|
|
#define BPF_FS_MAGIC 0xcafe4a11
|
2009-09-23 07:43:33 +08:00
|
|
|
|
2006-09-24 23:13:19 +08:00
|
|
|
#endif /* __LINUX_MAGIC_H__ */
|