cregit-Linux how code gets into the kernel

Release 4.14 drivers/target/target_core_stat.c

Directory: drivers/target
/*******************************************************************************
 * Filename:  target_core_stat.c
 *
 * Modern ConfigFS group context specific statistics based on original
 * target_core_mib.c code
 *
 * (c) Copyright 2006-2013 Datera, Inc.
 *
 * Nicholas A. Bellinger <nab@linux-iscsi.org>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 *
 ******************************************************************************/

#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/delay.h>
#include <linux/timer.h>
#include <linux/string.h>
#include <linux/utsname.h>
#include <linux/proc_fs.h>
#include <linux/seq_file.h>
#include <linux/configfs.h>

#include <target/target_core_base.h>
#include <target/target_core_backend.h>
#include <target/target_core_fabric.h>

#include "target_core_internal.h"

#ifndef INITIAL_JIFFIES

#define INITIAL_JIFFIES ((unsigned long)(unsigned int) (-300*HZ))
#endif


#define NONE		"None"

#define ISPRINT(a)   ((a >= ' ') && (a <= '~'))


#define SCSI_LU_INDEX			1

#define LU_COUNT			1

/*
 * SCSI Device Table
 */


static struct se_device *to_stat_dev(struct config_item *item) { struct se_dev_stat_grps *sgrps = container_of(to_config_group(item), struct se_dev_stat_grps, scsi_dev_group); return container_of(sgrps, struct se_device, dev_stat_grps); }

Contributors

PersonTokensPropCommitsCommitProp
Christoph Hellwig2559.52%266.67%
Nicholas Bellinger1740.48%133.33%
Total42100.00%3100.00%


static ssize_t target_stat_inst_show(struct config_item *item, char *page) { struct se_hba *hba = to_stat_dev(item)->se_hba; return snprintf(page, PAGE_SIZE, "%u\n", hba->hba_index); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2253.66%133.33%
Christoph Hellwig1946.34%266.67%
Total41100.00%3100.00%


static ssize_t target_stat_indx_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "%u\n", to_stat_dev(item)->dev_index); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2578.12%150.00%
Christoph Hellwig721.88%150.00%
Total32100.00%2100.00%


static ssize_t target_stat_role_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "Target\n"); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2288.00%150.00%
Christoph Hellwig312.00%150.00%
Total25100.00%2100.00%


static ssize_t target_stat_ports_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "%u\n", to_stat_dev(item)->export_count); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2475.00%133.33%
Christoph Hellwig825.00%266.67%
Total32100.00%3100.00%

CONFIGFS_ATTR_RO(target_stat_, inst); CONFIGFS_ATTR_RO(target_stat_, indx); CONFIGFS_ATTR_RO(target_stat_, role); CONFIGFS_ATTR_RO(target_stat_, ports); static struct configfs_attribute *target_stat_scsi_dev_attrs[] = { &target_stat_attr_inst, &target_stat_attr_indx, &target_stat_attr_role, &target_stat_attr_ports, NULL, }; static struct config_item_type target_stat_scsi_dev_cit = { .ct_attrs = target_stat_scsi_dev_attrs, .ct_owner = THIS_MODULE, }; /* * SCSI Target Device Table */
static struct se_device *to_stat_tgt_dev(struct config_item *item) { struct se_dev_stat_grps *sgrps = container_of(to_config_group(item), struct se_dev_stat_grps, scsi_tgt_dev_group); return container_of(sgrps, struct se_device, dev_stat_grps); }

Contributors

PersonTokensPropCommitsCommitProp
Christoph Hellwig2559.52%266.67%
Nicholas Bellinger1740.48%133.33%
Total42100.00%3100.00%


static ssize_t target_stat_tgt_inst_show(struct config_item *item, char *page) { struct se_hba *hba = to_stat_tgt_dev(item)->se_hba; return snprintf(page, PAGE_SIZE, "%u\n", hba->hba_index); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2253.66%133.33%
Christoph Hellwig1946.34%266.67%
Total41100.00%3100.00%


static ssize_t target_stat_tgt_indx_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "%u\n", to_stat_tgt_dev(item)->dev_index); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2578.12%150.00%
Christoph Hellwig721.88%150.00%
Total32100.00%2100.00%


static ssize_t target_stat_tgt_num_lus_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "%u\n", LU_COUNT); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2488.89%150.00%
Christoph Hellwig311.11%150.00%
Total27100.00%2100.00%


static ssize_t target_stat_tgt_status_show(struct config_item *item, char *page) { if (to_stat_tgt_dev(item)->export_count) return snprintf(page, PAGE_SIZE, "activated"); else return snprintf(page, PAGE_SIZE, "deactivated"); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2964.44%133.33%
Christoph Hellwig1635.56%266.67%
Total45100.00%3100.00%


static ssize_t target_stat_tgt_non_access_lus_show(struct config_item *item, char *page) { int non_accessible_lus; if (to_stat_tgt_dev(item)->export_count) non_accessible_lus = 0; else non_accessible_lus = 1; return snprintf(page, PAGE_SIZE, "%u\n", non_accessible_lus); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger3981.25%133.33%
Christoph Hellwig918.75%266.67%
Total48100.00%3100.00%


static ssize_t target_stat_tgt_resets_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "%lu\n", atomic_long_read(&to_stat_tgt_dev(item)->num_resets)); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2261.11%266.67%
Christoph Hellwig1438.89%133.33%
Total36100.00%3100.00%


static ssize_t target_stat_tgt_aborts_complete_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "%lu\n", atomic_long_read(&to_stat_tgt_dev(item)->aborts_complete)); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger36100.00%1100.00%
Total36100.00%1100.00%


