mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 14:50:19 +00:00
c942fddf87
Based on 3 normalized pattern(s): 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 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 [author] [kishon] [vijay] [abraham] [i] [kishon]@[ti] [com] 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 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 [author] [graeme] [gregory] [gg]@[slimlogic] [co] [uk] [author] [kishon] [vijay] [abraham] [i] [kishon]@[ti] [com] [based] [on] [twl6030]_[usb] [c] [author] [hema] [hk] [hemahk]@[ti] [com] 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 extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 1105 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Reviewed-by: Richard Fontana <rfontana@redhat.com> Reviewed-by: Kate Stewart <kstewart@linuxfoundation.org> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190527070033.202006027@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
58 lines
1.7 KiB
C
58 lines
1.7 KiB
C
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
/*******************************************************************************
|
|
* This file contains the iSCSI Virtual Device and Disk Transport
|
|
* agnostic related functions.
|
|
*
|
|
* (c) Copyright 2007-2013 Datera, Inc.
|
|
*
|
|
* Author: Nicholas A. Bellinger <nab@linux-iscsi.org>
|
|
*
|
|
******************************************************************************/
|
|
|
|
#include <target/target_core_base.h>
|
|
#include <target/target_core_fabric.h>
|
|
|
|
#include <target/iscsi/iscsi_target_core.h>
|
|
#include "iscsi_target_device.h"
|
|
#include "iscsi_target_tpg.h"
|
|
#include "iscsi_target_util.h"
|
|
|
|
void iscsit_determine_maxcmdsn(struct iscsi_session *sess)
|
|
{
|
|
struct se_node_acl *se_nacl;
|
|
|
|
/*
|
|
* This is a discovery session, the single queue slot was already
|
|
* assigned in iscsi_login_zero_tsih(). Since only Logout and
|
|
* Text Opcodes are allowed during discovery we do not have to worry
|
|
* about the HBA's queue depth here.
|
|
*/
|
|
if (sess->sess_ops->SessionType)
|
|
return;
|
|
|
|
se_nacl = sess->se_sess->se_node_acl;
|
|
|
|
/*
|
|
* This is a normal session, set the Session's CmdSN window to the
|
|
* struct se_node_acl->queue_depth. The value in struct se_node_acl->queue_depth
|
|
* has already been validated as a legal value in
|
|
* core_set_queue_depth_for_node().
|
|
*/
|
|
sess->cmdsn_window = se_nacl->queue_depth;
|
|
atomic_add(se_nacl->queue_depth - 1, &sess->max_cmd_sn);
|
|
}
|
|
|
|
void iscsit_increment_maxcmdsn(struct iscsi_cmd *cmd, struct iscsi_session *sess)
|
|
{
|
|
u32 max_cmd_sn;
|
|
|
|
if (cmd->immediate_cmd || cmd->maxcmdsn_inc)
|
|
return;
|
|
|
|
cmd->maxcmdsn_inc = 1;
|
|
|
|
max_cmd_sn = atomic_inc_return(&sess->max_cmd_sn);
|
|
pr_debug("Updated MaxCmdSN to 0x%08x\n", max_cmd_sn);
|
|
}
|
|
EXPORT_SYMBOL(iscsit_increment_maxcmdsn);
|