1 /*******************************************************************************
2 * Modern ConfigFS group context specific iSCSI statistics based on original
3 * iscsi_target_mib.c code
5 * Copyright (c) 2011-2013 Datera, Inc.
7 * Author: Nicholas A. Bellinger <nab@linux-iscsi.org>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 ******************************************************************************/
20 #include <linux/configfs.h>
21 #include <linux/export.h>
22 #include <scsi/iscsi_proto.h>
23 #include <target/target_core_base.h>
24 #include <target/configfs_macros.h>
26 #include "iscsi_target_core.h"
27 #include "iscsi_target_parameters.h"
28 #include "iscsi_target_device.h"
29 #include "iscsi_target_tpg.h"
30 #include "iscsi_target_util.h"
31 #include "iscsi_target_stat.h"
33 #ifndef INITIAL_JIFFIES
34 #define INITIAL_JIFFIES ((unsigned long)(unsigned int) (-300*HZ))
37 /* Instance Attributes Table */
38 #define ISCSI_INST_NUM_NODES 1
39 #define ISCSI_INST_DESCR "Storage Engine Target"
40 #define ISCSI_INST_LAST_FAILURE_TYPE 0
41 #define ISCSI_DISCONTINUITY_TIME 0
43 #define ISCSI_NODE_INDEX 1
45 #define ISPRINT(a) ((a >= ' ') && (a <= '~'))
47 /****************************************************************************
49 ****************************************************************************/
51 * Instance Attributes Table
53 CONFIGFS_EATTR_STRUCT(iscsi_stat_instance
, iscsi_wwn_stat_grps
);
54 #define ISCSI_STAT_INSTANCE_ATTR(_name, _mode) \
55 static struct iscsi_stat_instance_attribute \
56 iscsi_stat_instance_##_name = \
57 __CONFIGFS_EATTR(_name, _mode, \
58 iscsi_stat_instance_show_attr_##_name, \
59 iscsi_stat_instance_store_attr_##_name);
61 #define ISCSI_STAT_INSTANCE_ATTR_RO(_name) \
62 static struct iscsi_stat_instance_attribute \
63 iscsi_stat_instance_##_name = \
64 __CONFIGFS_EATTR_RO(_name, \
65 iscsi_stat_instance_show_attr_##_name);
67 static ssize_t
iscsi_stat_instance_show_attr_inst(
68 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
70 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
71 struct iscsi_tiqn
, tiqn_stat_grps
);
73 return snprintf(page
, PAGE_SIZE
, "%u\n", tiqn
->tiqn_index
);
75 ISCSI_STAT_INSTANCE_ATTR_RO(inst
);
77 static ssize_t
iscsi_stat_instance_show_attr_min_ver(
78 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
80 return snprintf(page
, PAGE_SIZE
, "%u\n", ISCSI_DRAFT20_VERSION
);
82 ISCSI_STAT_INSTANCE_ATTR_RO(min_ver
);
84 static ssize_t
iscsi_stat_instance_show_attr_max_ver(
85 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
87 return snprintf(page
, PAGE_SIZE
, "%u\n", ISCSI_DRAFT20_VERSION
);
89 ISCSI_STAT_INSTANCE_ATTR_RO(max_ver
);
91 static ssize_t
iscsi_stat_instance_show_attr_portals(
92 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
94 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
95 struct iscsi_tiqn
, tiqn_stat_grps
);
97 return snprintf(page
, PAGE_SIZE
, "%u\n", tiqn
->tiqn_num_tpg_nps
);
99 ISCSI_STAT_INSTANCE_ATTR_RO(portals
);
101 static ssize_t
iscsi_stat_instance_show_attr_nodes(
102 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
104 return snprintf(page
, PAGE_SIZE
, "%u\n", ISCSI_INST_NUM_NODES
);
106 ISCSI_STAT_INSTANCE_ATTR_RO(nodes
);
108 static ssize_t
iscsi_stat_instance_show_attr_sessions(
109 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
111 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
112 struct iscsi_tiqn
, tiqn_stat_grps
);
114 return snprintf(page
, PAGE_SIZE
, "%u\n", tiqn
->tiqn_nsessions
);
116 ISCSI_STAT_INSTANCE_ATTR_RO(sessions
);
118 static ssize_t
iscsi_stat_instance_show_attr_fail_sess(
119 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
121 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
122 struct iscsi_tiqn
, tiqn_stat_grps
);
123 struct iscsi_sess_err_stats
*sess_err
= &tiqn
->sess_err_stats
;
126 spin_lock_bh(&sess_err
->lock
);
127 sess_err_count
= (sess_err
->digest_errors
+
128 sess_err
->cxn_timeout_errors
+
129 sess_err
->pdu_format_errors
);
130 spin_unlock_bh(&sess_err
->lock
);
132 return snprintf(page
, PAGE_SIZE
, "%u\n", sess_err_count
);
134 ISCSI_STAT_INSTANCE_ATTR_RO(fail_sess
);
136 static ssize_t
iscsi_stat_instance_show_attr_fail_type(
137 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
139 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
140 struct iscsi_tiqn
, tiqn_stat_grps
);
141 struct iscsi_sess_err_stats
*sess_err
= &tiqn
->sess_err_stats
;
143 return snprintf(page
, PAGE_SIZE
, "%u\n",
144 sess_err
->last_sess_failure_type
);
146 ISCSI_STAT_INSTANCE_ATTR_RO(fail_type
);
148 static ssize_t
iscsi_stat_instance_show_attr_fail_rem_name(
149 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
151 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
152 struct iscsi_tiqn
, tiqn_stat_grps
);
153 struct iscsi_sess_err_stats
*sess_err
= &tiqn
->sess_err_stats
;
155 return snprintf(page
, PAGE_SIZE
, "%s\n",
156 sess_err
->last_sess_fail_rem_name
[0] ?
157 sess_err
->last_sess_fail_rem_name
: NONE
);
159 ISCSI_STAT_INSTANCE_ATTR_RO(fail_rem_name
);
161 static ssize_t
iscsi_stat_instance_show_attr_disc_time(
162 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
164 return snprintf(page
, PAGE_SIZE
, "%u\n", ISCSI_DISCONTINUITY_TIME
);
166 ISCSI_STAT_INSTANCE_ATTR_RO(disc_time
);
168 static ssize_t
iscsi_stat_instance_show_attr_description(
169 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
171 return snprintf(page
, PAGE_SIZE
, "%s\n", ISCSI_INST_DESCR
);
173 ISCSI_STAT_INSTANCE_ATTR_RO(description
);
175 static ssize_t
iscsi_stat_instance_show_attr_vendor(
176 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
178 return snprintf(page
, PAGE_SIZE
, "Datera, Inc. iSCSI-Target\n");
180 ISCSI_STAT_INSTANCE_ATTR_RO(vendor
);
182 static ssize_t
iscsi_stat_instance_show_attr_version(
183 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
185 return snprintf(page
, PAGE_SIZE
, "%s\n", ISCSIT_VERSION
);
187 ISCSI_STAT_INSTANCE_ATTR_RO(version
);
189 CONFIGFS_EATTR_OPS(iscsi_stat_instance
, iscsi_wwn_stat_grps
,
190 iscsi_instance_group
);
192 static struct configfs_attribute
*iscsi_stat_instance_attrs
[] = {
193 &iscsi_stat_instance_inst
.attr
,
194 &iscsi_stat_instance_min_ver
.attr
,
195 &iscsi_stat_instance_max_ver
.attr
,
196 &iscsi_stat_instance_portals
.attr
,
197 &iscsi_stat_instance_nodes
.attr
,
198 &iscsi_stat_instance_sessions
.attr
,
199 &iscsi_stat_instance_fail_sess
.attr
,
200 &iscsi_stat_instance_fail_type
.attr
,
201 &iscsi_stat_instance_fail_rem_name
.attr
,
202 &iscsi_stat_instance_disc_time
.attr
,
203 &iscsi_stat_instance_description
.attr
,
204 &iscsi_stat_instance_vendor
.attr
,
205 &iscsi_stat_instance_version
.attr
,
209 static struct configfs_item_operations iscsi_stat_instance_item_ops
= {
210 .show_attribute
= iscsi_stat_instance_attr_show
,
211 .store_attribute
= iscsi_stat_instance_attr_store
,
214 struct config_item_type iscsi_stat_instance_cit
= {
215 .ct_item_ops
= &iscsi_stat_instance_item_ops
,
216 .ct_attrs
= iscsi_stat_instance_attrs
,
217 .ct_owner
= THIS_MODULE
,
221 * Instance Session Failure Stats Table
223 CONFIGFS_EATTR_STRUCT(iscsi_stat_sess_err
, iscsi_wwn_stat_grps
);
224 #define ISCSI_STAT_SESS_ERR_ATTR(_name, _mode) \
225 static struct iscsi_stat_sess_err_attribute \
226 iscsi_stat_sess_err_##_name = \
227 __CONFIGFS_EATTR(_name, _mode, \
228 iscsi_stat_sess_err_show_attr_##_name, \
229 iscsi_stat_sess_err_store_attr_##_name);
231 #define ISCSI_STAT_SESS_ERR_ATTR_RO(_name) \
232 static struct iscsi_stat_sess_err_attribute \
233 iscsi_stat_sess_err_##_name = \
234 __CONFIGFS_EATTR_RO(_name, \
235 iscsi_stat_sess_err_show_attr_##_name);
237 static ssize_t
iscsi_stat_sess_err_show_attr_inst(
238 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
240 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
241 struct iscsi_tiqn
, tiqn_stat_grps
);
243 return snprintf(page
, PAGE_SIZE
, "%u\n", tiqn
->tiqn_index
);
245 ISCSI_STAT_SESS_ERR_ATTR_RO(inst
);
247 static ssize_t
iscsi_stat_sess_err_show_attr_digest_errors(
248 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
250 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
251 struct iscsi_tiqn
, tiqn_stat_grps
);
252 struct iscsi_sess_err_stats
*sess_err
= &tiqn
->sess_err_stats
;
254 return snprintf(page
, PAGE_SIZE
, "%u\n", sess_err
->digest_errors
);
256 ISCSI_STAT_SESS_ERR_ATTR_RO(digest_errors
);
258 static ssize_t
iscsi_stat_sess_err_show_attr_cxn_errors(
259 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
261 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
262 struct iscsi_tiqn
, tiqn_stat_grps
);
263 struct iscsi_sess_err_stats
*sess_err
= &tiqn
->sess_err_stats
;
265 return snprintf(page
, PAGE_SIZE
, "%u\n", sess_err
->cxn_timeout_errors
);
267 ISCSI_STAT_SESS_ERR_ATTR_RO(cxn_errors
);
269 static ssize_t
iscsi_stat_sess_err_show_attr_format_errors(
270 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
272 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
273 struct iscsi_tiqn
, tiqn_stat_grps
);
274 struct iscsi_sess_err_stats
*sess_err
= &tiqn
->sess_err_stats
;
276 return snprintf(page
, PAGE_SIZE
, "%u\n", sess_err
->pdu_format_errors
);
278 ISCSI_STAT_SESS_ERR_ATTR_RO(format_errors
);
280 CONFIGFS_EATTR_OPS(iscsi_stat_sess_err
, iscsi_wwn_stat_grps
,
281 iscsi_sess_err_group
);
283 static struct configfs_attribute
*iscsi_stat_sess_err_attrs
[] = {
284 &iscsi_stat_sess_err_inst
.attr
,
285 &iscsi_stat_sess_err_digest_errors
.attr
,
286 &iscsi_stat_sess_err_cxn_errors
.attr
,
287 &iscsi_stat_sess_err_format_errors
.attr
,
291 static struct configfs_item_operations iscsi_stat_sess_err_item_ops
= {
292 .show_attribute
= iscsi_stat_sess_err_attr_show
,
293 .store_attribute
= iscsi_stat_sess_err_attr_store
,
296 struct config_item_type iscsi_stat_sess_err_cit
= {
297 .ct_item_ops
= &iscsi_stat_sess_err_item_ops
,
298 .ct_attrs
= iscsi_stat_sess_err_attrs
,
299 .ct_owner
= THIS_MODULE
,
303 * Target Attributes Table
305 CONFIGFS_EATTR_STRUCT(iscsi_stat_tgt_attr
, iscsi_wwn_stat_grps
);
306 #define ISCSI_STAT_TGT_ATTR(_name, _mode) \
307 static struct iscsi_stat_tgt_attr_attribute \
308 iscsi_stat_tgt_attr_##_name = \
309 __CONFIGFS_EATTR(_name, _mode, \
310 iscsi_stat_tgt-attr_show_attr_##_name, \
311 iscsi_stat_tgt_attr_store_attr_##_name);
313 #define ISCSI_STAT_TGT_ATTR_RO(_name) \
314 static struct iscsi_stat_tgt_attr_attribute \
315 iscsi_stat_tgt_attr_##_name = \
316 __CONFIGFS_EATTR_RO(_name, \
317 iscsi_stat_tgt_attr_show_attr_##_name);
319 static ssize_t
iscsi_stat_tgt_attr_show_attr_inst(
320 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
322 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
323 struct iscsi_tiqn
, tiqn_stat_grps
);
325 return snprintf(page
, PAGE_SIZE
, "%u\n", tiqn
->tiqn_index
);
327 ISCSI_STAT_TGT_ATTR_RO(inst
);
329 static ssize_t
iscsi_stat_tgt_attr_show_attr_indx(
330 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
332 return snprintf(page
, PAGE_SIZE
, "%u\n", ISCSI_NODE_INDEX
);
334 ISCSI_STAT_TGT_ATTR_RO(indx
);
336 static ssize_t
iscsi_stat_tgt_attr_show_attr_login_fails(
337 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
339 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
340 struct iscsi_tiqn
, tiqn_stat_grps
);
341 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
344 spin_lock(&lstat
->lock
);
345 fail_count
= (lstat
->redirects
+ lstat
->authorize_fails
+
346 lstat
->authenticate_fails
+ lstat
->negotiate_fails
+
348 spin_unlock(&lstat
->lock
);
350 return snprintf(page
, PAGE_SIZE
, "%u\n", fail_count
);
352 ISCSI_STAT_TGT_ATTR_RO(login_fails
);
354 static ssize_t
iscsi_stat_tgt_attr_show_attr_last_fail_time(
355 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
357 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
358 struct iscsi_tiqn
, tiqn_stat_grps
);
359 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
362 spin_lock(&lstat
->lock
);
363 last_fail_time
= lstat
->last_fail_time
?
364 (u32
)(((u32
)lstat
->last_fail_time
-
365 INITIAL_JIFFIES
) * 100 / HZ
) : 0;
366 spin_unlock(&lstat
->lock
);
368 return snprintf(page
, PAGE_SIZE
, "%u\n", last_fail_time
);
370 ISCSI_STAT_TGT_ATTR_RO(last_fail_time
);
372 static ssize_t
iscsi_stat_tgt_attr_show_attr_last_fail_type(
373 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
375 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
376 struct iscsi_tiqn
, tiqn_stat_grps
);
377 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
380 spin_lock(&lstat
->lock
);
381 last_fail_type
= lstat
->last_fail_type
;
382 spin_unlock(&lstat
->lock
);
384 return snprintf(page
, PAGE_SIZE
, "%u\n", last_fail_type
);
386 ISCSI_STAT_TGT_ATTR_RO(last_fail_type
);
388 static ssize_t
iscsi_stat_tgt_attr_show_attr_fail_intr_name(
389 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
391 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
392 struct iscsi_tiqn
, tiqn_stat_grps
);
393 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
394 unsigned char buf
[224];
396 spin_lock(&lstat
->lock
);
397 snprintf(buf
, 224, "%s", lstat
->last_intr_fail_name
[0] ?
398 lstat
->last_intr_fail_name
: NONE
);
399 spin_unlock(&lstat
->lock
);
401 return snprintf(page
, PAGE_SIZE
, "%s\n", buf
);
403 ISCSI_STAT_TGT_ATTR_RO(fail_intr_name
);
405 static ssize_t
iscsi_stat_tgt_attr_show_attr_fail_intr_addr_type(
406 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
408 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
409 struct iscsi_tiqn
, tiqn_stat_grps
);
410 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
413 spin_lock(&lstat
->lock
);
414 if (lstat
->last_intr_fail_ip_family
== AF_INET6
)
415 ret
= snprintf(page
, PAGE_SIZE
, "ipv6\n");
417 ret
= snprintf(page
, PAGE_SIZE
, "ipv4\n");
418 spin_unlock(&lstat
->lock
);
422 ISCSI_STAT_TGT_ATTR_RO(fail_intr_addr_type
);
424 static ssize_t
iscsi_stat_tgt_attr_show_attr_fail_intr_addr(
425 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
427 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
428 struct iscsi_tiqn
, tiqn_stat_grps
);
429 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
432 spin_lock(&lstat
->lock
);
433 ret
= snprintf(page
, PAGE_SIZE
, "%s\n", lstat
->last_intr_fail_ip_addr
);
434 spin_unlock(&lstat
->lock
);
438 ISCSI_STAT_TGT_ATTR_RO(fail_intr_addr
);
440 CONFIGFS_EATTR_OPS(iscsi_stat_tgt_attr
, iscsi_wwn_stat_grps
,
441 iscsi_tgt_attr_group
);
443 static struct configfs_attribute
*iscsi_stat_tgt_attr_attrs
[] = {
444 &iscsi_stat_tgt_attr_inst
.attr
,
445 &iscsi_stat_tgt_attr_indx
.attr
,
446 &iscsi_stat_tgt_attr_login_fails
.attr
,
447 &iscsi_stat_tgt_attr_last_fail_time
.attr
,
448 &iscsi_stat_tgt_attr_last_fail_type
.attr
,
449 &iscsi_stat_tgt_attr_fail_intr_name
.attr
,
450 &iscsi_stat_tgt_attr_fail_intr_addr_type
.attr
,
451 &iscsi_stat_tgt_attr_fail_intr_addr
.attr
,
455 static struct configfs_item_operations iscsi_stat_tgt_attr_item_ops
= {
456 .show_attribute
= iscsi_stat_tgt_attr_attr_show
,
457 .store_attribute
= iscsi_stat_tgt_attr_attr_store
,
460 struct config_item_type iscsi_stat_tgt_attr_cit
= {
461 .ct_item_ops
= &iscsi_stat_tgt_attr_item_ops
,
462 .ct_attrs
= iscsi_stat_tgt_attr_attrs
,
463 .ct_owner
= THIS_MODULE
,
467 * Target Login Stats Table
469 CONFIGFS_EATTR_STRUCT(iscsi_stat_login
, iscsi_wwn_stat_grps
);
470 #define ISCSI_STAT_LOGIN(_name, _mode) \
471 static struct iscsi_stat_login_attribute \
472 iscsi_stat_login_##_name = \
473 __CONFIGFS_EATTR(_name, _mode, \
474 iscsi_stat_login_show_attr_##_name, \
475 iscsi_stat_login_store_attr_##_name);
477 #define ISCSI_STAT_LOGIN_RO(_name) \
478 static struct iscsi_stat_login_attribute \
479 iscsi_stat_login_##_name = \
480 __CONFIGFS_EATTR_RO(_name, \
481 iscsi_stat_login_show_attr_##_name);
483 static ssize_t
iscsi_stat_login_show_attr_inst(
484 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
486 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
487 struct iscsi_tiqn
, tiqn_stat_grps
);
489 return snprintf(page
, PAGE_SIZE
, "%u\n", tiqn
->tiqn_index
);
491 ISCSI_STAT_LOGIN_RO(inst
);
493 static ssize_t
iscsi_stat_login_show_attr_indx(
494 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
496 return snprintf(page
, PAGE_SIZE
, "%u\n", ISCSI_NODE_INDEX
);
498 ISCSI_STAT_LOGIN_RO(indx
);
500 static ssize_t
iscsi_stat_login_show_attr_accepts(
501 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
503 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
504 struct iscsi_tiqn
, tiqn_stat_grps
);
505 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
508 spin_lock(&lstat
->lock
);
509 ret
= snprintf(page
, PAGE_SIZE
, "%u\n", lstat
->accepts
);
510 spin_unlock(&lstat
->lock
);
514 ISCSI_STAT_LOGIN_RO(accepts
);
516 static ssize_t
iscsi_stat_login_show_attr_other_fails(
517 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
519 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
520 struct iscsi_tiqn
, tiqn_stat_grps
);
521 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
524 spin_lock(&lstat
->lock
);
525 ret
= snprintf(page
, PAGE_SIZE
, "%u\n", lstat
->other_fails
);
526 spin_unlock(&lstat
->lock
);
530 ISCSI_STAT_LOGIN_RO(other_fails
);
532 static ssize_t
iscsi_stat_login_show_attr_redirects(
533 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
535 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
536 struct iscsi_tiqn
, tiqn_stat_grps
);
537 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
540 spin_lock(&lstat
->lock
);
541 ret
= snprintf(page
, PAGE_SIZE
, "%u\n", lstat
->redirects
);
542 spin_unlock(&lstat
->lock
);
546 ISCSI_STAT_LOGIN_RO(redirects
);
548 static ssize_t
iscsi_stat_login_show_attr_authorize_fails(
549 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
551 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
552 struct iscsi_tiqn
, tiqn_stat_grps
);
553 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
556 spin_lock(&lstat
->lock
);
557 ret
= snprintf(page
, PAGE_SIZE
, "%u\n", lstat
->authorize_fails
);
558 spin_unlock(&lstat
->lock
);
562 ISCSI_STAT_LOGIN_RO(authorize_fails
);
564 static ssize_t
iscsi_stat_login_show_attr_authenticate_fails(
565 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
567 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
568 struct iscsi_tiqn
, tiqn_stat_grps
);
569 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
572 spin_lock(&lstat
->lock
);
573 ret
= snprintf(page
, PAGE_SIZE
, "%u\n", lstat
->authenticate_fails
);
574 spin_unlock(&lstat
->lock
);
578 ISCSI_STAT_LOGIN_RO(authenticate_fails
);
580 static ssize_t
iscsi_stat_login_show_attr_negotiate_fails(
581 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
583 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
584 struct iscsi_tiqn
, tiqn_stat_grps
);
585 struct iscsi_login_stats
*lstat
= &tiqn
->login_stats
;
588 spin_lock(&lstat
->lock
);
589 ret
= snprintf(page
, PAGE_SIZE
, "%u\n", lstat
->negotiate_fails
);
590 spin_unlock(&lstat
->lock
);
594 ISCSI_STAT_LOGIN_RO(negotiate_fails
);
596 CONFIGFS_EATTR_OPS(iscsi_stat_login
, iscsi_wwn_stat_grps
,
597 iscsi_login_stats_group
);
599 static struct configfs_attribute
*iscsi_stat_login_stats_attrs
[] = {
600 &iscsi_stat_login_inst
.attr
,
601 &iscsi_stat_login_indx
.attr
,
602 &iscsi_stat_login_accepts
.attr
,
603 &iscsi_stat_login_other_fails
.attr
,
604 &iscsi_stat_login_redirects
.attr
,
605 &iscsi_stat_login_authorize_fails
.attr
,
606 &iscsi_stat_login_authenticate_fails
.attr
,
607 &iscsi_stat_login_negotiate_fails
.attr
,
611 static struct configfs_item_operations iscsi_stat_login_stats_item_ops
= {
612 .show_attribute
= iscsi_stat_login_attr_show
,
613 .store_attribute
= iscsi_stat_login_attr_store
,
616 struct config_item_type iscsi_stat_login_cit
= {
617 .ct_item_ops
= &iscsi_stat_login_stats_item_ops
,
618 .ct_attrs
= iscsi_stat_login_stats_attrs
,
619 .ct_owner
= THIS_MODULE
,
623 * Target Logout Stats Table
626 CONFIGFS_EATTR_STRUCT(iscsi_stat_logout
, iscsi_wwn_stat_grps
);
627 #define ISCSI_STAT_LOGOUT(_name, _mode) \
628 static struct iscsi_stat_logout_attribute \
629 iscsi_stat_logout_##_name = \
630 __CONFIGFS_EATTR(_name, _mode, \
631 iscsi_stat_logout_show_attr_##_name, \
632 iscsi_stat_logout_store_attr_##_name);
634 #define ISCSI_STAT_LOGOUT_RO(_name) \
635 static struct iscsi_stat_logout_attribute \
636 iscsi_stat_logout_##_name = \
637 __CONFIGFS_EATTR_RO(_name, \
638 iscsi_stat_logout_show_attr_##_name);
640 static ssize_t
iscsi_stat_logout_show_attr_inst(
641 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
643 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
644 struct iscsi_tiqn
, tiqn_stat_grps
);
646 return snprintf(page
, PAGE_SIZE
, "%u\n", tiqn
->tiqn_index
);
648 ISCSI_STAT_LOGOUT_RO(inst
);
650 static ssize_t
iscsi_stat_logout_show_attr_indx(
651 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
653 return snprintf(page
, PAGE_SIZE
, "%u\n", ISCSI_NODE_INDEX
);
655 ISCSI_STAT_LOGOUT_RO(indx
);
657 static ssize_t
iscsi_stat_logout_show_attr_normal_logouts(
658 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
660 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
661 struct iscsi_tiqn
, tiqn_stat_grps
);
662 struct iscsi_logout_stats
*lstats
= &tiqn
->logout_stats
;
664 return snprintf(page
, PAGE_SIZE
, "%u\n", lstats
->normal_logouts
);
666 ISCSI_STAT_LOGOUT_RO(normal_logouts
);
668 static ssize_t
iscsi_stat_logout_show_attr_abnormal_logouts(
669 struct iscsi_wwn_stat_grps
*igrps
, char *page
)
671 struct iscsi_tiqn
*tiqn
= container_of(igrps
,
672 struct iscsi_tiqn
, tiqn_stat_grps
);
673 struct iscsi_logout_stats
*lstats
= &tiqn
->logout_stats
;
675 return snprintf(page
, PAGE_SIZE
, "%u\n", lstats
->abnormal_logouts
);
677 ISCSI_STAT_LOGOUT_RO(abnormal_logouts
);
679 CONFIGFS_EATTR_OPS(iscsi_stat_logout
, iscsi_wwn_stat_grps
,
680 iscsi_logout_stats_group
);
682 static struct configfs_attribute
*iscsi_stat_logout_stats_attrs
[] = {
683 &iscsi_stat_logout_inst
.attr
,
684 &iscsi_stat_logout_indx
.attr
,
685 &iscsi_stat_logout_normal_logouts
.attr
,
686 &iscsi_stat_logout_abnormal_logouts
.attr
,
690 static struct configfs_item_operations iscsi_stat_logout_stats_item_ops
= {
691 .show_attribute
= iscsi_stat_logout_attr_show
,
692 .store_attribute
= iscsi_stat_logout_attr_store
,
695 struct config_item_type iscsi_stat_logout_cit
= {
696 .ct_item_ops
= &iscsi_stat_logout_stats_item_ops
,
697 .ct_attrs
= iscsi_stat_logout_stats_attrs
,
698 .ct_owner
= THIS_MODULE
,
702 * Session Stats Table
705 CONFIGFS_EATTR_STRUCT(iscsi_stat_sess
, iscsi_node_stat_grps
);
706 #define ISCSI_STAT_SESS(_name, _mode) \
707 static struct iscsi_stat_sess_attribute \
708 iscsi_stat_sess_##_name = \
709 __CONFIGFS_EATTR(_name, _mode, \
710 iscsi_stat_sess_show_attr_##_name, \
711 iscsi_stat_sess_store_attr_##_name);
713 #define ISCSI_STAT_SESS_RO(_name) \
714 static struct iscsi_stat_sess_attribute \
715 iscsi_stat_sess_##_name = \
716 __CONFIGFS_EATTR_RO(_name, \
717 iscsi_stat_sess_show_attr_##_name);
719 static ssize_t
iscsi_stat_sess_show_attr_inst(
720 struct iscsi_node_stat_grps
*igrps
, char *page
)
722 struct iscsi_node_acl
*acl
= container_of(igrps
,
723 struct iscsi_node_acl
, node_stat_grps
);
724 struct se_wwn
*wwn
= acl
->se_node_acl
.se_tpg
->se_tpg_wwn
;
725 struct iscsi_tiqn
*tiqn
= container_of(wwn
,
726 struct iscsi_tiqn
, tiqn_wwn
);
728 return snprintf(page
, PAGE_SIZE
, "%u\n", tiqn
->tiqn_index
);
730 ISCSI_STAT_SESS_RO(inst
);
732 static ssize_t
iscsi_stat_sess_show_attr_node(
733 struct iscsi_node_stat_grps
*igrps
, char *page
)
735 struct iscsi_node_acl
*acl
= container_of(igrps
,
736 struct iscsi_node_acl
, node_stat_grps
);
737 struct se_node_acl
*se_nacl
= &acl
->se_node_acl
;
738 struct iscsi_session
*sess
;
739 struct se_session
*se_sess
;
742 spin_lock_bh(&se_nacl
->nacl_sess_lock
);
743 se_sess
= se_nacl
->nacl_sess
;
745 sess
= se_sess
->fabric_sess_ptr
;
747 ret
= snprintf(page
, PAGE_SIZE
, "%u\n",
748 sess
->sess_ops
->SessionType
? 0 : ISCSI_NODE_INDEX
);
750 spin_unlock_bh(&se_nacl
->nacl_sess_lock
);
754 ISCSI_STAT_SESS_RO(node
);
756 static ssize_t
iscsi_stat_sess_show_attr_indx(
757 struct iscsi_node_stat_grps
*igrps
, char *page
)
759 struct iscsi_node_acl
*acl
= container_of(igrps
,
760 struct iscsi_node_acl
, node_stat_grps
);
761 struct se_node_acl
*se_nacl
= &acl
->se_node_acl
;
762 struct iscsi_session
*sess
;
763 struct se_session
*se_sess
;
766 spin_lock_bh(&se_nacl
->nacl_sess_lock
);
767 se_sess
= se_nacl
->nacl_sess
;
769 sess
= se_sess
->fabric_sess_ptr
;
771 ret
= snprintf(page
, PAGE_SIZE
, "%u\n",
772 sess
->session_index
);
774 spin_unlock_bh(&se_nacl
->nacl_sess_lock
);
778 ISCSI_STAT_SESS_RO(indx
);
780 static ssize_t
iscsi_stat_sess_show_attr_cmd_pdus(
781 struct iscsi_node_stat_grps
*igrps
, char *page
)
783 struct iscsi_node_acl
*acl
= container_of(igrps
,
784 struct iscsi_node_acl
, node_stat_grps
);
785 struct se_node_acl
*se_nacl
= &acl
->se_node_acl
;
786 struct iscsi_session
*sess
;
787 struct se_session
*se_sess
;
790 spin_lock_bh(&se_nacl
->nacl_sess_lock
);
791 se_sess
= se_nacl
->nacl_sess
;
793 sess
= se_sess
->fabric_sess_ptr
;
795 ret
= snprintf(page
, PAGE_SIZE
, "%u\n", sess
->cmd_pdus
);
797 spin_unlock_bh(&se_nacl
->nacl_sess_lock
);
801 ISCSI_STAT_SESS_RO(cmd_pdus
);
803 static ssize_t
iscsi_stat_sess_show_attr_rsp_pdus(
804 struct iscsi_node_stat_grps
*igrps
, char *page
)
806 struct iscsi_node_acl
*acl
= container_of(igrps
,
807 struct iscsi_node_acl
, node_stat_grps
);
808 struct se_node_acl
*se_nacl
= &acl
->se_node_acl
;
809 struct iscsi_session
*sess
;
810 struct se_session
*se_sess
;
813 spin_lock_bh(&se_nacl
->nacl_sess_lock
);
814 se_sess
= se_nacl
->nacl_sess
;
816 sess
= se_sess
->fabric_sess_ptr
;
818 ret
= snprintf(page
, PAGE_SIZE
, "%u\n", sess
->rsp_pdus
);
820 spin_unlock_bh(&se_nacl
->nacl_sess_lock
);
824 ISCSI_STAT_SESS_RO(rsp_pdus
);
826 static ssize_t
iscsi_stat_sess_show_attr_txdata_octs(
827 struct iscsi_node_stat_grps
*igrps
, char *page
)
829 struct iscsi_node_acl
*acl
= container_of(igrps
,
830 struct iscsi_node_acl
, node_stat_grps
);
831 struct se_node_acl
*se_nacl
= &acl
->se_node_acl
;
832 struct iscsi_session
*sess
;
833 struct se_session
*se_sess
;
836 spin_lock_bh(&se_nacl
->nacl_sess_lock
);
837 se_sess
= se_nacl
->nacl_sess
;
839 sess
= se_sess
->fabric_sess_ptr
;
841 ret
= snprintf(page
, PAGE_SIZE
, "%llu\n",
842 (unsigned long long)sess
->tx_data_octets
);
844 spin_unlock_bh(&se_nacl
->nacl_sess_lock
);
848 ISCSI_STAT_SESS_RO(txdata_octs
);
850 static ssize_t
iscsi_stat_sess_show_attr_rxdata_octs(
851 struct iscsi_node_stat_grps
*igrps
, char *page
)
853 struct iscsi_node_acl
*acl
= container_of(igrps
,
854 struct iscsi_node_acl
, node_stat_grps
);
855 struct se_node_acl
*se_nacl
= &acl
->se_node_acl
;
856 struct iscsi_session
*sess
;
857 struct se_session
*se_sess
;
860 spin_lock_bh(&se_nacl
->nacl_sess_lock
);
861 se_sess
= se_nacl
->nacl_sess
;
863 sess
= se_sess
->fabric_sess_ptr
;
865 ret
= snprintf(page
, PAGE_SIZE
, "%llu\n",
866 (unsigned long long)sess
->rx_data_octets
);
868 spin_unlock_bh(&se_nacl
->nacl_sess_lock
);
872 ISCSI_STAT_SESS_RO(rxdata_octs
);
874 static ssize_t
iscsi_stat_sess_show_attr_conn_digest_errors(
875 struct iscsi_node_stat_grps
*igrps
, char *page
)
877 struct iscsi_node_acl
*acl
= container_of(igrps
,
878 struct iscsi_node_acl
, node_stat_grps
);
879 struct se_node_acl
*se_nacl
= &acl
->se_node_acl
;
880 struct iscsi_session
*sess
;
881 struct se_session
*se_sess
;
884 spin_lock_bh(&se_nacl
->nacl_sess_lock
);
885 se_sess
= se_nacl
->nacl_sess
;
887 sess
= se_sess
->fabric_sess_ptr
;
889 ret
= snprintf(page
, PAGE_SIZE
, "%u\n",
890 sess
->conn_digest_errors
);
892 spin_unlock_bh(&se_nacl
->nacl_sess_lock
);
896 ISCSI_STAT_SESS_RO(conn_digest_errors
);
898 static ssize_t
iscsi_stat_sess_show_attr_conn_timeout_errors(
899 struct iscsi_node_stat_grps
*igrps
, char *page
)
901 struct iscsi_node_acl
*acl
= container_of(igrps
,
902 struct iscsi_node_acl
, node_stat_grps
);
903 struct se_node_acl
*se_nacl
= &acl
->se_node_acl
;
904 struct iscsi_session
*sess
;
905 struct se_session
*se_sess
;
908 spin_lock_bh(&se_nacl
->nacl_sess_lock
);
909 se_sess
= se_nacl
->nacl_sess
;
911 sess
= se_sess
->fabric_sess_ptr
;
913 ret
= snprintf(page
, PAGE_SIZE
, "%u\n",
914 sess
->conn_timeout_errors
);
916 spin_unlock_bh(&se_nacl
->nacl_sess_lock
);
920 ISCSI_STAT_SESS_RO(conn_timeout_errors
);
922 CONFIGFS_EATTR_OPS(iscsi_stat_sess
, iscsi_node_stat_grps
,
923 iscsi_sess_stats_group
);
925 static struct configfs_attribute
*iscsi_stat_sess_stats_attrs
[] = {
926 &iscsi_stat_sess_inst
.attr
,
927 &iscsi_stat_sess_node
.attr
,
928 &iscsi_stat_sess_indx
.attr
,
929 &iscsi_stat_sess_cmd_pdus
.attr
,
930 &iscsi_stat_sess_rsp_pdus
.attr
,
931 &iscsi_stat_sess_txdata_octs
.attr
,
932 &iscsi_stat_sess_rxdata_octs
.attr
,
933 &iscsi_stat_sess_conn_digest_errors
.attr
,
934 &iscsi_stat_sess_conn_timeout_errors
.attr
,
938 static struct configfs_item_operations iscsi_stat_sess_stats_item_ops
= {
939 .show_attribute
= iscsi_stat_sess_attr_show
,
940 .store_attribute
= iscsi_stat_sess_attr_store
,
943 struct config_item_type iscsi_stat_sess_cit
= {
944 .ct_item_ops
= &iscsi_stat_sess_stats_item_ops
,
945 .ct_attrs
= iscsi_stat_sess_stats_attrs
,
946 .ct_owner
= THIS_MODULE
,