static ssize_t target_stat_tgt_aborts_no_task_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "%lu\n", atomic_long_read(&to_stat_tgt_dev(item)->aborts_no_task)); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger36100.00%1100.00%
Total36100.00%1100.00%

CONFIGFS_ATTR_RO(target_stat_tgt_, inst); CONFIGFS_ATTR_RO(target_stat_tgt_, indx); CONFIGFS_ATTR_RO(target_stat_tgt_, num_lus); CONFIGFS_ATTR_RO(target_stat_tgt_, status); CONFIGFS_ATTR_RO(target_stat_tgt_, non_access_lus); CONFIGFS_ATTR_RO(target_stat_tgt_, resets); CONFIGFS_ATTR_RO(target_stat_tgt_, aborts_complete); CONFIGFS_ATTR_RO(target_stat_tgt_, aborts_no_task); static struct configfs_attribute *target_stat_scsi_tgt_dev_attrs[] = { &target_stat_tgt_attr_inst, &target_stat_tgt_attr_indx, &target_stat_tgt_attr_num_lus, &target_stat_tgt_attr_status, &target_stat_tgt_attr_non_access_lus, &target_stat_tgt_attr_resets, &target_stat_tgt_attr_aborts_complete, &target_stat_tgt_attr_aborts_no_task, NULL, }; static struct config_item_type target_stat_scsi_tgt_dev_cit = { .ct_attrs = target_stat_scsi_tgt_dev_attrs, .ct_owner = THIS_MODULE, }; /* * SCSI Logical Unit Table */
static struct se_device *to_stat_lu_dev(struct config_item *item) { struct se_dev_stat_grps *sgrps = container_of(to_config_group(item), struct se_dev_stat_grps, scsi_lu_group); return container_of(sgrps, struct se_device, dev_stat_grps); }

Contributors

PersonTokensPropCommitsCommitProp
Christoph Hellwig2559.52%266.67%
Nicholas Bellinger1740.48%133.33%
Total42100.00%3100.00%


static ssize_t target_stat_lu_inst_show(struct config_item *item, char *page) { struct se_hba *hba = to_stat_lu_dev(item)->se_hba; return snprintf(page, PAGE_SIZE, "%u\n", hba->hba_index); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2253.66%133.33%
Christoph Hellwig1946.34%266.67%
Total41100.00%3100.00%


static ssize_t target_stat_lu_dev_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "%u\n", to_stat_lu_dev(item)->dev_index); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2578.12%150.00%
Christoph Hellwig721.88%150.00%
Total32100.00%2100.00%


static ssize_t target_stat_lu_indx_show(struct config_item *item, char *page) { return snprintf(page, PAGE_SIZE, "%u\n", SCSI_LU_INDEX); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2488.89%150.00%
Christoph Hellwig311.11%150.00%
Total27100.00%2100.00%


static ssize_t target_stat_lu_lun_show(struct config_item *item, char *page) { /* FIXME: scsiLuDefaultLun */ return snprintf(page, PAGE_SIZE, "%llu\n", (unsigned long long)0); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger3090.91%150.00%
Christoph Hellwig39.09%150.00%
Total33100.00%2100.00%


static ssize_t target_stat_lu_lu_name_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); /* scsiLuWwnName */ return snprintf(page, PAGE_SIZE, "%s\n", (strlen(dev->t10_wwn.unit_serial)) ? dev->t10_wwn.unit_serial : "None"); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger4480.00%125.00%
Christoph Hellwig712.73%250.00%
Andy Grover47.27%125.00%
Total55100.00%4100.00%


static ssize_t target_stat_lu_vend_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); int i; char str[sizeof(dev->t10_wwn.vendor)+1]; /* scsiLuVendorId */ for (i = 0; i < sizeof(dev->t10_wwn.vendor); i++) str[i] = ISPRINT(dev->t10_wwn.vendor[i]) ? dev->t10_wwn.vendor[i] : ' '; str[i] = '\0'; return snprintf(page, PAGE_SIZE, "%s\n", str); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger7264.86%125.00%
Andy Grover3228.83%125.00%
Christoph Hellwig76.31%250.00%
Total111100.00%4100.00%


static ssize_t target_stat_lu_prod_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); int i; char str[sizeof(dev->t10_wwn.model)+1]; /* scsiLuProductId */ for (i = 0; i < sizeof(dev->t10_wwn.model); i++) str[i] = ISPRINT(dev->t10_wwn.model[i]) ? dev->t10_wwn.model[i] : ' '; str[i] = '\0'; return snprintf(page, PAGE_SIZE, "%s\n", str); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger7063.06%120.00%
Andy Grover3027.03%120.00%
Christoph Hellwig109.01%240.00%
David Disseldorp10.90%120.00%
Total111100.00%5100.00%


static ssize_t target_stat_lu_rev_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); int i; char str[sizeof(dev->t10_wwn.revision)+1]; /* scsiLuRevisionId */ for (i = 0; i < sizeof(dev->t10_wwn.revision); i++) str[i] = ISPRINT(dev->t10_wwn.revision[i]) ? dev->t10_wwn.revision[i] : ' '; str[i] = '\0'; return snprintf(page, PAGE_SIZE, "%s\n", str); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger7264.86%125.00%
Andy Grover3228.83%125.00%
Christoph Hellwig76.31%250.00%
Total111100.00%4100.00%


