V4L/DVB (6573): unexport flexcop_reset_block_300
[deliverable/linux.git] / fs / gfs2 / main.c
CommitLineData
b3b94faa
DT
1/*
2 * Copyright (C) Sistina Software, Inc. 1997-2003 All rights reserved.
3a8a9a10 3 * Copyright (C) 2004-2006 Red Hat, Inc. All rights reserved.
b3b94faa
DT
4 *
5 * This copyrighted material is made available to anyone wishing to use,
6 * modify, copy, or redistribute it subject to the terms and conditions
e9fc2aa0 7 * of the GNU General Public License version 2.
b3b94faa
DT
8 */
9
b3b94faa
DT
10#include <linux/slab.h>
11#include <linux/spinlock.h>
12#include <linux/completion.h>
13#include <linux/buffer_head.h>
14#include <linux/module.h>
15#include <linux/init.h>
5c676f6d 16#include <linux/gfs2_ondisk.h>
7d308590 17#include <linux/lm_interface.h>
ec45d9f5 18#include <asm/atomic.h>
b3b94faa
DT
19
20#include "gfs2.h"
5c676f6d 21#include "incore.h"
b3b94faa
DT
22#include "ops_fstype.h"
23#include "sys.h"
5c676f6d 24#include "util.h"
85d1da67 25#include "glock.h"
b3b94faa 26
4ba9b9d0 27static void gfs2_init_inode_once(struct kmem_cache *cachep, void *foo)
320dd101
SW
28{
29 struct gfs2_inode *ip = foo;
a35afb83
CL
30
31 inode_init_once(&ip->i_inode);
a35afb83 32 init_rwsem(&ip->i_rw_mutex);
6dbd8224 33 ip->i_alloc = NULL;
320dd101
SW
34}
35
4ba9b9d0 36static void gfs2_init_glock_once(struct kmem_cache *cachep, void *foo)
ec45d9f5
SW
37{
38 struct gfs2_glock *gl = foo;
a35afb83
CL
39
40 INIT_HLIST_NODE(&gl->gl_list);
41 spin_lock_init(&gl->gl_spin);
42 INIT_LIST_HEAD(&gl->gl_holders);
43 INIT_LIST_HEAD(&gl->gl_waiters1);
44 INIT_LIST_HEAD(&gl->gl_waiters3);
45 gl->gl_lvb = NULL;
46 atomic_set(&gl->gl_lvb_count, 0);
47 INIT_LIST_HEAD(&gl->gl_reclaim);
48 INIT_LIST_HEAD(&gl->gl_ail_list);
49 atomic_set(&gl->gl_ail_count, 0);
ec45d9f5
SW
50}
51
b3b94faa
DT
52/**
53 * init_gfs2_fs - Register GFS2 as a filesystem
54 *
55 * Returns: 0 on success, error code on failure
56 */
57
58static int __init init_gfs2_fs(void)
59{
60 int error;
61
b3b94faa
DT
62 error = gfs2_sys_init();
63 if (error)
64 return error;
65
85d1da67
SW
66 error = gfs2_glock_init();
67 if (error)
68 goto fail;
b3b94faa 69
85d1da67 70 error = -ENOMEM;
b3b94faa
DT
71 gfs2_glock_cachep = kmem_cache_create("gfs2_glock",
72 sizeof(struct gfs2_glock),
907b9bce 73 0, 0,
20c2df83 74 gfs2_init_glock_once);
b3b94faa
DT
75 if (!gfs2_glock_cachep)
76 goto fail;
77
78 gfs2_inode_cachep = kmem_cache_create("gfs2_inode",
79 sizeof(struct gfs2_inode),
eb1dc33a
AD
80 0, SLAB_RECLAIM_ACCOUNT|
81 SLAB_MEM_SPREAD,
20c2df83 82 gfs2_init_inode_once);
b3b94faa
DT
83 if (!gfs2_inode_cachep)
84 goto fail;
85
86 gfs2_bufdata_cachep = kmem_cache_create("gfs2_bufdata",
87 sizeof(struct gfs2_bufdata),
20c2df83 88 0, 0, NULL);
b3b94faa
DT
89 if (!gfs2_bufdata_cachep)
90 goto fail;
91
92 error = register_filesystem(&gfs2_fs_type);
93 if (error)
94 goto fail;
95
419c93e0
SW
96 error = register_filesystem(&gfs2meta_fs_type);
97 if (error)
98 goto fail_unregister;
99
7c52b166
RP
100 gfs2_register_debugfs();
101
b3b94faa
DT
102 printk("GFS2 (built %s %s) installed\n", __DATE__, __TIME__);
103
104 return 0;
105
419c93e0
SW
106fail_unregister:
107 unregister_filesystem(&gfs2_fs_type);
108fail:
8fbbfd21
SW
109 gfs2_glock_exit();
110
b3b94faa
DT
111 if (gfs2_bufdata_cachep)
112 kmem_cache_destroy(gfs2_bufdata_cachep);
113
114 if (gfs2_inode_cachep)
115 kmem_cache_destroy(gfs2_inode_cachep);
116
117 if (gfs2_glock_cachep)
118 kmem_cache_destroy(gfs2_glock_cachep);
119
120 gfs2_sys_uninit();
121 return error;
122}
123
124/**
125 * exit_gfs2_fs - Unregister the file system
126 *
127 */
128
129static void __exit exit_gfs2_fs(void)
130{
8fbbfd21 131 gfs2_glock_exit();
7c52b166 132 gfs2_unregister_debugfs();
b3b94faa 133 unregister_filesystem(&gfs2_fs_type);
419c93e0 134 unregister_filesystem(&gfs2meta_fs_type);
b3b94faa
DT
135
136 kmem_cache_destroy(gfs2_bufdata_cachep);
137 kmem_cache_destroy(gfs2_inode_cachep);
138 kmem_cache_destroy(gfs2_glock_cachep);
139
140 gfs2_sys_uninit();
141}
142
143MODULE_DESCRIPTION("Global File System");
144MODULE_AUTHOR("Red Hat, Inc.");
145MODULE_LICENSE("GPL");
146
147module_init(init_gfs2_fs);
148module_exit(exit_gfs2_fs);
149
This page took 0.16741 seconds and 5 git commands to generate.