]>
Commit | Line | Data |
---|---|---|
60c778b2 | 1 | /* SCTP kernel implementation |
1da177e4 | 2 | * (C) Copyright IBM Corp. 2001, 2004 |
d808ad9a | 3 | * |
60c778b2 | 4 | * This file is part of the SCTP kernel implementation |
d808ad9a | 5 | * |
1da177e4 | 6 | * Support for memory object debugging. This allows one to monitor the |
d808ad9a YH |
7 | * object allocations/deallocations for types instrumented for this |
8 | * via the proc fs. | |
9 | * | |
60c778b2 | 10 | * This SCTP implementation is free software; |
d808ad9a | 11 | * you can redistribute it and/or modify it under the terms of |
1da177e4 LT |
12 | * the GNU General Public License as published by |
13 | * the Free Software Foundation; either version 2, or (at your option) | |
14 | * any later version. | |
d808ad9a | 15 | * |
60c778b2 | 16 | * This SCTP implementation is distributed in the hope that it |
1da177e4 LT |
17 | * will be useful, but WITHOUT ANY WARRANTY; without even the implied |
18 | * ************************ | |
19 | * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | |
20 | * See the GNU General Public License for more details. | |
d808ad9a | 21 | * |
1da177e4 LT |
22 | * You should have received a copy of the GNU General Public License |
23 | * along with GNU CC; see the file COPYING. If not, write to | |
24 | * the Free Software Foundation, 59 Temple Place - Suite 330, | |
d808ad9a YH |
25 | * Boston, MA 02111-1307, USA. |
26 | * | |
1da177e4 LT |
27 | * Please send any bug reports or fixes you make to the |
28 | * email address(es): | |
29 | * lksctp developers <[email protected]> | |
d808ad9a | 30 | * |
1da177e4 LT |
31 | * Or submit a bug report through the following website: |
32 | * http://www.sf.net/projects/lksctp | |
33 | * | |
d808ad9a | 34 | * Written or modified by: |
1da177e4 | 35 | * Jon Grimm <[email protected]> |
d808ad9a | 36 | * |
1da177e4 LT |
37 | * Any bugs reported given to us we will try to fix... any fixes shared will |
38 | * be incorporated into the next SCTP release. | |
39 | */ | |
40 | ||
41 | #include <linux/kernel.h> | |
42 | #include <net/sctp/sctp.h> | |
43 | ||
44 | /* | |
45 | * Global counters to count raw object allocation counts. | |
46 | * To add new counters, choose a unique suffix for the variable | |
47 | * name as the helper macros key off this suffix to make | |
48 | * life easier for the programmer. | |
49 | */ | |
50 | ||
51 | SCTP_DBG_OBJCNT(sock); | |
52 | SCTP_DBG_OBJCNT(ep); | |
53 | SCTP_DBG_OBJCNT(transport); | |
54 | SCTP_DBG_OBJCNT(assoc); | |
55 | SCTP_DBG_OBJCNT(bind_addr); | |
56 | SCTP_DBG_OBJCNT(bind_bucket); | |
57 | SCTP_DBG_OBJCNT(chunk); | |
58 | SCTP_DBG_OBJCNT(addr); | |
59 | SCTP_DBG_OBJCNT(ssnmap); | |
60 | SCTP_DBG_OBJCNT(datamsg); | |
1f485649 | 61 | SCTP_DBG_OBJCNT(keys); |
1da177e4 LT |
62 | |
63 | /* An array to make it easy to pretty print the debug information | |
64 | * to the proc fs. | |
65 | */ | |
66 | static sctp_dbg_objcnt_entry_t sctp_dbg_objcnt[] = { | |
67 | SCTP_DBG_OBJCNT_ENTRY(sock), | |
68 | SCTP_DBG_OBJCNT_ENTRY(ep), | |
69 | SCTP_DBG_OBJCNT_ENTRY(assoc), | |
70 | SCTP_DBG_OBJCNT_ENTRY(transport), | |
71 | SCTP_DBG_OBJCNT_ENTRY(chunk), | |
72 | SCTP_DBG_OBJCNT_ENTRY(bind_addr), | |
73 | SCTP_DBG_OBJCNT_ENTRY(bind_bucket), | |
74 | SCTP_DBG_OBJCNT_ENTRY(addr), | |
75 | SCTP_DBG_OBJCNT_ENTRY(ssnmap), | |
76 | SCTP_DBG_OBJCNT_ENTRY(datamsg), | |
1f485649 | 77 | SCTP_DBG_OBJCNT_ENTRY(keys), |
1da177e4 LT |
78 | }; |
79 | ||
80 | /* Callback from procfs to read out objcount information. | |
81 | * Walk through the entries in the sctp_dbg_objcnt array, dumping | |
82 | * the raw object counts for each monitored type. | |
1da177e4 | 83 | */ |
8ff65b46 | 84 | static int sctp_objcnt_seq_show(struct seq_file *seq, void *v) |
1da177e4 | 85 | { |
5e659e4c | 86 | int i, len; |
1da177e4 | 87 | |
8ff65b46 | 88 | i = (int)*(loff_t *)v; |
5e659e4c PE |
89 | seq_printf(seq, "%s: %d%n", sctp_dbg_objcnt[i].label, |
90 | atomic_read(sctp_dbg_objcnt[i].counter), &len); | |
91 | seq_printf(seq, "%*s\n", 127 - len, ""); | |
8ff65b46 PE |
92 | return 0; |
93 | } | |
94 | ||
95 | static void *sctp_objcnt_seq_start(struct seq_file *seq, loff_t *pos) | |
96 | { | |
97 | return (*pos >= ARRAY_SIZE(sctp_dbg_objcnt)) ? NULL : (void *)pos; | |
98 | } | |
99 | ||
100 | static void sctp_objcnt_seq_stop(struct seq_file *seq, void *v) | |
101 | { | |
102 | } | |
103 | ||
104 | static void * sctp_objcnt_seq_next(struct seq_file *seq, void *v, loff_t *pos) | |
105 | { | |
106 | ++*pos; | |
107 | return (*pos >= ARRAY_SIZE(sctp_dbg_objcnt)) ? NULL : (void *)pos; | |
1da177e4 LT |
108 | } |
109 | ||
8ff65b46 PE |
110 | static const struct seq_operations sctp_objcnt_seq_ops = { |
111 | .start = sctp_objcnt_seq_start, | |
112 | .next = sctp_objcnt_seq_next, | |
113 | .stop = sctp_objcnt_seq_stop, | |
114 | .show = sctp_objcnt_seq_show, | |
115 | }; | |
116 | ||
117 | static int sctp_objcnt_seq_open(struct inode *inode, struct file *file) | |
118 | { | |
119 | return seq_open(file, &sctp_objcnt_seq_ops); | |
120 | } | |
121 | ||
122 | static const struct file_operations sctp_objcnt_ops = { | |
123 | .open = sctp_objcnt_seq_open, | |
124 | .read = seq_read, | |
125 | .llseek = seq_lseek, | |
126 | .release = seq_release, | |
127 | }; | |
128 | ||
1da177e4 LT |
129 | /* Initialize the objcount in the proc filesystem. */ |
130 | void sctp_dbg_objcnt_init(void) | |
131 | { | |
ee71a29e | 132 | struct proc_dir_entry *ent; |
8ff65b46 | 133 | |
160f17e3 WC |
134 | ent = proc_create("sctp_dbg_objcnt", 0, |
135 | proc_net_sctp, &sctp_objcnt_ops); | |
ee71a29e | 136 | if (!ent) |
d808ad9a | 137 | printk(KERN_WARNING |
ee71a29e | 138 | "sctp_dbg_objcnt: Unable to create /proc entry.\n"); |
1da177e4 LT |
139 | } |
140 | ||
141 | /* Cleanup the objcount entry in the proc filesystem. */ | |
142 | void sctp_dbg_objcnt_exit(void) | |
143 | { | |
144 | remove_proc_entry("sctp_dbg_objcnt", proc_net_sctp); | |
145 | } | |
146 | ||
147 |