static ssize_t target_stat_lu_dev_type_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); /* scsiLuPeripheralType */ return snprintf(page, PAGE_SIZE, "%u\n", dev->transport->get_device_type(dev)); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger3680.00%125.00%
Christoph Hellwig715.56%250.00%
Andy Grover24.44%125.00%
Total45100.00%4100.00%


static ssize_t target_stat_lu_status_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); /* scsiLuStatus */ return snprintf(page, PAGE_SIZE, "%s\n", (dev->export_count) ? "available" : "notavailable"); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger3882.61%133.33%
Christoph Hellwig817.39%266.67%
Total46100.00%3100.00%


static ssize_t target_stat_lu_state_bit_show(struct config_item *item, char *page) { /* scsiLuState */ return snprintf(page, PAGE_SIZE, "exposed\n"); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2388.46%150.00%
Christoph Hellwig311.54%150.00%
Total26100.00%2100.00%


static ssize_t target_stat_lu_num_cmds_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); /* scsiLuNumCommands */ return snprintf(page, PAGE_SIZE, "%lu\n", atomic_long_read(&dev->num_cmds)); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger3784.09%250.00%
Christoph Hellwig715.91%250.00%
Total44100.00%4100.00%


static ssize_t target_stat_lu_read_mbytes_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); /* scsiLuReadMegaBytes */ return snprintf(page, PAGE_SIZE, "%lu\n", atomic_long_read(&dev->read_bytes) >> 20); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger3984.78%250.00%
Christoph Hellwig715.22%250.00%
Total46100.00%4100.00%


static ssize_t target_stat_lu_write_mbytes_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); /* scsiLuWrittenMegaBytes */ return snprintf(page, PAGE_SIZE, "%lu\n", atomic_long_read(&dev->write_bytes) >> 20); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger3984.78%250.00%
Christoph Hellwig715.22%250.00%
Total46100.00%4100.00%


static ssize_t target_stat_lu_resets_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); /* scsiLuInResets */ return snprintf(page, PAGE_SIZE, "%lu\n", atomic_long_read(&dev->num_resets)); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger3784.09%250.00%
Christoph Hellwig715.91%250.00%
Total44100.00%4100.00%


