diff options
author | Christoph Hellwig <hch@infradead.org> | 2008-07-18 03:11:46 -0400 |
---|---|---|
committer | Niv Sardi <xaiki@debian.org> | 2008-07-28 02:59:25 -0400 |
commit | 9f8868ffb39c2f80ba69df4552cb530b6634f646 (patch) | |
tree | fba09366faf55ee039cdbd91dff78b7d87a86d0b /fs/xfs | |
parent | 136f8f21b6d564f553abe6130127d16fb50432d3 (diff) |
[XFS] streamline init/exit path
Currently the xfs module init/exit code is a mess. It's farmed out over a
lot of function with very little error checking. This patch makes sure we
propagate all initialization failures properly and clean up after them.
Various runtime initializations are replaced with compile-time
initializations where possible to make this easier. The exit path is
similarly consolidated.
There's now split out function to create/destroy the kmem zones and
alloc/free the trace buffers. I've also changed the ktrace allocations to
KM_MAYFAIL and handled errors resulting from that.
And yes, we really should replace the XFS_*_TRACE ifdefs with a single
XFS_TRACE..
SGI-PV: 976035
SGI-Modid: xfs-linux-melb:xfs-kern:31354a
Signed-off-by: Christoph Hellwig <hch@infradead.org>
Signed-off-by: Niv Sardi <xaiki@sgi.com>
Signed-off-by: Lachlan McIlroy <lachlan@sgi.com>
Diffstat (limited to 'fs/xfs')
-rw-r--r-- | fs/xfs/linux-2.6/xfs_stats.c | 15 | ||||
-rw-r--r-- | fs/xfs/linux-2.6/xfs_stats.h | 11 | ||||
-rw-r--r-- | fs/xfs/linux-2.6/xfs_super.c | 330 | ||||
-rw-r--r-- | fs/xfs/linux-2.6/xfs_sysctl.c | 8 | ||||
-rw-r--r-- | fs/xfs/linux-2.6/xfs_sysctl.h | 4 | ||||
-rw-r--r-- | fs/xfs/support/uuid.c | 8 | ||||
-rw-r--r-- | fs/xfs/support/uuid.h | 1 | ||||
-rw-r--r-- | fs/xfs/xfs_da_btree.c | 2 | ||||
-rw-r--r-- | fs/xfs/xfs_error.c | 8 | ||||
-rw-r--r-- | fs/xfs/xfs_error.h | 1 | ||||
-rw-r--r-- | fs/xfs/xfs_filestream.c | 4 | ||||
-rw-r--r-- | fs/xfs/xfs_mount.h | 3 | ||||
-rw-r--r-- | fs/xfs/xfs_mru_cache.c | 13 | ||||
-rw-r--r-- | fs/xfs/xfs_vfsops.c | 131 |
14 files changed, 318 insertions, 221 deletions
diff --git a/fs/xfs/linux-2.6/xfs_stats.c b/fs/xfs/linux-2.6/xfs_stats.c index e480b6102051..3d5b67c075c7 100644 --- a/fs/xfs/linux-2.6/xfs_stats.c +++ b/fs/xfs/linux-2.6/xfs_stats.c | |||
@@ -98,12 +98,21 @@ xfs_read_xfsstats( | |||
98 | return len; | 98 | return len; |
99 | } | 99 | } |
100 | 100 | ||
101 | void | 101 | int |
102 | xfs_init_procfs(void) | 102 | xfs_init_procfs(void) |
103 | { | 103 | { |
104 | if (!proc_mkdir("fs/xfs", NULL)) | 104 | if (!proc_mkdir("fs/xfs", NULL)) |
105 | return; | 105 | goto out; |
106 | create_proc_read_entry("fs/xfs/stat", 0, NULL, xfs_read_xfsstats, NULL); | 106 | |
107 | if (!create_proc_read_entry("fs/xfs/stat", 0, NULL, | ||
108 | xfs_read_xfsstats, NULL)) | ||
109 | goto out_remove_entry; | ||
110 | return 0; | ||
111 | |||
112 | out_remove_entry: | ||
113 | remove_proc_entry("fs/xfs", NULL); | ||
114 | out: | ||
115 | return -ENOMEM; | ||
107 | } | 116 | } |
108 | 117 | ||
109 | void | 118 | void |
diff --git a/fs/xfs/linux-2.6/xfs_stats.h b/fs/xfs/linux-2.6/xfs_stats.h index afd0b0d5fdb2..3fa753d7b700 100644 --- a/fs/xfs/linux-2.6/xfs_stats.h +++ b/fs/xfs/linux-2.6/xfs_stats.h | |||
@@ -134,7 +134,7 @@ DECLARE_PER_CPU(struct xfsstats, xfsstats); | |||
134 | #define XFS_STATS_DEC(v) (per_cpu(xfsstats, current_cpu()).v--) | 134 | #define XFS_STATS_DEC(v) (per_cpu(xfsstats, current_cpu()).v--) |
135 | #define XFS_STATS_ADD(v, inc) (per_cpu(xfsstats, current_cpu()).v += (inc)) | 135 | #define XFS_STATS_ADD(v, inc) (per_cpu(xfsstats, current_cpu()).v += (inc)) |
136 | 136 | ||
137 | extern void xfs_init_procfs(void); | 137 | extern int xfs_init_procfs(void); |
138 | extern void xfs_cleanup_procfs(void); | 138 | extern void xfs_cleanup_procfs(void); |
139 | 139 | ||
140 | 140 | ||
@@ -144,8 +144,13 @@ extern void xfs_cleanup_procfs(void); | |||
144 | # define XFS_STATS_DEC(count) | 144 | # define XFS_STATS_DEC(count) |
145 | # define XFS_STATS_ADD(count, inc) | 145 | # define XFS_STATS_ADD(count, inc) |
146 | 146 | ||
147 | static inline void xfs_init_procfs(void) { }; | 147 | static inline int xfs_init_procfs(void) |
148 | static inline void xfs_cleanup_procfs(void) { }; | 148 | { |
149 | return 0 | ||
150 | }; | ||
151 | static inline void xfs_cleanup_procfs(void) | ||
152 | { | ||
153 | }; | ||
149 | 154 | ||
150 | #endif /* !CONFIG_PROC_FS */ | 155 | #endif /* !CONFIG_PROC_FS */ |
151 | 156 | ||
diff --git a/fs/xfs/linux-2.6/xfs_super.c b/fs/xfs/linux-2.6/xfs_super.c index 967603c46998..7c621dfee73d 100644 --- a/fs/xfs/linux-2.6/xfs_super.c +++ b/fs/xfs/linux-2.6/xfs_super.c | |||
@@ -53,6 +53,11 @@ | |||
53 | #include "xfs_log_priv.h" | 53 | #include "xfs_log_priv.h" |
54 | #include "xfs_trans_priv.h" | 54 | #include "xfs_trans_priv.h" |
55 | #include "xfs_filestream.h" | 55 | #include "xfs_filestream.h" |
56 | #include "xfs_da_btree.h" | ||
57 | #include "xfs_dir2_trace.h" | ||
58 | #include "xfs_extfree_item.h" | ||
59 | #include "xfs_mru_cache.h" | ||
60 | #include "xfs_inode_item.h" | ||
56 | 61 | ||
57 | #include <linux/namei.h> | 62 | #include <linux/namei.h> |
58 | #include <linux/init.h> | 63 | #include <linux/init.h> |
@@ -987,42 +992,6 @@ xfs_fs_inode_init_once( | |||
987 | inode_init_once(vn_to_inode((bhv_vnode_t *)vnode)); | 992 | inode_init_once(vn_to_inode((bhv_vnode_t *)vnode)); |
988 | } | 993 | } |
989 | 994 | ||
990 | STATIC int __init | ||
991 | xfs_init_zones(void) | ||
992 | { | ||
993 | xfs_vnode_zone = kmem_zone_init_flags(sizeof(bhv_vnode_t), "xfs_vnode", | ||
994 | KM_ZONE_HWALIGN | KM_ZONE_RECLAIM | | ||
995 | KM_ZONE_SPREAD, | ||
996 | xfs_fs_inode_init_once); | ||
997 | if (!xfs_vnode_zone) | ||
998 | goto out; | ||
999 | |||
1000 | xfs_ioend_zone = kmem_zone_init(sizeof(xfs_ioend_t), "xfs_ioend"); | ||
1001 | if (!xfs_ioend_zone) | ||
1002 | goto out_destroy_vnode_zone; | ||
1003 | |||
1004 | xfs_ioend_pool = mempool_create_slab_pool(4 * MAX_BUF_PER_PAGE, | ||
1005 | xfs_ioend_zone); | ||
1006 | if (!xfs_ioend_pool) | ||
1007 | goto out_free_ioend_zone; | ||
1008 | return 0; | ||
1009 | |||
1010 | out_free_ioend_zone: | ||
1011 | kmem_zone_destroy(xfs_ioend_zone); | ||
1012 | out_destroy_vnode_zone: | ||
1013 | kmem_zone_destroy(xfs_vnode_zone); | ||
1014 | out: | ||
1015 | return -ENOMEM; | ||
1016 | } | ||
1017 | |||
1018 | STATIC void | ||
1019 | xfs_destroy_zones(void) | ||
1020 | { | ||
1021 | mempool_destroy(xfs_ioend_pool); | ||
1022 | kmem_zone_destroy(xfs_vnode_zone); | ||
1023 | kmem_zone_destroy(xfs_ioend_zone); | ||
1024 | } | ||
1025 | |||
1026 | /* | 995 | /* |
1027 | * Attempt to flush the inode, this will actually fail | 996 | * Attempt to flush the inode, this will actually fail |
1028 | * if the inode is pinned, but we dirty the inode again | 997 | * if the inode is pinned, but we dirty the inode again |
@@ -1939,9 +1908,235 @@ static struct file_system_type xfs_fs_type = { | |||
1939 | .fs_flags = FS_REQUIRES_DEV, | 1908 | .fs_flags = FS_REQUIRES_DEV, |
1940 | }; | 1909 | }; |
1941 | 1910 | ||
1911 | STATIC int __init | ||
1912 | xfs_alloc_trace_bufs(void) | ||
1913 | { | ||
1914 | #ifdef XFS_ALLOC_TRACE | ||
1915 | xfs_alloc_trace_buf = ktrace_alloc(XFS_ALLOC_TRACE_SIZE, KM_MAYFAIL); | ||
1916 | if (!xfs_alloc_trace_buf) | ||
1917 | goto out; | ||
1918 | #endif | ||
1919 | #ifdef XFS_BMAP_TRACE | ||
1920 | xfs_bmap_trace_buf = ktrace_alloc(XFS_BMAP_TRACE_SIZE, KM_MAYFAIL); | ||
1921 | if (!xfs_bmap_trace_buf) | ||
1922 | goto out_free_alloc_trace; | ||
1923 | #endif | ||
1924 | #ifdef XFS_BMBT_TRACE | ||
1925 | xfs_bmbt_trace_buf = ktrace_alloc(XFS_BMBT_TRACE_SIZE, KM_MAYFAIL); | ||
1926 | if (!xfs_bmbt_trace_buf) | ||
1927 | goto out_free_bmap_trace; | ||
1928 | #endif | ||
1929 | #ifdef XFS_ATTR_TRACE | ||
1930 | xfs_attr_trace_buf = ktrace_alloc(XFS_ATTR_TRACE_SIZE, KM_MAYFAIL); | ||
1931 | if (!xfs_attr_trace_buf) | ||
1932 | goto out_free_bmbt_trace; | ||
1933 | #endif | ||
1934 | #ifdef XFS_DIR2_TRACE | ||
1935 | xfs_dir2_trace_buf = ktrace_alloc(XFS_DIR2_GTRACE_SIZE, KM_MAYFAIL); | ||
1936 | if (!xfs_dir2_trace_buf) | ||
1937 | goto out_free_attr_trace; | ||
1938 | #endif | ||
1939 | |||
1940 | return 0; | ||
1941 | |||
1942 | #ifdef XFS_DIR2_TRACE | ||
1943 | out_free_attr_trace: | ||
1944 | #endif | ||
1945 | #ifdef XFS_ATTR_TRACE | ||
1946 | ktrace_free(xfs_attr_trace_buf); | ||
1947 | out_free_bmbt_trace: | ||
1948 | #endif | ||
1949 | #ifdef XFS_BMBT_TRACE | ||
1950 | ktrace_free(xfs_bmbt_trace_buf); | ||
1951 | out_free_bmap_trace: | ||
1952 | #endif | ||
1953 | #ifdef XFS_BMAP_TRACE | ||
1954 | ktrace_free(xfs_bmap_trace_buf); | ||
1955 | out_free_alloc_trace: | ||
1956 | #endif | ||
1957 | #ifdef XFS_ALLOC_TRACE | ||
1958 | ktrace_free(xfs_alloc_trace_buf); | ||
1959 | out: | ||
1960 | #endif | ||
1961 | return -ENOMEM; | ||
1962 | } | ||
1963 | |||
1964 | STATIC void | ||
1965 | xfs_free_trace_bufs(void) | ||
1966 | { | ||
1967 | #ifdef XFS_DIR2_TRACE | ||
1968 | ktrace_free(xfs_dir2_trace_buf); | ||
1969 | #endif | ||
1970 | #ifdef XFS_ATTR_TRACE | ||
1971 | ktrace_free(xfs_attr_trace_buf); | ||
1972 | #endif | ||
1973 | #ifdef XFS_BMBT_TRACE | ||
1974 | ktrace_free(xfs_bmbt_trace_buf); | ||
1975 | #endif | ||
1976 | #ifdef XFS_BMAP_TRACE | ||
1977 | ktrace_free(xfs_bmap_trace_buf); | ||
1978 | #endif | ||
1979 | #ifdef XFS_ALLOC_TRACE | ||
1980 | ktrace_free(xfs_alloc_trace_buf); | ||
1981 | #endif | ||
1982 | } | ||
1983 | |||
1984 | STATIC int __init | ||
1985 | xfs_init_zones(void) | ||
1986 | { | ||
1987 | xfs_vnode_zone = kmem_zone_init_flags(sizeof(bhv_vnode_t), "xfs_vnode", | ||
1988 | KM_ZONE_HWALIGN | KM_ZONE_RECLAIM | | ||
1989 | KM_ZONE_SPREAD, | ||
1990 | xfs_fs_inode_init_once); | ||
1991 | if (!xfs_vnode_zone) | ||
1992 | goto out; | ||
1993 | |||
1994 | xfs_ioend_zone = kmem_zone_init(sizeof(xfs_ioend_t), "xfs_ioend"); | ||
1995 | if (!xfs_ioend_zone) | ||
1996 | goto out_destroy_vnode_zone; | ||
1997 | |||
1998 | xfs_ioend_pool = mempool_create_slab_pool(4 * MAX_BUF_PER_PAGE, | ||
1999 | xfs_ioend_zone); | ||
2000 | if (!xfs_ioend_pool) | ||
2001 | goto out_destroy_ioend_zone; | ||
2002 | |||
2003 | xfs_log_ticket_zone = kmem_zone_init(sizeof(xlog_ticket_t), | ||
2004 | "xfs_log_ticket"); | ||
2005 | if (!xfs_log_ticket_zone) | ||
2006 | goto out_destroy_ioend_pool; | ||
2007 | |||
2008 | xfs_bmap_free_item_zone = kmem_zone_init(sizeof(xfs_bmap_free_item_t), | ||
2009 | "xfs_bmap_free_item"); | ||
2010 | if (!xfs_bmap_free_item_zone) | ||
2011 | goto out_destroy_log_ticket_zone; | ||
2012 | xfs_btree_cur_zone = kmem_zone_init(sizeof(xfs_btree_cur_t), | ||
2013 | "xfs_btree_cur"); | ||
2014 | if (!xfs_btree_cur_zone) | ||
2015 | goto out_destroy_bmap_free_item_zone; | ||
2016 | |||
2017 | xfs_da_state_zone = kmem_zone_init(sizeof(xfs_da_state_t), | ||
2018 | "xfs_da_state"); | ||
2019 | if (!xfs_da_state_zone) | ||
2020 | goto out_destroy_btree_cur_zone; | ||
2021 | |||
2022 | xfs_dabuf_zone = kmem_zone_init(sizeof(xfs_dabuf_t), "xfs_dabuf"); | ||
2023 | if (!xfs_dabuf_zone) | ||
2024 | goto out_destroy_da_state_zone; | ||
2025 | |||
2026 | xfs_ifork_zone = kmem_zone_init(sizeof(xfs_ifork_t), "xfs_ifork"); | ||
2027 | if (!xfs_ifork_zone) | ||
2028 | goto out_destroy_dabuf_zone; | ||
2029 | |||
2030 | xfs_trans_zone = kmem_zone_init(sizeof(xfs_trans_t), "xfs_trans"); | ||
2031 | if (!xfs_trans_zone) | ||
2032 | goto out_destroy_ifork_zone; | ||
2033 | |||
2034 | /* | ||
2035 | * The size of the zone allocated buf log item is the maximum | ||
2036 | * size possible under XFS. This wastes a little bit of memory, | ||
2037 | * but it is much faster. | ||
2038 | */ | ||
2039 | xfs_buf_item_zone = kmem_zone_init((sizeof(xfs_buf_log_item_t) + | ||
2040 | (((XFS_MAX_BLOCKSIZE / XFS_BLI_CHUNK) / | ||
2041 | NBWORD) * sizeof(int))), "xfs_buf_item"); | ||
2042 | if (!xfs_buf_item_zone) | ||
2043 | goto out_destroy_trans_zone; | ||
2044 | |||
2045 | xfs_efd_zone = kmem_zone_init((sizeof(xfs_efd_log_item_t) + | ||
2046 | ((XFS_EFD_MAX_FAST_EXTENTS - 1) * | ||
2047 | sizeof(xfs_extent_t))), "xfs_efd_item"); | ||
2048 | if (!xfs_efd_zone) | ||
2049 | goto out_destroy_buf_item_zone; | ||
2050 | |||
2051 | xfs_efi_zone = kmem_zone_init((sizeof(xfs_efi_log_item_t) + | ||
2052 | ((XFS_EFI_MAX_FAST_EXTENTS - 1) * | ||
2053 | sizeof(xfs_extent_t))), "xfs_efi_item"); | ||
2054 | if (!xfs_efi_zone) | ||
2055 | goto out_destroy_efd_zone; | ||
2056 | |||
2057 | xfs_inode_zone = | ||
2058 | kmem_zone_init_flags(sizeof(xfs_inode_t), "xfs_inode", | ||
2059 | KM_ZONE_HWALIGN | KM_ZONE_RECLAIM | | ||
2060 | KM_ZONE_SPREAD, NULL); | ||
2061 | if (!xfs_inode_zone) | ||
2062 | goto out_destroy_efi_zone; | ||
2063 | |||
2064 | xfs_ili_zone = | ||
2065 | kmem_zone_init_flags(sizeof(xfs_inode_log_item_t), "xfs_ili", | ||
2066 | KM_ZONE_SPREAD, NULL); | ||
2067 | if (!xfs_ili_zone) | ||
2068 | goto out_destroy_inode_zone; | ||
2069 | |||
2070 | #ifdef CONFIG_XFS_POSIX_ACL | ||
2071 | xfs_acl_zone = kmem_zone_init(sizeof(xfs_acl_t), "xfs_acl"); | ||
2072 | if (!xfs_acl_zone) | ||
2073 | goto out_destroy_ili_zone; | ||
2074 | #endif | ||
2075 | |||
2076 | return 0; | ||
2077 | |||
2078 | #ifdef CONFIG_XFS_POSIX_ACL | ||
2079 | out_destroy_ili_zone: | ||
2080 | #endif | ||
2081 | kmem_zone_destroy(xfs_ili_zone); | ||
2082 | out_destroy_inode_zone: | ||
2083 | kmem_zone_destroy(xfs_inode_zone); | ||
2084 | out_destroy_efi_zone: | ||
2085 | kmem_zone_destroy(xfs_efi_zone); | ||
2086 | out_destroy_efd_zone: | ||
2087 | kmem_zone_destroy(xfs_efd_zone); | ||
2088 | out_destroy_buf_item_zone: | ||
2089 | kmem_zone_destroy(xfs_buf_item_zone); | ||
2090 | out_destroy_trans_zone: | ||
2091 | kmem_zone_destroy(xfs_trans_zone); | ||
2092 | out_destroy_ifork_zone: | ||
2093 | kmem_zone_destroy(xfs_ifork_zone); | ||
2094 | out_destroy_dabuf_zone: | ||
2095 | kmem_zone_destroy(xfs_dabuf_zone); | ||
2096 | out_destroy_da_state_zone: | ||
2097 | kmem_zone_destroy(xfs_da_state_zone); | ||
2098 | out_destroy_btree_cur_zone: | ||
2099 | kmem_zone_destroy(xfs_btree_cur_zone); | ||
2100 | out_destroy_bmap_free_item_zone: | ||
2101 | kmem_zone_destroy(xfs_bmap_free_item_zone); | ||
2102 | out_destroy_log_ticket_zone: | ||
2103 | kmem_zone_destroy(xfs_log_ticket_zone); | ||
2104 | out_destroy_ioend_pool: | ||
2105 | mempool_destroy(xfs_ioend_pool); | ||
2106 | out_destroy_ioend_zone: | ||
2107 | kmem_zone_destroy(xfs_ioend_zone); | ||
2108 | out_destroy_vnode_zone: | ||
2109 | kmem_zone_destroy(xfs_vnode_zone); | ||
2110 | out: | ||
2111 | return -ENOMEM; | ||
2112 | } | ||
2113 | |||
2114 | STATIC void | ||
2115 | xfs_destroy_zones(void) | ||
2116 | { | ||
2117 | #ifdef CONFIG_XFS_POSIX_ACL | ||
2118 | kmem_zone_destroy(xfs_acl_zone); | ||
2119 | #endif | ||
2120 | kmem_zone_destroy(xfs_ili_zone); | ||
2121 | kmem_zone_destroy(xfs_inode_zone); | ||
2122 | kmem_zone_destroy(xfs_efi_zone); | ||
2123 | kmem_zone_destroy(xfs_efd_zone); | ||
2124 | kmem_zone_destroy(xfs_buf_item_zone); | ||
2125 | kmem_zone_destroy(xfs_trans_zone); | ||
2126 | kmem_zone_destroy(xfs_ifork_zone); | ||
2127 | kmem_zone_destroy(xfs_dabuf_zone); | ||
2128 | kmem_zone_destroy(xfs_da_state_zone); | ||
2129 | kmem_zone_destroy(xfs_btree_cur_zone); | ||
2130 | kmem_zone_destroy(xfs_bmap_free_item_zone); | ||
2131 | kmem_zone_destroy(xfs_log_ticket_zone); | ||
2132 | mempool_destroy(xfs_ioend_pool); | ||
2133 | kmem_zone_destroy(xfs_ioend_zone); | ||
2134 | kmem_zone_destroy(xfs_vnode_zone); | ||
2135 | |||
2136 | } | ||
1942 | 2137 | ||
1943 | STATIC int __init | 2138 | STATIC int __init |
1944 | init_xfs_fs( void ) | 2139 | init_xfs_fs(void) |
1945 | { | 2140 | { |
1946 | int error; | 2141 | int error; |
1947 | static char message[] __initdata = KERN_INFO \ | 2142 | static char message[] __initdata = KERN_INFO \ |
@@ -1950,42 +2145,73 @@ init_xfs_fs( void ) | |||
1950 | printk(message); | 2145 | printk(message); |
1951 | 2146 | ||
1952 | ktrace_init(64); | 2147 | ktrace_init(64); |
2148 | vn_init(); | ||
2149 | xfs_dir_startup(); | ||
1953 | 2150 | ||
1954 | error = xfs_init_zones(); | 2151 | error = xfs_init_zones(); |
1955 | if (error < 0) | 2152 | if (error) |
1956 | goto undo_zones; | 2153 | goto out; |
2154 | |||
2155 | error = xfs_alloc_trace_bufs(); | ||
2156 | if (error) | ||
2157 | goto out_destroy_zones; | ||
2158 | |||
2159 | error = xfs_mru_cache_init(); | ||
2160 | if (error) | ||
2161 | goto out_free_trace_buffers; | ||
2162 | |||
2163 | error = xfs_filestream_init(); | ||
2164 | if (error) | ||
2165 | goto out_mru_cache_uninit; | ||
1957 | 2166 | ||
1958 | error = xfs_buf_init(); | 2167 | error = xfs_buf_init(); |
1959 | if (error < 0) | 2168 | if (error) |
1960 | goto undo_buffers; | 2169 | goto out_filestream_uninit; |
2170 | |||
2171 | error = xfs_init_procfs(); | ||
2172 | if (error) | ||
2173 | goto out_buf_terminate; | ||
2174 | |||
2175 | error = xfs_sysctl_register(); | ||
2176 | if (error) | ||
2177 | goto out_cleanup_procfs; | ||
1961 | 2178 | ||
1962 | vn_init(); | ||
1963 | xfs_init(); | ||
1964 | uuid_init(); | ||
1965 | vfs_initquota(); | 2179 | vfs_initquota(); |
1966 | 2180 | ||
1967 | error = register_filesystem(&xfs_fs_type); | 2181 | error = register_filesystem(&xfs_fs_type); |
1968 | if (error) | 2182 | if (error) |
1969 | goto undo_register; | 2183 | goto out_sysctl_unregister; |
1970 | return 0; | 2184 | return 0; |
1971 | 2185 | ||
1972 | undo_register: | 2186 | out_sysctl_unregister: |
2187 | xfs_sysctl_unregister(); | ||
2188 | out_cleanup_procfs: | ||
2189 | xfs_cleanup_procfs(); | ||
2190 | out_buf_terminate: | ||
1973 | xfs_buf_terminate(); | 2191 | xfs_buf_terminate(); |
1974 | 2192 | out_filestream_uninit: | |
1975 | undo_buffers: | 2193 | xfs_filestream_uninit(); |
2194 | out_mru_cache_uninit: | ||
2195 | xfs_mru_cache_uninit(); | ||
2196 | out_free_trace_buffers: | ||
2197 | xfs_free_trace_bufs(); | ||
2198 | out_destroy_zones: | ||
1976 | xfs_destroy_zones(); | 2199 | xfs_destroy_zones(); |
1977 | 2200 | out: | |
1978 | undo_zones: | ||
1979 | return error; | 2201 | return error; |
1980 | } | 2202 | } |
1981 | 2203 | ||
1982 | STATIC void __exit | 2204 | STATIC void __exit |
1983 | exit_xfs_fs( void ) | 2205 | exit_xfs_fs(void) |
1984 | { | 2206 | { |
1985 | vfs_exitquota(); | 2207 | vfs_exitquota(); |
1986 | unregister_filesystem(&xfs_fs_type); | 2208 | unregister_filesystem(&xfs_fs_type); |
1987 | xfs_cleanup(); | 2209 | xfs_sysctl_unregister(); |
2210 | xfs_cleanup_procfs(); | ||
1988 | xfs_buf_terminate(); | 2211 | xfs_buf_terminate(); |
2212 | xfs_filestream_uninit(); | ||
2213 | xfs_mru_cache_uninit(); | ||
2214 | xfs_free_trace_bufs(); | ||
1989 | xfs_destroy_zones(); | 2215 | xfs_destroy_zones(); |
1990 | ktrace_uninit(); | 2216 | ktrace_uninit(); |
1991 | } | 2217 | } |
diff --git a/fs/xfs/linux-2.6/xfs_sysctl.c b/fs/xfs/linux-2.6/xfs_sysctl.c index bb997d75c05c..7dacb5bbde3f 100644 --- a/fs/xfs/linux-2.6/xfs_sysctl.c +++ b/fs/xfs/linux-2.6/xfs_sysctl.c | |||
@@ -259,15 +259,17 @@ static ctl_table xfs_root_table[] = { | |||
259 | {} | 259 | {} |
260 | }; | 260 | }; |
261 | 261 | ||
262 | void | 262 | int |
263 | xfs_sysctl_register(void) | 263 | xfs_sysctl_register(void) |
264 | { | 264 | { |
265 | xfs_table_header = register_sysctl_table(xfs_root_table); | 265 | xfs_table_header = register_sysctl_table(xfs_root_table); |
266 | if (!xfs_table_header) | ||
267 | return -ENOMEM; | ||
268 | return 0; | ||
266 | } | 269 | } |
267 | 270 | ||
268 | void | 271 | void |
269 | xfs_sysctl_unregister(void) | 272 | xfs_sysctl_unregister(void) |
270 | { | 273 | { |
271 | if (xfs_table_header) | 274 | unregister_sysctl_table(xfs_table_header); |
272 | unregister_sysctl_table(xfs_table_header); | ||
273 | } | 275 | } |
diff --git a/fs/xfs/linux-2.6/xfs_sysctl.h b/fs/xfs/linux-2.6/xfs_sysctl.h index 98b97e399d6f..4aadb8056c37 100644 --- a/fs/xfs/linux-2.6/xfs_sysctl.h +++ b/fs/xfs/linux-2.6/xfs_sysctl.h | |||
@@ -93,10 +93,10 @@ enum { | |||
93 | extern xfs_param_t xfs_params; | 93 | extern xfs_param_t xfs_params; |
94 | 94 | ||
95 | #ifdef CONFIG_SYSCTL | 95 | #ifdef CONFIG_SYSCTL |
96 | extern void xfs_sysctl_register(void); | 96 | extern int xfs_sysctl_register(void); |
97 | extern void xfs_sysctl_unregister(void); | 97 | extern void xfs_sysctl_unregister(void); |
98 | #else | 98 | #else |
99 | # define xfs_sysctl_register() do { } while (0) | 99 | # define xfs_sysctl_register() (0) |
100 | # define xfs_sysctl_unregister() do { } while (0) | 100 | # define xfs_sysctl_unregister() do { } while (0) |
101 | #endif /* CONFIG_SYSCTL */ | 101 | #endif /* CONFIG_SYSCTL */ |
102 | 102 | ||
diff --git a/fs/xfs/support/uuid.c b/fs/xfs/support/uuid.c index 493a6ecf8590..5830c040ea7e 100644 --- a/fs/xfs/support/uuid.c +++ b/fs/xfs/support/uuid.c | |||
@@ -17,7 +17,7 @@ | |||
17 | */ | 17 | */ |
18 | #include <xfs.h> | 18 | #include <xfs.h> |
19 | 19 | ||
20 | static mutex_t uuid_monitor; | 20 | static DEFINE_MUTEX(uuid_monitor); |
21 | static int uuid_table_size; | 21 | static int uuid_table_size; |
22 | static uuid_t *uuid_table; | 22 | static uuid_t *uuid_table; |
23 | 23 | ||
@@ -132,9 +132,3 @@ uuid_table_remove(uuid_t *uuid) | |||
132 | ASSERT(i < uuid_table_size); | 132 | ASSERT(i < uuid_table_size); |
133 | mutex_unlock(&uuid_monitor); | 133 | mutex_unlock(&uuid_monitor); |
134 | } | 134 | } |
135 | |||
136 | void __init | ||
137 | uuid_init(void) | ||
138 | { | ||
139 | mutex_init(&uuid_monitor); | ||
140 | } | ||
diff --git a/fs/xfs/support/uuid.h b/fs/xfs/support/uuid.h index b6f5922199ba..cff5b607d445 100644 --- a/fs/xfs/support/uuid.h +++ b/fs/xfs/support/uuid.h | |||
@@ -22,7 +22,6 @@ typedef struct { | |||
22 | unsigned char __u_bits[16]; | 22 | unsigned char __u_bits[16]; |
23 | } uuid_t; | 23 | } uuid_t; |
24 | 24 | ||
25 | extern void uuid_init(void); | ||
26 | extern void uuid_create_nil(uuid_t *uuid); | 25 | extern void uuid_create_nil(uuid_t *uuid); |
27 | extern int uuid_is_nil(uuid_t *uuid); | 26 | extern int uuid_is_nil(uuid_t *uuid); |
28 | extern int uuid_equal(uuid_t *uuid1, uuid_t *uuid2); | 27 | extern int uuid_equal(uuid_t *uuid1, uuid_t *uuid2); |
diff --git a/fs/xfs/xfs_da_btree.c b/fs/xfs/xfs_da_btree.c index edc0aef4e51e..9e561a9cefca 100644 --- a/fs/xfs/xfs_da_btree.c +++ b/fs/xfs/xfs_da_btree.c | |||
@@ -2240,7 +2240,7 @@ xfs_da_state_free(xfs_da_state_t *state) | |||
2240 | 2240 | ||
2241 | #ifdef XFS_DABUF_DEBUG | 2241 | #ifdef XFS_DABUF_DEBUG |
2242 | xfs_dabuf_t *xfs_dabuf_global_list; | 2242 | xfs_dabuf_t *xfs_dabuf_global_list; |
2243 | spinlock_t xfs_dabuf_global_lock; | 2243 | static DEFINE_SPINLOCK(xfs_dabuf_global_lock); |
2244 | #endif | 2244 | #endif |
2245 | 2245 | ||
2246 | /* | 2246 | /* |
diff --git a/fs/xfs/xfs_error.c b/fs/xfs/xfs_error.c index 7380a00644c8..f66756cfb5e8 100644 --- a/fs/xfs/xfs_error.c +++ b/fs/xfs/xfs_error.c | |||
@@ -66,14 +66,6 @@ int xfs_etest[XFS_NUM_INJECT_ERROR]; | |||
66 | int64_t xfs_etest_fsid[XFS_NUM_INJECT_ERROR]; | 66 | int64_t xfs_etest_fsid[XFS_NUM_INJECT_ERROR]; |
67 | char * xfs_etest_fsname[XFS_NUM_INJECT_ERROR]; | 67 | char * xfs_etest_fsname[XFS_NUM_INJECT_ERROR]; |
68 | 68 | ||
69 | void | ||
70 | xfs_error_test_init(void) | ||
71 | { | ||
72 | memset(xfs_etest, 0, sizeof(xfs_etest)); | ||
73 | memset(xfs_etest_fsid, 0, sizeof(xfs_etest_fsid)); | ||
74 | memset(xfs_etest_fsname, 0, sizeof(xfs_etest_fsname)); | ||
75 | } | ||
76 | |||
77 | int | 69 | int |
78 | xfs_error_test(int error_tag, int *fsidp, char *expression, | 70 | xfs_error_test(int error_tag, int *fsidp, char *expression, |
79 | int line, char *file, unsigned long randfactor) | 71 | int line, char *file, unsigned long randfactor) |
diff --git a/fs/xfs/xfs_error.h b/fs/xfs/xfs_error.h index 6490d2a9f8e1..d8559d132efa 100644 --- a/fs/xfs/xfs_error.h +++ b/fs/xfs/xfs_error.h | |||
@@ -127,7 +127,6 @@ extern void xfs_corruption_error(char *tag, int level, struct xfs_mount *mp, | |||
127 | 127 | ||
128 | #if (defined(DEBUG) || defined(INDUCE_IO_ERROR)) | 128 | #if (defined(DEBUG) || defined(INDUCE_IO_ERROR)) |
129 | extern int xfs_error_test(int, int *, char *, int, char *, unsigned long); | 129 | extern int xfs_error_test(int, int *, char *, int, char *, unsigned long); |
130 | extern void xfs_error_test_init(void); | ||
131 | 130 | ||
132 | #define XFS_NUM_INJECT_ERROR 10 | 131 | #define XFS_NUM_INJECT_ERROR 10 |
133 | 132 | ||
diff --git a/fs/xfs/xfs_filestream.c b/fs/xfs/xfs_filestream.c index 3f3785b10804..c38fd14fca29 100644 --- a/fs/xfs/xfs_filestream.c +++ b/fs/xfs/xfs_filestream.c | |||
@@ -397,10 +397,12 @@ int | |||
397 | xfs_filestream_init(void) | 397 | xfs_filestream_init(void) |
398 | { | 398 | { |
399 | item_zone = kmem_zone_init(sizeof(fstrm_item_t), "fstrm_item"); | 399 | item_zone = kmem_zone_init(sizeof(fstrm_item_t), "fstrm_item"); |
400 | if (!item_zone) | ||
401 | return -ENOMEM; | ||
400 | #ifdef XFS_FILESTREAMS_TRACE | 402 | #ifdef XFS_FILESTREAMS_TRACE |
401 | xfs_filestreams_trace_buf = ktrace_alloc(XFS_FSTRM_KTRACE_SIZE, KM_SLEEP); | 403 | xfs_filestreams_trace_buf = ktrace_alloc(XFS_FSTRM_KTRACE_SIZE, KM_SLEEP); |
402 | #endif | 404 | #endif |
403 | return item_zone ? 0 : -ENOMEM; | 405 | return 0; |
404 | } | 406 | } |
405 | 407 | ||
406 | /* | 408 | /* |
diff --git a/fs/xfs/xfs_mount.h b/fs/xfs/xfs_mount.h index 2a75f1703b39..5269bd6e3df0 100644 --- a/fs/xfs/xfs_mount.h +++ b/fs/xfs/xfs_mount.h | |||
@@ -546,9 +546,6 @@ extern void xfs_qmops_put(struct xfs_mount *); | |||
546 | 546 | ||
547 | extern struct xfs_dmops xfs_dmcore_xfs; | 547 | extern struct xfs_dmops xfs_dmcore_xfs; |
548 | 548 | ||
549 | extern int xfs_init(void); | ||
550 | extern void xfs_cleanup(void); | ||
551 | |||
552 | #endif /* __KERNEL__ */ | 549 | #endif /* __KERNEL__ */ |
553 | 550 | ||
554 | #endif /* __XFS_MOUNT_H__ */ | 551 | #endif /* __XFS_MOUNT_H__ */ |
diff --git a/fs/xfs/xfs_mru_cache.c b/fs/xfs/xfs_mru_cache.c index 26d14a1e0e14..afee7eb24323 100644 --- a/fs/xfs/xfs_mru_cache.c +++ b/fs/xfs/xfs_mru_cache.c | |||
@@ -307,15 +307,18 @@ xfs_mru_cache_init(void) | |||
307 | xfs_mru_elem_zone = kmem_zone_init(sizeof(xfs_mru_cache_elem_t), | 307 | xfs_mru_elem_zone = kmem_zone_init(sizeof(xfs_mru_cache_elem_t), |
308 | "xfs_mru_cache_elem"); | 308 | "xfs_mru_cache_elem"); |
309 | if (!xfs_mru_elem_zone) | 309 | if (!xfs_mru_elem_zone) |
310 | return ENOMEM; | 310 | goto out; |
311 | 311 | ||
312 | xfs_mru_reap_wq = create_singlethread_workqueue("xfs_mru_cache"); | 312 | xfs_mru_reap_wq = create_singlethread_workqueue("xfs_mru_cache"); |
313 | if (!xfs_mru_reap_wq) { | 313 | if (!xfs_mru_reap_wq) |
314 | kmem_zone_destroy(xfs_mru_elem_zone); | 314 | goto out_destroy_mru_elem_zone; |
315 | return ENOMEM; | ||
316 | } | ||
317 | 315 | ||
318 | return 0; | 316 | return 0; |
317 | |||
318 | out_destroy_mru_elem_zone: | ||
319 | kmem_zone_destroy(xfs_mru_elem_zone); | ||
320 | out: | ||
321 | return -ENOMEM; | ||
319 | } | 322 | } |
320 | 323 | ||
321 | void | 324 | void |
diff --git a/fs/xfs/xfs_vfsops.c b/fs/xfs/xfs_vfsops.c index 8b5a3376c2f7..4a9a43315a86 100644 --- a/fs/xfs/xfs_vfsops.c +++ b/fs/xfs/xfs_vfsops.c | |||
@@ -58,137 +58,6 @@ | |||
58 | #include "xfs_utils.h" | 58 | #include "xfs_utils.h" |
59 | 59 | ||
60 | 60 | ||
61 | int __init | ||
62 | xfs_init(void) | ||
63 | { | ||
64 | #ifdef XFS_DABUF_DEBUG | ||
65 | extern spinlock_t xfs_dabuf_global_lock; | ||
66 | spin_lock_init(&xfs_dabuf_global_lock); | ||
67 | #endif | ||
68 | |||
69 | /* | ||
70 | * Initialize all of the zone allocators we use. | ||
71 | */ | ||
72 | xfs_log_ticket_zone = kmem_zone_init(sizeof(xlog_ticket_t), | ||
73 | "xfs_log_ticket"); | ||
74 | xfs_bmap_free_item_zone = kmem_zone_init(sizeof(xfs_bmap_free_item_t), | ||
75 | "xfs_bmap_free_item"); | ||
76 | xfs_btree_cur_zone = kmem_zone_init(sizeof(xfs_btree_cur_t), | ||
77 | "xfs_btree_cur"); | ||
78 | xfs_da_state_zone = kmem_zone_init(sizeof(xfs_da_state_t), | ||
79 | "xfs_da_state"); | ||
80 | xfs_dabuf_zone = kmem_zone_init(sizeof(xfs_dabuf_t), "xfs_dabuf"); | ||
81 | xfs_ifork_zone = kmem_zone_init(sizeof(xfs_ifork_t), "xfs_ifork"); | ||
82 | xfs_trans_zone = kmem_zone_init(sizeof(xfs_trans_t), "xfs_trans"); | ||
83 | xfs_acl_zone_init(xfs_acl_zone, "xfs_acl"); | ||
84 | xfs_mru_cache_init(); | ||
85 | xfs_filestream_init(); | ||
86 | |||
87 | /* | ||
88 | * The size of the zone allocated buf log item is the maximum | ||
89 | * size possible under XFS. This wastes a little bit of memory, | ||
90 | * but it is much faster. | ||
91 | */ | ||
92 | xfs_buf_item_zone = | ||
93 | kmem_zone_init((sizeof(xfs_buf_log_item_t) + | ||
94 | (((XFS_MAX_BLOCKSIZE / XFS_BLI_CHUNK) / | ||
95 | NBWORD) * sizeof(int))), | ||
96 | "xfs_buf_item"); | ||
97 | xfs_efd_zone = | ||
98 | kmem_zone_init((sizeof(xfs_efd_log_item_t) + | ||
99 | ((XFS_EFD_MAX_FAST_EXTENTS - 1) * | ||
100 | sizeof(xfs_extent_t))), | ||
101 | "xfs_efd_item"); | ||
102 | xfs_efi_zone = | ||
103 | kmem_zone_init((sizeof(xfs_efi_log_item_t) + | ||
104 | ((XFS_EFI_MAX_FAST_EXTENTS - 1) * | ||
105 | sizeof(xfs_extent_t))), | ||
106 | "xfs_efi_item"); | ||
107 | |||
108 | /* | ||
109 | * These zones warrant special memory allocator hints | ||
110 | */ | ||
111 | xfs_inode_zone = | ||
112 | kmem_zone_init_flags(sizeof(xfs_inode_t), "xfs_inode", | ||
113 | KM_ZONE_HWALIGN | KM_ZONE_RECLAIM | | ||
114 | KM_ZONE_SPREAD, NULL); | ||
115 | xfs_ili_zone = | ||
116 | kmem_zone_init_flags(sizeof(xfs_inode_log_item_t), "xfs_ili", | ||
117 | KM_ZONE_SPREAD, NULL); | ||
118 | |||
119 | /* | ||
120 | * Allocate global trace buffers. | ||
121 | */ | ||
122 | #ifdef XFS_ALLOC_TRACE | ||
123 | xfs_alloc_trace_buf = ktrace_alloc(XFS_ALLOC_TRACE_SIZE, KM_SLEEP); | ||
124 | #endif | ||
125 | #ifdef XFS_BMAP_TRACE | ||
126 | xfs_bmap_trace_buf = ktrace_alloc(XFS_BMAP_TRACE_SIZE, KM_SLEEP); | ||
127 | #endif | ||
128 | #ifdef XFS_BMBT_TRACE | ||
129 | xfs_bmbt_trace_buf = ktrace_alloc(XFS_BMBT_TRACE_SIZE, KM_SLEEP); | ||
130 | #endif | ||
131 | #ifdef XFS_ATTR_TRACE | ||
132 | xfs_attr_trace_buf = ktrace_alloc(XFS_ATTR_TRACE_SIZE, KM_SLEEP); | ||
133 | #endif | ||
134 | #ifdef XFS_DIR2_TRACE | ||
135 | xfs_dir2_trace_buf = ktrace_alloc(XFS_DIR2_GTRACE_SIZE, KM_SLEEP); | ||
136 | #endif | ||
137 | |||
138 | xfs_dir_startup(); | ||
139 | |||
140 | #if (defined(DEBUG) || defined(INDUCE_IO_ERROR)) | ||
141 | xfs_error_test_init(); | ||
142 | #endif /* DEBUG || INDUCE_IO_ERROR */ | ||
143 | |||
144 | xfs_init_procfs(); | ||
145 | xfs_sysctl_register(); | ||
146 | return 0; | ||
147 | } | ||
148 | |||
149 | void __exit | ||
150 | xfs_cleanup(void) | ||
151 | { | ||
152 | extern kmem_zone_t *xfs_inode_zone; | ||
153 | extern kmem_zone_t *xfs_efd_zone; | ||
154 | extern kmem_zone_t *xfs_efi_zone; | ||
155 | |||
156 | xfs_cleanup_procfs(); | ||
157 | xfs_sysctl_unregister(); | ||
158 | xfs_filestream_uninit(); | ||
159 | xfs_mru_cache_uninit(); | ||
160 | xfs_acl_zone_destroy(xfs_acl_zone); | ||
161 | |||
162 | #ifdef XFS_DIR2_TRACE | ||
163 | ktrace_free(xfs_dir2_trace_buf); | ||
164 | #endif | ||
165 | #ifdef XFS_ATTR_TRACE | ||
166 | ktrace_free(xfs_attr_trace_buf); | ||
167 | #endif | ||
168 | #ifdef XFS_BMBT_TRACE | ||
169 | ktrace_free(xfs_bmbt_trace_buf); | ||
170 | #endif | ||
171 | #ifdef XFS_BMAP_TRACE | ||
172 | ktrace_free(xfs_bmap_trace_buf); | ||
173 | #endif | ||
174 | #ifdef XFS_ALLOC_TRACE | ||
175 | ktrace_free(xfs_alloc_trace_buf); | ||
176 | #endif | ||
177 | |||
178 | kmem_zone_destroy(xfs_bmap_free_item_zone); | ||
179 | kmem_zone_destroy(xfs_btree_cur_zone); | ||
180 | kmem_zone_destroy(xfs_inode_zone); | ||
181 | kmem_zone_destroy(xfs_trans_zone); | ||
182 | kmem_zone_destroy(xfs_da_state_zone); | ||
183 | kmem_zone_destroy(xfs_dabuf_zone); | ||
184 | kmem_zone_destroy(xfs_buf_item_zone); | ||
185 | kmem_zone_destroy(xfs_efd_zone); | ||
186 | kmem_zone_destroy(xfs_efi_zone); | ||
187 | kmem_zone_destroy(xfs_ifork_zone); | ||
188 | kmem_zone_destroy(xfs_ili_zone); | ||
189 | kmem_zone_destroy(xfs_log_ticket_zone); | ||
190 | } | ||
191 | |||
192 | STATIC void | 61 | STATIC void |
193 | xfs_quiesce_fs( | 62 | xfs_quiesce_fs( |
194 | xfs_mount_t *mp) | 63 | xfs_mount_t *mp) |