2 * Kernel CAPI 2.0 Module - /proc/capi handling
4 * Copyright 1999 by Carsten Paeth <calle@calle.de>
5 * Copyright 2002 by Kai Germaschewski <kai@germaschewski.name>
7 * This software may be used and distributed according to the terms
8 * of the GNU General Public License, incorporated herein by reference.
14 #include <linux/proc_fs.h>
15 #include <linux/seq_file.h>
16 #include <linux/init.h>
17 #include <linux/export.h>
19 static char *state2str(unsigned short state
)
22 case CAPI_CTR_DETECTED
: return "detected";
23 case CAPI_CTR_LOADING
: return "loading";
24 case CAPI_CTR_RUNNING
: return "running";
25 default: return "???";
30 // ===========================================================================
32 // /proc/capi/controller:
33 // cnr driver cardstate name driverinfo
34 // /proc/capi/contrstats:
35 // cnr nrecvctlpkt nrecvdatapkt nsentctlpkt nsentdatapkt
36 // ---------------------------------------------------------------------------
38 static void *controller_start(struct seq_file
*seq
, loff_t
*pos
)
39 __acquires(capi_controller_lock
)
41 mutex_lock(&capi_controller_lock
);
43 if (*pos
< CAPI_MAXCONTR
)
44 return &capi_controller
[*pos
];
49 static void *controller_next(struct seq_file
*seq
, void *v
, loff_t
*pos
)
52 if (*pos
< CAPI_MAXCONTR
)
53 return &capi_controller
[*pos
];
58 static void controller_stop(struct seq_file
*seq
, void *v
)
59 __releases(capi_controller_lock
)
61 mutex_unlock(&capi_controller_lock
);
64 static int controller_show(struct seq_file
*seq
, void *v
)
66 struct capi_ctr
*ctr
= *(struct capi_ctr
**) v
;
71 seq_printf(seq
, "%d %-10s %-8s %-16s %s\n",
72 ctr
->cnr
, ctr
->driver_name
,
73 state2str(ctr
->state
),
75 ctr
->procinfo
? ctr
->procinfo(ctr
) : "");
80 static int contrstats_show(struct seq_file
*seq
, void *v
)
82 struct capi_ctr
*ctr
= *(struct capi_ctr
**) v
;
87 seq_printf(seq
, "%d %lu %lu %lu %lu\n",
97 static const struct seq_operations seq_controller_ops
= {
98 .start
= controller_start
,
99 .next
= controller_next
,
100 .stop
= controller_stop
,
101 .show
= controller_show
,
104 static const struct seq_operations seq_contrstats_ops
= {
105 .start
= controller_start
,
106 .next
= controller_next
,
107 .stop
= controller_stop
,
108 .show
= contrstats_show
,
111 // /proc/capi/applications:
112 // applid l3cnt dblkcnt dblklen #ncci recvqueuelen
113 // /proc/capi/applstats:
114 // applid nrecvctlpkt nrecvdatapkt nsentctlpkt nsentdatapkt
115 // ---------------------------------------------------------------------------
117 static void *applications_start(struct seq_file
*seq
, loff_t
*pos
)
118 __acquires(capi_controller_lock
)
120 mutex_lock(&capi_controller_lock
);
122 if (*pos
< CAPI_MAXAPPL
)
123 return &capi_applications
[*pos
];
129 applications_next(struct seq_file
*seq
, void *v
, loff_t
*pos
)
132 if (*pos
< CAPI_MAXAPPL
)
133 return &capi_applications
[*pos
];
138 static void applications_stop(struct seq_file
*seq
, void *v
)
139 __releases(capi_controller_lock
)
141 mutex_unlock(&capi_controller_lock
);
145 applications_show(struct seq_file
*seq
, void *v
)
147 struct capi20_appl
*ap
= *(struct capi20_appl
**) v
;
152 seq_printf(seq
, "%u %d %d %d\n",
154 ap
->rparam
.level3cnt
,
155 ap
->rparam
.datablkcnt
,
156 ap
->rparam
.datablklen
);
162 applstats_show(struct seq_file
*seq
, void *v
)
164 struct capi20_appl
*ap
= *(struct capi20_appl
**) v
;
169 seq_printf(seq
, "%u %lu %lu %lu %lu\n",
179 static const struct seq_operations seq_applications_ops
= {
180 .start
= applications_start
,
181 .next
= applications_next
,
182 .stop
= applications_stop
,
183 .show
= applications_show
,
186 static const struct seq_operations seq_applstats_ops
= {
187 .start
= applications_start
,
188 .next
= applications_next
,
189 .stop
= applications_stop
,
190 .show
= applstats_show
,
193 // ---------------------------------------------------------------------------
195 /* /proc/capi/drivers is always empty */
196 static ssize_t
empty_read(struct file
*file
, char __user
*buf
,
197 size_t size
, loff_t
*off
)
202 static const struct proc_ops empty_proc_ops
= {
203 .proc_read
= empty_read
,
204 .proc_lseek
= default_llseek
,
207 // ---------------------------------------------------------------------------
210 kcapi_proc_init(void)
212 proc_mkdir("capi", NULL
);
213 proc_mkdir("capi/controllers", NULL
);
214 proc_create_seq("capi/controller", 0, NULL
, &seq_controller_ops
);
215 proc_create_seq("capi/contrstats", 0, NULL
, &seq_contrstats_ops
);
216 proc_create_seq("capi/applications", 0, NULL
, &seq_applications_ops
);
217 proc_create_seq("capi/applstats", 0, NULL
, &seq_applstats_ops
);
218 proc_create("capi/driver", 0, NULL
, &empty_proc_ops
);
222 kcapi_proc_exit(void)
224 remove_proc_entry("capi/driver", NULL
);
225 remove_proc_entry("capi/controller", NULL
);
226 remove_proc_entry("capi/contrstats", NULL
);
227 remove_proc_entry("capi/applications", NULL
);
228 remove_proc_entry("capi/applstats", NULL
);
229 remove_proc_entry("capi/controllers", NULL
);
230 remove_proc_entry("capi", NULL
);