static ssize_t target_stat_lu_full_stat_show(struct config_item *item, char *page) { /* FIXME: scsiLuOutTaskSetFullStatus */ return snprintf(page, PAGE_SIZE, "%u\n", 0); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2589.29%150.00%
Christoph Hellwig310.71%150.00%
Total28100.00%2100.00%


static ssize_t target_stat_lu_hs_num_cmds_show(struct config_item *item, char *page) { /* FIXME: scsiLuHSInCommands */ return snprintf(page, PAGE_SIZE, "%u\n", 0); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger2589.29%150.00%
Christoph Hellwig310.71%150.00%
Total28100.00%2100.00%


static ssize_t target_stat_lu_creation_time_show(struct config_item *item, char *page) { struct se_device *dev = to_stat_lu_dev(item); /* scsiLuCreationTime */ return snprintf(page, PAGE_SIZE, "%u\n", (u32)(((u32)dev->creation_time - INITIAL_JIFFIES) * 100 / HZ)); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger4987.50%133.33%
Christoph Hellwig712.50%266.67%
Total56100.00%3100.00%

CONFIGFS_ATTR_RO(target_stat_lu_, inst); CONFIGFS_ATTR_RO(target_stat_lu_, dev); CONFIGFS_ATTR_RO(target_stat_lu_, indx); CONFIGFS_ATTR_RO(target_stat_lu_, lun); CONFIGFS_ATTR_RO(target_stat_lu_, lu_name); CONFIGFS_ATTR_RO(target_stat_lu_, vend); CONFIGFS_ATTR_RO(target_stat_lu_, prod); CONFIGFS_ATTR_RO(target_stat_lu_, rev); CONFIGFS_ATTR_RO(target_stat_lu_, dev_type); CONFIGFS_ATTR_RO(target_stat_lu_, status); CONFIGFS_ATTR_RO(target_stat_lu_, state_bit); CONFIGFS_ATTR_RO(target_stat_lu_, num_cmds); CONFIGFS_ATTR_RO(target_stat_lu_, read_mbytes); CONFIGFS_ATTR_RO(target_stat_lu_, write_mbytes); CONFIGFS_ATTR_RO(target_stat_lu_, resets); CONFIGFS_ATTR_RO(target_stat_lu_, full_stat); CONFIGFS_ATTR_RO(target_stat_lu_, hs_num_cmds); CONFIGFS_ATTR_RO(target_stat_lu_, creation_time); static struct configfs_attribute *target_stat_scsi_lu_attrs[] = { &target_stat_lu_attr_inst, &target_stat_lu_attr_dev, &target_stat_lu_attr_indx, &target_stat_lu_attr_lun, &target_stat_lu_attr_lu_name, &target_stat_lu_attr_vend, &target_stat_lu_attr_prod, &target_stat_lu_attr_rev, &target_stat_lu_attr_dev_type, &target_stat_lu_attr_status, &target_stat_lu_attr_state_bit, &target_stat_lu_attr_num_cmds, &target_stat_lu_attr_read_mbytes, &target_stat_lu_attr_write_mbytes, &target_stat_lu_attr_resets, &target_stat_lu_attr_full_stat, &target_stat_lu_attr_hs_num_cmds, &target_stat_lu_attr_creation_time, NULL, }; static struct config_item_type target_stat_scsi_lu_cit = { .ct_attrs = target_stat_scsi_lu_attrs, .ct_owner = THIS_MODULE, }; /* * Called from target_core_configfs.c:target_core_make_subdev() to setup * the target statistics groups + configfs CITs located in target_core_stat.c */
void target_stat_setup_dev_default_groups(struct se_device *dev) { config_group_init_type_name(&dev->dev_stat_grps.scsi_dev_group, "scsi_dev", &target_stat_scsi_dev_cit); configfs_add_default_group(&dev->dev_stat_grps.scsi_dev_group, &dev->dev_stat_grps.stat_group); config_group_init_type_name(&dev->dev_stat_grps.scsi_tgt_dev_group, "scsi_tgt_dev", &target_stat_scsi_tgt_dev_cit); configfs_add_default_group(&dev->dev_stat_grps.scsi_tgt_dev_group, &dev->dev_stat_grps.stat_group); config_group_init_type_name(&dev->dev_stat_grps.scsi_lu_group, "scsi_lu", &target_stat_scsi_lu_cit); configfs_add_default_group(&dev->dev_stat_grps.scsi_lu_group, &dev->dev_stat_grps.stat_group); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger4845.28%125.00%
Christoph Hellwig4643.40%250.00%
Andy Grover1211.32%125.00%
Total106100.00%4100.00%

/* * SCSI Port Table */
static struct se_lun *to_stat_port(struct config_item *item) { struct se_port_stat_grps *pgrps = container_of(to_config_group(item), struct se_port_stat_grps, scsi_port_group); return container_of(pgrps, struct se_lun, port_stat_grps); }

Contributors

PersonTokensPropCommitsCommitProp
Christoph Hellwig3890.48%150.00%
Nicholas Bellinger49.52%150.00%
Total42100.00%2100.00%


static ssize_t target_stat_port_inst_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", dev->hba_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6183.56%250.00%
Christoph Hellwig1216.44%250.00%
Total73100.00%4100.00%


static ssize_t target_stat_port_dev_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", dev->dev_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6284.93%250.00%
Christoph Hellwig1115.07%250.00%
Total73100.00%4100.00%


static ssize_t target_stat_port_indx_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", lun->lun_rtpi); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger5980.82%250.00%
Christoph Hellwig1419.18%250.00%
Total73100.00%4100.00%


static ssize_t target_stat_port_role_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%s%u\n", "Device", dev->dev_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6586.67%250.00%
Christoph Hellwig1013.33%250.00%
Total75100.00%4100.00%


static ssize_t target_stat_port_busy_count_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) { /* FIXME: scsiPortBusyStatuses */ ret = snprintf(page, PAGE_SIZE, "%u\n", 0); } rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6081.08%250.00%
Christoph Hellwig1418.92%250.00%
Total74100.00%4100.00%

CONFIGFS_ATTR_RO(target_stat_port_, inst); CONFIGFS_ATTR_RO(target_stat_port_, dev); CONFIGFS_ATTR_RO(target_stat_port_, indx); CONFIGFS_ATTR_RO(target_stat_port_, role); CONFIGFS_ATTR_RO(target_stat_port_, busy_count); static struct configfs_attribute *target_stat_scsi_port_attrs[] = { &target_stat_port_attr_inst, &target_stat_port_attr_dev, &target_stat_port_attr_indx, &target_stat_port_attr_role, &target_stat_port_attr_busy_count, NULL, }; static struct config_item_type target_stat_scsi_port_cit = { .ct_attrs = target_stat_scsi_port_attrs, .ct_owner = THIS_MODULE, }; /* * SCSI Target Port Table */
static struct se_lun *to_stat_tgt_port(struct config_item *item) { struct se_port_stat_grps *pgrps = container_of(to_config_group(item), struct se_port_stat_grps, scsi_tgt_port_group); return container_of(pgrps, struct se_lun, port_stat_grps); }

Contributors

PersonTokensPropCommitsCommitProp
Christoph Hellwig3890.48%150.00%
Nicholas Bellinger49.52%150.00%
Total42100.00%2100.00%


static ssize_t target_stat_tgt_port_inst_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_tgt_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", dev->hba_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6284.93%250.00%
Christoph Hellwig1115.07%250.00%
Total73100.00%4100.00%


static ssize_t target_stat_tgt_port_dev_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_tgt_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", dev->dev_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6284.93%250.00%
Christoph Hellwig1115.07%250.00%
Total73100.00%4100.00%


static ssize_t target_stat_tgt_port_indx_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_tgt_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", lun->lun_rtpi); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger5980.82%250.00%
Christoph Hellwig1419.18%250.00%
Total73100.00%4100.00%


static ssize_t target_stat_tgt_port_name_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_tgt_port(item); struct se_portal_group *tpg = lun->lun_tpg; struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%sPort#%u\n", tpg->se_tpg_tfo->get_fabric_name(), lun->lun_rtpi); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6775.28%240.00%
Christoph Hellwig2022.47%240.00%
Andy Grover22.25%120.00%
Total89100.00%5100.00%


static ssize_t target_stat_tgt_port_port_index_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_tgt_port(item); struct se_portal_group *tpg = lun->lun_tpg; struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%s%s%d\n", tpg->se_tpg_tfo->tpg_get_wwn(tpg), "+t+", tpg->se_tpg_tfo->tpg_get_tag(tpg)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger7576.53%240.00%
Christoph Hellwig1919.39%240.00%
Andy Grover44.08%120.00%
Total98100.00%5100.00%


static ssize_t target_stat_tgt_port_in_cmds_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_tgt_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%lu\n", atomic_long_read(&lun->lun_stats.cmd_pdus)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6582.28%250.00%
Christoph Hellwig1417.72%250.00%
Total79100.00%4100.00%


static ssize_t target_stat_tgt_port_write_mbytes_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_tgt_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", (u32)(atomic_long_read(&lun->lun_stats.rx_data_octets) >> 20)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger7182.56%250.00%
Christoph Hellwig1517.44%250.00%
Total86100.00%4100.00%


static ssize_t target_stat_tgt_port_read_mbytes_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_tgt_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", (u32)(atomic_long_read(&lun->lun_stats.tx_data_octets) >> 20)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger7182.56%250.00%
Christoph Hellwig1517.44%250.00%
Total86100.00%4100.00%


static ssize_t target_stat_tgt_port_hs_in_cmds_show(struct config_item *item, char *page) { struct se_lun *lun = to_stat_tgt_port(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) { /* FIXME: scsiTgtPortHsInCommands */ ret = snprintf(page, PAGE_SIZE, "%u\n", 0); } rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6081.08%250.00%
Christoph Hellwig1418.92%250.00%
Total74100.00%4100.00%

CONFIGFS_ATTR_RO(target_stat_tgt_port_, inst); CONFIGFS_ATTR_RO(target_stat_tgt_port_, dev); CONFIGFS_ATTR_RO(target_stat_tgt_port_, indx); CONFIGFS_ATTR_RO(target_stat_tgt_port_, name); CONFIGFS_ATTR_RO(target_stat_tgt_port_, port_index); CONFIGFS_ATTR_RO(target_stat_tgt_port_, in_cmds); CONFIGFS_ATTR_RO(target_stat_tgt_port_, write_mbytes); CONFIGFS_ATTR_RO(target_stat_tgt_port_, read_mbytes); CONFIGFS_ATTR_RO(target_stat_tgt_port_, hs_in_cmds); static struct configfs_attribute *target_stat_scsi_tgt_port_attrs[] = { &target_stat_tgt_port_attr_inst, &target_stat_tgt_port_attr_dev, &target_stat_tgt_port_attr_indx, &target_stat_tgt_port_attr_name, &target_stat_tgt_port_attr_port_index, &target_stat_tgt_port_attr_in_cmds, &target_stat_tgt_port_attr_write_mbytes, &target_stat_tgt_port_attr_read_mbytes, &target_stat_tgt_port_attr_hs_in_cmds, NULL, }; static struct config_item_type target_stat_scsi_tgt_port_cit = { .ct_attrs = target_stat_scsi_tgt_port_attrs, .ct_owner = THIS_MODULE, }; /* * SCSI Transport Table */
static struct se_lun *to_transport_stat(struct config_item *item) { struct se_port_stat_grps *pgrps = container_of(to_config_group(item), struct se_port_stat_grps, scsi_transport_group); return container_of(pgrps, struct se_lun, port_stat_grps); }

Contributors

PersonTokensPropCommitsCommitProp
Christoph Hellwig3992.86%150.00%
Nicholas Bellinger37.14%150.00%
Total42100.00%2100.00%


static ssize_t target_stat_transport_inst_show(struct config_item *item, char *page) { struct se_lun *lun = to_transport_stat(item); struct se_device *dev; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", dev->hba_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6183.56%250.00%
Christoph Hellwig1216.44%250.00%
Total73100.00%4100.00%


static ssize_t target_stat_transport_device_show(struct config_item *item, char *page) { struct se_lun *lun = to_transport_stat(item); struct se_device *dev; struct se_portal_group *tpg = lun->lun_tpg; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) { /* scsiTransportType */ ret = snprintf(page, PAGE_SIZE, "scsiTransport%s\n", tpg->se_tpg_tfo->get_fabric_name()); } rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6877.27%240.00%
Christoph Hellwig1820.45%240.00%
Andy Grover22.27%120.00%
Total88100.00%5100.00%


static ssize_t target_stat_transport_indx_show(struct config_item *item, char *page) { struct se_lun *lun = to_transport_stat(item); struct se_device *dev; struct se_portal_group *tpg = lun->lun_tpg; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", tpg->se_tpg_tfo->tpg_get_inst_index(tpg)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6878.16%240.00%
Christoph Hellwig1719.54%240.00%
Andy Grover22.30%120.00%
Total87100.00%5100.00%


static ssize_t target_stat_transport_dev_name_show(struct config_item *item, char *page) { struct se_lun *lun = to_transport_stat(item); struct se_device *dev; struct se_portal_group *tpg = lun->lun_tpg; struct t10_wwn *wwn; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) { wwn = &dev->t10_wwn; /* scsiTransportDevName */ ret = snprintf(page, PAGE_SIZE, "%s+%s\n", tpg->se_tpg_tfo->tpg_get_wwn(tpg), (strlen(wwn->unit_serial)) ? wwn->unit_serial : wwn->vendor); } rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger9882.35%240.00%
Christoph Hellwig1613.45%240.00%
Andy Grover54.20%120.00%
Total119100.00%5100.00%


static ssize_t target_stat_transport_proto_id_show(struct config_item *item, char *page) { struct se_lun *lun = to_transport_stat(item); struct se_device *dev; struct se_portal_group *tpg = lun->lun_tpg; ssize_t ret = -ENODEV; rcu_read_lock(); dev = rcu_dereference(lun->lun_se_dev); if (dev) ret = snprintf(page, PAGE_SIZE, "%u\n", tpg->proto_id); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Michael Christie82100.00%1100.00%
Total82100.00%1100.00%

CONFIGFS_ATTR_RO(target_stat_transport_, inst); CONFIGFS_ATTR_RO(target_stat_transport_, device); CONFIGFS_ATTR_RO(target_stat_transport_, indx); CONFIGFS_ATTR_RO(target_stat_transport_, dev_name); CONFIGFS_ATTR_RO(target_stat_transport_, proto_id); static struct configfs_attribute *target_stat_scsi_transport_attrs[] = { &target_stat_transport_attr_inst, &target_stat_transport_attr_device, &target_stat_transport_attr_indx, &target_stat_transport_attr_dev_name, &target_stat_transport_attr_proto_id, NULL, }; static struct config_item_type target_stat_scsi_transport_cit = { .ct_attrs = target_stat_scsi_transport_attrs, .ct_owner = THIS_MODULE, }; /* * Called from target_core_fabric_configfs.c:target_fabric_make_lun() to setup * the target port statistics groups + configfs CITs located in target_core_stat.c */
void target_stat_setup_port_default_groups(struct se_lun *lun) { config_group_init_type_name(&lun->port_stat_grps.scsi_port_group, "scsi_port", &target_stat_scsi_port_cit); configfs_add_default_group(&lun->port_stat_grps.scsi_port_group, &lun->port_stat_grps.stat_group); config_group_init_type_name(&lun->port_stat_grps.scsi_tgt_port_group, "scsi_tgt_port", &target_stat_scsi_tgt_port_cit); configfs_add_default_group(&lun->port_stat_grps.scsi_tgt_port_group, &lun->port_stat_grps.stat_group); config_group_init_type_name(&lun->port_stat_grps.scsi_transport_group, "scsi_transport", &target_stat_scsi_transport_cit); configfs_add_default_group(&lun->port_stat_grps.scsi_transport_group, &lun->port_stat_grps.stat_group); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger5652.83%133.33%
Christoph Hellwig3835.85%133.33%
Andy Grover1211.32%133.33%
Total106100.00%3100.00%

/* * SCSI Authorized Initiator Table */
static struct se_lun_acl *auth_to_lacl(struct config_item *item) { struct se_ml_stat_grps *lgrps = container_of(to_config_group(item), struct se_ml_stat_grps, scsi_auth_intr_group); return container_of(lgrps, struct se_lun_acl, ml_stat_grps); }

Contributors

PersonTokensPropCommitsCommitProp
Christoph Hellwig3890.48%150.00%
Nicholas Bellinger49.52%150.00%
Total42100.00%2100.00%


static ssize_t target_stat_auth_inst_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; struct se_portal_group *tpg; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } tpg = nacl->se_tpg; /* scsiInstIndex */ ret = snprintf(page, PAGE_SIZE, "%u\n", tpg->se_tpg_tfo->tpg_get_inst_index(tpg)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger10193.52%250.00%
Christoph Hellwig54.63%125.00%
Andy Grover21.85%125.00%
Total108100.00%4100.00%


static ssize_t target_stat_auth_dev_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; struct se_lun *lun; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } lun = rcu_dereference(deve->se_lun); /* scsiDeviceIndex */ ret = snprintf(page, PAGE_SIZE, "%u\n", lun->lun_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger10195.28%266.67%
Christoph Hellwig54.72%133.33%
Total106100.00%3100.00%


static ssize_t target_stat_auth_port_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; struct se_portal_group *tpg; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } tpg = nacl->se_tpg; /* scsiAuthIntrTgtPortIndex */ ret = snprintf(page, PAGE_SIZE, "%u\n", tpg->se_tpg_tfo->tpg_get_tag(tpg)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger10193.52%250.00%
Christoph Hellwig54.63%125.00%
Andy Grover21.85%125.00%
Total108100.00%4100.00%


static ssize_t target_stat_auth_indx_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* scsiAuthIntrIndex */ ret = snprintf(page, PAGE_SIZE, "%u\n", nacl->acl_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger8794.57%266.67%
Christoph Hellwig55.43%133.33%
Total92100.00%3100.00%


static ssize_t target_stat_auth_dev_or_port_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* scsiAuthIntrDevOrPort */ ret = snprintf(page, PAGE_SIZE, "%u\n", 1); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger8190.00%266.67%
Christoph Hellwig910.00%133.33%
Total90100.00%3100.00%


static ssize_t target_stat_auth_intr_name_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* scsiAuthIntrName */ ret = snprintf(page, PAGE_SIZE, "%s\n", nacl->initiatorname); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger8794.57%266.67%
Christoph Hellwig55.43%133.33%
Total92100.00%3100.00%


static ssize_t target_stat_auth_map_indx_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* FIXME: scsiAuthIntrLunMapIndex */ ret = snprintf(page, PAGE_SIZE, "%u\n", 0); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger8594.44%266.67%
Christoph Hellwig55.56%133.33%
Total90100.00%3100.00%


static ssize_t target_stat_auth_att_count_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* scsiAuthIntrAttachedTimes */ ret = snprintf(page, PAGE_SIZE, "%u\n", deve->attach_count); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger8794.57%266.67%
Christoph Hellwig55.43%133.33%
Total92100.00%3100.00%


static ssize_t target_stat_auth_num_cmds_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* scsiAuthIntrOutCommands */ ret = snprintf(page, PAGE_SIZE, "%lu\n", atomic_long_read(&deve->total_cmds)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger9194.79%266.67%
Christoph Hellwig55.21%133.33%
Total96100.00%3100.00%


static ssize_t target_stat_auth_read_mbytes_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* scsiAuthIntrReadMegaBytes */ ret = snprintf(page, PAGE_SIZE, "%u\n", (u32)(atomic_long_read(&deve->read_bytes) >> 20)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger9895.15%266.67%
Christoph Hellwig54.85%133.33%
Total103100.00%3100.00%


static ssize_t target_stat_auth_write_mbytes_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* scsiAuthIntrWrittenMegaBytes */ ret = snprintf(page, PAGE_SIZE, "%u\n", (u32)(atomic_long_read(&deve->write_bytes) >> 20)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger9895.15%266.67%
Christoph Hellwig54.85%133.33%
Total103100.00%3100.00%


static ssize_t target_stat_auth_hs_num_cmds_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* FIXME: scsiAuthIntrHSOutCommands */ ret = snprintf(page, PAGE_SIZE, "%u\n", 0); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger8594.44%266.67%
Christoph Hellwig55.56%133.33%
Total90100.00%3100.00%


static ssize_t target_stat_auth_creation_time_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* scsiAuthIntrLastCreation */ ret = snprintf(page, PAGE_SIZE, "%u\n", (u32)(((u32)deve->creation_time - INITIAL_JIFFIES) * 100 / HZ)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger10395.37%266.67%
Christoph Hellwig54.63%133.33%
Total108100.00%3100.00%


static ssize_t target_stat_auth_row_status_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = auth_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* FIXME: scsiAuthIntrRowStatus */ ret = snprintf(page, PAGE_SIZE, "Ready\n"); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger6978.41%266.67%
Christoph Hellwig1921.59%133.33%
Total88100.00%3100.00%

CONFIGFS_ATTR_RO(target_stat_auth_, inst); CONFIGFS_ATTR_RO(target_stat_auth_, dev); CONFIGFS_ATTR_RO(target_stat_auth_, port); CONFIGFS_ATTR_RO(target_stat_auth_, indx); CONFIGFS_ATTR_RO(target_stat_auth_, dev_or_port); CONFIGFS_ATTR_RO(target_stat_auth_, intr_name); CONFIGFS_ATTR_RO(target_stat_auth_, map_indx); CONFIGFS_ATTR_RO(target_stat_auth_, att_count); CONFIGFS_ATTR_RO(target_stat_auth_, num_cmds); CONFIGFS_ATTR_RO(target_stat_auth_, read_mbytes); CONFIGFS_ATTR_RO(target_stat_auth_, write_mbytes); CONFIGFS_ATTR_RO(target_stat_auth_, hs_num_cmds); CONFIGFS_ATTR_RO(target_stat_auth_, creation_time); CONFIGFS_ATTR_RO(target_stat_auth_, row_status); static struct configfs_attribute *target_stat_scsi_auth_intr_attrs[] = { &target_stat_auth_attr_inst, &target_stat_auth_attr_dev, &target_stat_auth_attr_port, &target_stat_auth_attr_indx, &target_stat_auth_attr_dev_or_port, &target_stat_auth_attr_intr_name, &target_stat_auth_attr_map_indx, &target_stat_auth_attr_att_count, &target_stat_auth_attr_num_cmds, &target_stat_auth_attr_read_mbytes, &target_stat_auth_attr_write_mbytes, &target_stat_auth_attr_hs_num_cmds, &target_stat_auth_attr_creation_time, &target_stat_auth_attr_row_status, NULL, }; static struct config_item_type target_stat_scsi_auth_intr_cit = { .ct_attrs = target_stat_scsi_auth_intr_attrs, .ct_owner = THIS_MODULE, }; /* * SCSI Attached Initiator Port Table */
static struct se_lun_acl *iport_to_lacl(struct config_item *item) { struct se_ml_stat_grps *lgrps = container_of(to_config_group(item), struct se_ml_stat_grps, scsi_att_intr_port_group); return container_of(lgrps, struct se_lun_acl, ml_stat_grps); }

Contributors

PersonTokensPropCommitsCommitProp
Christoph Hellwig3890.48%150.00%
Nicholas Bellinger49.52%150.00%
Total42100.00%2100.00%


static ssize_t target_stat_iport_inst_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = iport_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; struct se_portal_group *tpg; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } tpg = nacl->se_tpg; /* scsiInstIndex */ ret = snprintf(page, PAGE_SIZE, "%u\n", tpg->se_tpg_tfo->tpg_get_inst_index(tpg)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger10193.52%250.00%
Christoph Hellwig54.63%125.00%
Andy Grover21.85%125.00%
Total108100.00%4100.00%


static ssize_t target_stat_iport_dev_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = iport_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; struct se_lun *lun; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } lun = rcu_dereference(deve->se_lun); /* scsiDeviceIndex */ ret = snprintf(page, PAGE_SIZE, "%u\n", lun->lun_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger10195.28%266.67%
Christoph Hellwig54.72%133.33%
Total106100.00%3100.00%


static ssize_t target_stat_iport_port_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = iport_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; struct se_portal_group *tpg; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } tpg = nacl->se_tpg; /* scsiPortIndex */ ret = snprintf(page, PAGE_SIZE, "%u\n", tpg->se_tpg_tfo->tpg_get_tag(tpg)); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger10193.52%250.00%
Christoph Hellwig54.63%125.00%
Andy Grover21.85%125.00%
Total108100.00%4100.00%


static ssize_t target_stat_iport_indx_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = iport_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_session *se_sess; struct se_portal_group *tpg; ssize_t ret; spin_lock_irq(&nacl->nacl_sess_lock); se_sess = nacl->nacl_sess; if (!se_sess) { spin_unlock_irq(&nacl->nacl_sess_lock); return -ENODEV; } tpg = nacl->se_tpg; /* scsiAttIntrPortIndex */ ret = snprintf(page, PAGE_SIZE, "%u\n", tpg->se_tpg_tfo->sess_get_index(se_sess)); spin_unlock_irq(&nacl->nacl_sess_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger11194.07%133.33%
Christoph Hellwig54.24%133.33%
Andy Grover21.69%133.33%
Total118100.00%3100.00%


static ssize_t target_stat_iport_port_auth_indx_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = iport_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_dev_entry *deve; ssize_t ret; rcu_read_lock(); deve = target_nacl_find_deve(nacl, lacl->mapped_lun); if (!deve) { rcu_read_unlock(); return -ENODEV; } /* scsiAttIntrPortAuthIntrIdx */ ret = snprintf(page, PAGE_SIZE, "%u\n", nacl->acl_index); rcu_read_unlock(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger8794.57%266.67%
Christoph Hellwig55.43%133.33%
Total92100.00%3100.00%


static ssize_t target_stat_iport_port_ident_show(struct config_item *item, char *page) { struct se_lun_acl *lacl = iport_to_lacl(item); struct se_node_acl *nacl = lacl->se_lun_nacl; struct se_session *se_sess; struct se_portal_group *tpg; ssize_t ret; unsigned char buf[64]; spin_lock_irq(&nacl->nacl_sess_lock); se_sess = nacl->nacl_sess; if (!se_sess) { spin_unlock_irq(&nacl->nacl_sess_lock); return -ENODEV; } tpg = nacl->se_tpg; /* scsiAttIntrPortName+scsiAttIntrPortIdentifier */ memset(buf, 0, 64); if (tpg->se_tpg_tfo->sess_get_initiator_sid != NULL) tpg->se_tpg_tfo->sess_get_initiator_sid(se_sess, buf, 64); ret = snprintf(page, PAGE_SIZE, "%s+i+%s\n", nacl->initiatorname, buf); spin_unlock_irq(&nacl->nacl_sess_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger14594.16%133.33%
Christoph Hellwig53.25%133.33%
Andy Grover42.60%133.33%
Total154100.00%3100.00%

CONFIGFS_ATTR_RO(target_stat_iport_, inst); CONFIGFS_ATTR_RO(target_stat_iport_, dev); CONFIGFS_ATTR_RO(target_stat_iport_, port); CONFIGFS_ATTR_RO(target_stat_iport_, indx); CONFIGFS_ATTR_RO(target_stat_iport_, port_auth_indx); CONFIGFS_ATTR_RO(target_stat_iport_, port_ident); static struct configfs_attribute *target_stat_scsi_ath_intr_port_attrs[] = { &target_stat_iport_attr_inst, &target_stat_iport_attr_dev, &target_stat_iport_attr_port, &target_stat_iport_attr_indx, &target_stat_iport_attr_port_auth_indx, &target_stat_iport_attr_port_ident, NULL, }; static struct config_item_type target_stat_scsi_att_intr_port_cit = { .ct_attrs = target_stat_scsi_ath_intr_port_attrs, .ct_owner = THIS_MODULE, }; /* * Called from target_core_fabric_configfs.c:target_fabric_make_mappedlun() to setup * the target MappedLUN statistics groups + configfs CITs located in target_core_stat.c */
void target_stat_setup_mappedlun_default_groups(struct se_lun_acl *lacl) { config_group_init_type_name(&lacl->ml_stat_grps.scsi_auth_intr_group, "scsi_auth_intr", &target_stat_scsi_auth_intr_cit); configfs_add_default_group(&lacl->ml_stat_grps.scsi_auth_intr_group, &lacl->ml_stat_grps.stat_group); config_group_init_type_name(&lacl->ml_stat_grps.scsi_att_intr_port_group, "scsi_att_intr_port", &target_stat_scsi_att_intr_port_cit); configfs_add_default_group(&lacl->ml_stat_grps.scsi_att_intr_port_group, &lacl->ml_stat_grps.stat_group); }

Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger4256.76%133.33%
Christoph Hellwig2229.73%133.33%
Andy Grover1013.51%133.33%
Total74100.00%3100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Nicholas Bellinger488274.24%640.00%
Christoph Hellwig143821.87%640.00%
Andy Grover1632.48%16.67%
Michael Christie921.40%16.67%
David Disseldorp10.02%16.67%
Total6576100.00%15100.00%
Directory: drivers/target
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.