diff options
author | Bryan Schumaker <bjschuma@netapp.com> | 2012-11-29 11:40:44 -0500 |
---|---|---|
committer | J. Bruce Fields <bfields@redhat.com> | 2012-12-03 09:59:01 -0500 |
commit | 184c18471f7d0963ad5752692c4b441a546d88f1 (patch) | |
tree | 92dc8d2d5d7104888055741b6c2c6fca67795b05 /fs/nfsd/fault_inject.c | |
parent | 8ce54e0d82730ece61737c9fd7b61b28ab8c3390 (diff) |
NFSD: Reading a fault injection file prints a state count
I also log basic information that I can figure out about the type of
state (such as number of locks for each client IP address). This can be
useful for checking that state was actually dropped and later for
checking if the client was able to recover.
Signed-off-by: Bryan Schumaker <bjschuma@netapp.com>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Diffstat (limited to 'fs/nfsd/fault_inject.c')
-rw-r--r-- | fs/nfsd/fault_inject.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/fs/nfsd/fault_inject.c b/fs/nfsd/fault_inject.c index bf6161adf663..545f8e4ed101 100644 --- a/fs/nfsd/fault_inject.c +++ b/fs/nfsd/fault_inject.c | |||
@@ -14,28 +14,34 @@ | |||
14 | struct nfsd_fault_inject_op { | 14 | struct nfsd_fault_inject_op { |
15 | char *file; | 15 | char *file; |
16 | u64 (*forget)(struct nfs4_client *, u64); | 16 | u64 (*forget)(struct nfs4_client *, u64); |
17 | u64 (*print)(struct nfs4_client *, u64); | ||
17 | }; | 18 | }; |
18 | 19 | ||
19 | static struct nfsd_fault_inject_op inject_ops[] = { | 20 | static struct nfsd_fault_inject_op inject_ops[] = { |
20 | { | 21 | { |
21 | .file = "forget_clients", | 22 | .file = "forget_clients", |
22 | .forget = nfsd_forget_client, | 23 | .forget = nfsd_forget_client, |
24 | .print = nfsd_print_client, | ||
23 | }, | 25 | }, |
24 | { | 26 | { |
25 | .file = "forget_locks", | 27 | .file = "forget_locks", |
26 | .forget = nfsd_forget_client_locks, | 28 | .forget = nfsd_forget_client_locks, |
29 | .print = nfsd_print_client_locks, | ||
27 | }, | 30 | }, |
28 | { | 31 | { |
29 | .file = "forget_openowners", | 32 | .file = "forget_openowners", |
30 | .forget = nfsd_forget_client_openowners, | 33 | .forget = nfsd_forget_client_openowners, |
34 | .print = nfsd_print_client_openowners, | ||
31 | }, | 35 | }, |
32 | { | 36 | { |
33 | .file = "forget_delegations", | 37 | .file = "forget_delegations", |
34 | .forget = nfsd_forget_client_delegations, | 38 | .forget = nfsd_forget_client_delegations, |
39 | .print = nfsd_print_client_delegations, | ||
35 | }, | 40 | }, |
36 | { | 41 | { |
37 | .file = "recall_delegations", | 42 | .file = "recall_delegations", |
38 | .forget = nfsd_recall_client_delegations, | 43 | .forget = nfsd_recall_client_delegations, |
44 | .print = nfsd_print_client_delegations, | ||
39 | }, | 45 | }, |
40 | }; | 46 | }; |
41 | 47 | ||
@@ -59,9 +65,12 @@ static int nfsd_inject_set(void *op_ptr, u64 val) | |||
59 | return 0; | 65 | return 0; |
60 | } | 66 | } |
61 | 67 | ||
62 | static int nfsd_inject_get(void *data, u64 *val) | 68 | static int nfsd_inject_get(void *op_ptr, u64 *val) |
63 | { | 69 | { |
64 | *val = 0; | 70 | struct nfsd_fault_inject_op *op = op_ptr; |
71 | nfs4_lock_state(); | ||
72 | *val = nfsd_for_n_state(0, op->print); | ||
73 | nfs4_unlock_state(); | ||
65 | return 0; | 74 | return 0; |
66 | } | 75 | } |
67 | 76 | ||