diff options
author | David Howells <dhowells@redhat.com> | 2009-04-03 11:42:38 -0400 |
---|---|---|
committer | David Howells <dhowells@redhat.com> | 2009-04-03 11:42:38 -0400 |
commit | 955d00917f0c094e0f2fb88df967e980ab66b8ca (patch) | |
tree | c6109684239fd45462e494fb4f26aa8e2e651922 /fs/fscache/cookie.c | |
parent | 4c515dd47ab41be3f89e757d441661795470b376 (diff) |
FS-Cache: Provide a slab for cookie allocation
Provide a slab from which can be allocated the FS-Cache cookies that will be
presented to the netfs.
Also provide a slab constructor and a function to recursively discard a cookie
and its ancestor chain.
Signed-off-by: David Howells <dhowells@redhat.com>
Acked-by: Steve Dickson <steved@redhat.com>
Acked-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Acked-by: Al Viro <viro@zeniv.linux.org.uk>
Tested-by: Daire Byrne <Daire.Byrne@framestore.com>
Diffstat (limited to 'fs/fscache/cookie.c')
-rw-r--r-- | fs/fscache/cookie.c | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/fs/fscache/cookie.c b/fs/fscache/cookie.c new file mode 100644 index 000000000000..47fd75b832e1 --- /dev/null +++ b/fs/fscache/cookie.c | |||
@@ -0,0 +1,56 @@ | |||
1 | /* netfs cookie management | ||
2 | * | ||
3 | * Copyright (C) 2004-2007 Red Hat, Inc. All Rights Reserved. | ||
4 | * Written by David Howells (dhowells@redhat.com) | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or | ||
7 | * modify it under the terms of the GNU General Public License | ||
8 | * as published by the Free Software Foundation; either version | ||
9 | * 2 of the License, or (at your option) any later version. | ||
10 | */ | ||
11 | |||
12 | #define FSCACHE_DEBUG_LEVEL COOKIE | ||
13 | #include <linux/module.h> | ||
14 | #include <linux/slab.h> | ||
15 | #include "internal.h" | ||
16 | |||
17 | struct kmem_cache *fscache_cookie_jar; | ||
18 | |||
19 | /* | ||
20 | * initialise an cookie jar slab element prior to any use | ||
21 | */ | ||
22 | void fscache_cookie_init_once(void *_cookie) | ||
23 | { | ||
24 | struct fscache_cookie *cookie = _cookie; | ||
25 | |||
26 | memset(cookie, 0, sizeof(*cookie)); | ||
27 | spin_lock_init(&cookie->lock); | ||
28 | INIT_HLIST_HEAD(&cookie->backing_objects); | ||
29 | } | ||
30 | |||
31 | /* | ||
32 | * destroy a cookie | ||
33 | */ | ||
34 | void __fscache_cookie_put(struct fscache_cookie *cookie) | ||
35 | { | ||
36 | struct fscache_cookie *parent; | ||
37 | |||
38 | _enter("%p", cookie); | ||
39 | |||
40 | for (;;) { | ||
41 | _debug("FREE COOKIE %p", cookie); | ||
42 | parent = cookie->parent; | ||
43 | BUG_ON(!hlist_empty(&cookie->backing_objects)); | ||
44 | kmem_cache_free(fscache_cookie_jar, cookie); | ||
45 | |||
46 | if (!parent) | ||
47 | break; | ||
48 | |||
49 | cookie = parent; | ||
50 | BUG_ON(atomic_read(&cookie->usage) <= 0); | ||
51 | if (!atomic_dec_and_test(&cookie->usage)) | ||
52 | break; | ||
53 | } | ||
54 | |||
55 | _leave(""); | ||
56 | } | ||