Commit 6bdd9be6 authored by Bob Peterson's avatar Bob Peterson Committed by Steven Whitehouse
Browse files

[GFS2] Allocate gfs2_rgrpd from slab memory



This patch moves the gfs2_rgrpd structure to its own slab
memory.  This makes it easier to control and monitor, and
yields less memory fragmentation.

Signed-off-by: default avatarBob Peterson <rpeterso@redhat.com>
Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
parent 3ad62e87
Loading
Loading
Loading
Loading
+10 −0
Original line number Original line Diff line number Diff line
@@ -89,6 +89,12 @@ static int __init init_gfs2_fs(void)
	if (!gfs2_bufdata_cachep)
	if (!gfs2_bufdata_cachep)
		goto fail;
		goto fail;


	gfs2_rgrpd_cachep = kmem_cache_create("gfs2_rgrpd",
					      sizeof(struct gfs2_rgrpd),
					      0, 0, NULL);
	if (!gfs2_rgrpd_cachep)
		goto fail;

	error = register_filesystem(&gfs2_fs_type);
	error = register_filesystem(&gfs2_fs_type);
	if (error)
	if (error)
		goto fail;
		goto fail;
@@ -108,6 +114,9 @@ static int __init init_gfs2_fs(void)
fail:
fail:
	gfs2_glock_exit();
	gfs2_glock_exit();


	if (gfs2_rgrpd_cachep)
		kmem_cache_destroy(gfs2_rgrpd_cachep);

	if (gfs2_bufdata_cachep)
	if (gfs2_bufdata_cachep)
		kmem_cache_destroy(gfs2_bufdata_cachep);
		kmem_cache_destroy(gfs2_bufdata_cachep);


@@ -133,6 +142,7 @@ static void __exit exit_gfs2_fs(void)
	unregister_filesystem(&gfs2_fs_type);
	unregister_filesystem(&gfs2_fs_type);
	unregister_filesystem(&gfs2meta_fs_type);
	unregister_filesystem(&gfs2meta_fs_type);


	kmem_cache_destroy(gfs2_rgrpd_cachep);
	kmem_cache_destroy(gfs2_bufdata_cachep);
	kmem_cache_destroy(gfs2_bufdata_cachep);
	kmem_cache_destroy(gfs2_inode_cachep);
	kmem_cache_destroy(gfs2_inode_cachep);
	kmem_cache_destroy(gfs2_glock_cachep);
	kmem_cache_destroy(gfs2_glock_cachep);
+2 −2
Original line number Original line Diff line number Diff line
@@ -353,7 +353,7 @@ static void clear_rgrpdi(struct gfs2_sbd *sdp)
		}
		}


		kfree(rgd->rd_bits);
		kfree(rgd->rd_bits);
		kfree(rgd);
		kmem_cache_free(gfs2_rgrpd_cachep, rgd);
	}
	}
}
}


@@ -516,7 +516,7 @@ static int read_rindex_entry(struct gfs2_inode *ip,
		return error;
		return error;
	}
	}


	rgd = kzalloc(sizeof(struct gfs2_rgrpd), GFP_NOFS);
	rgd = kmem_cache_zalloc(gfs2_rgrpd_cachep, GFP_NOFS);
	error = -ENOMEM;
	error = -ENOMEM;
	if (!rgd)
	if (!rgd)
		return error;
		return error;
+1 −0
Original line number Original line Diff line number Diff line
@@ -25,6 +25,7 @@
struct kmem_cache *gfs2_glock_cachep __read_mostly;
struct kmem_cache *gfs2_glock_cachep __read_mostly;
struct kmem_cache *gfs2_inode_cachep __read_mostly;
struct kmem_cache *gfs2_inode_cachep __read_mostly;
struct kmem_cache *gfs2_bufdata_cachep __read_mostly;
struct kmem_cache *gfs2_bufdata_cachep __read_mostly;
struct kmem_cache *gfs2_rgrpd_cachep __read_mostly;


void gfs2_assert_i(struct gfs2_sbd *sdp)
void gfs2_assert_i(struct gfs2_sbd *sdp)
{
{
+1 −0
Original line number Original line Diff line number Diff line
@@ -147,6 +147,7 @@ gfs2_io_error_bh_i((sdp), (bh), __FUNCTION__, __FILE__, __LINE__);
extern struct kmem_cache *gfs2_glock_cachep;
extern struct kmem_cache *gfs2_glock_cachep;
extern struct kmem_cache *gfs2_inode_cachep;
extern struct kmem_cache *gfs2_inode_cachep;
extern struct kmem_cache *gfs2_bufdata_cachep;
extern struct kmem_cache *gfs2_bufdata_cachep;
extern struct kmem_cache *gfs2_rgrpd_cachep;


static inline unsigned int gfs2_tune_get_i(struct gfs2_tune *gt,
static inline unsigned int gfs2_tune_get_i(struct gfs2_tune *gt,
					   unsigned int *p)
					   unsigned int *p)