SCSI misc on 20190315
This is the final round of mostly small fixes and performance improvements to our initial submit. The main regression fix is the ia64 simscsi build failure which was missed in the serial number elimination conversion. Signed-off-by: James E.J. Bottomley <jejb@linux.ibm.com> -----BEGIN PGP SIGNATURE----- iJwEABMIAEQWIQTnYEDbdso9F2cI+arnQslM7pishQUCXIxBayYcamFtZXMuYm90 dG9tbGV5QGhhbnNlbnBhcnRuZXJzaGlwLmNvbQAKCRDnQslM7pisherpAP4rxLpX bcUnQnEsvoxys/JyoK08Qfv1JebZo1B2MAZ62wD/VZ7LpOuzVLhsM2KhLFGRrs1/ 7D2K4tgtO2dQsFix7H0= =pcHl -----END PGP SIGNATURE----- Merge tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi Pull more SCSI updates from James Bottomley: "This is the final round of mostly small fixes and performance improvements to our initial submit. The main regression fix is the ia64 simscsi build failure which was missed in the serial number elimination conversion" * tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi: (24 commits) scsi: ia64: simscsi: use request tag instead of serial_number scsi: aacraid: Fix performance issue on logical drives scsi: lpfc: Fix error codes in lpfc_sli4_pci_mem_setup() scsi: libiscsi: Hold back_lock when calling iscsi_complete_task scsi: hisi_sas: Change SERDES_CFG init value to increase reliability of HiLink scsi: hisi_sas: Send HARD RESET to clear the previous affiliation of STP target port scsi: hisi_sas: Set PHY linkrate when disconnected scsi: hisi_sas: print PHY RX errors count for later revision of v3 hw scsi: hisi_sas: Fix a timeout race of driver internal and SMP IO scsi: hisi_sas: Change return variable type in phy_up_v3_hw() scsi: qla2xxx: check for kstrtol() failure scsi: lpfc: fix 32-bit format string warning scsi: lpfc: fix unused variable warning scsi: target: tcmu: Switch to bitmap_zalloc() scsi: libiscsi: fall back to sendmsg for slab pages scsi: qla2xxx: avoid printf format warning scsi: lpfc: resolve static checker warning in lpfc_sli4_hba_unset scsi: lpfc: Correct __lpfc_sli_issue_iocb_s4 lockdep check scsi: ufs: hisi: fix ufs_hba_variant_ops passing scsi: qla2xxx: Fix panic in qla_dfs_tgt_counters_show ...
This commit is contained in:
commit
477558d7e8
@ -105,7 +105,8 @@ simscsi_interrupt (unsigned long val)
|
|||||||
atomic_dec(&num_reqs);
|
atomic_dec(&num_reqs);
|
||||||
queue[rd].sc = NULL;
|
queue[rd].sc = NULL;
|
||||||
if (DBG)
|
if (DBG)
|
||||||
printk("simscsi_interrupt: done with %ld\n", sc->serial_number);
|
printk("simscsi_interrupt: done with %u\n",
|
||||||
|
sc->request->tag);
|
||||||
(*sc->scsi_done)(sc);
|
(*sc->scsi_done)(sc);
|
||||||
rd = (rd + 1) % SIMSCSI_REQ_QUEUE_LEN;
|
rd = (rd + 1) % SIMSCSI_REQ_QUEUE_LEN;
|
||||||
}
|
}
|
||||||
@ -214,8 +215,8 @@ simscsi_queuecommand_lck (struct scsi_cmnd *sc, void (*done)(struct scsi_cmnd *)
|
|||||||
register long sp asm ("sp");
|
register long sp asm ("sp");
|
||||||
|
|
||||||
if (DBG)
|
if (DBG)
|
||||||
printk("simscsi_queuecommand: target=%d,cmnd=%u,sc=%lu,sp=%lx,done=%p\n",
|
printk("simscsi_queuecommand: target=%d,cmnd=%u,sc=%u,sp=%lx,done=%p\n",
|
||||||
target_id, sc->cmnd[0], sc->serial_number, sp, done);
|
target_id, sc->cmnd[0], sc->request->tag, sp, done);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
sc->result = DID_BAD_TARGET << 16;
|
sc->result = DID_BAD_TARGET << 16;
|
||||||
|
@ -413,13 +413,16 @@ static int aac_slave_configure(struct scsi_device *sdev)
|
|||||||
if (chn < AAC_MAX_BUSES && tid < AAC_MAX_TARGETS && aac->sa_firmware) {
|
if (chn < AAC_MAX_BUSES && tid < AAC_MAX_TARGETS && aac->sa_firmware) {
|
||||||
devtype = aac->hba_map[chn][tid].devtype;
|
devtype = aac->hba_map[chn][tid].devtype;
|
||||||
|
|
||||||
if (devtype == AAC_DEVTYPE_NATIVE_RAW)
|
if (devtype == AAC_DEVTYPE_NATIVE_RAW) {
|
||||||
depth = aac->hba_map[chn][tid].qd_limit;
|
depth = aac->hba_map[chn][tid].qd_limit;
|
||||||
else if (devtype == AAC_DEVTYPE_ARC_RAW)
|
set_timeout = 1;
|
||||||
|
goto common_config;
|
||||||
|
}
|
||||||
|
if (devtype == AAC_DEVTYPE_ARC_RAW) {
|
||||||
set_qd_dev_type = true;
|
set_qd_dev_type = true;
|
||||||
|
set_timeout = 1;
|
||||||
set_timeout = 1;
|
goto common_config;
|
||||||
goto common_config;
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (aac->jbod && (sdev->type == TYPE_DISK))
|
if (aac->jbod && (sdev->type == TYPE_DISK))
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
#include <linux/dmapool.h>
|
#include <linux/dmapool.h>
|
||||||
#include <linux/iopoll.h>
|
#include <linux/iopoll.h>
|
||||||
#include <linux/lcm.h>
|
#include <linux/lcm.h>
|
||||||
|
#include <linux/libata.h>
|
||||||
#include <linux/mfd/syscon.h>
|
#include <linux/mfd/syscon.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/of_address.h>
|
#include <linux/of_address.h>
|
||||||
@ -94,6 +95,11 @@ enum {
|
|||||||
PORT_TYPE_SATA = (1U << 0),
|
PORT_TYPE_SATA = (1U << 0),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum dev_status {
|
||||||
|
HISI_SAS_DEV_INIT,
|
||||||
|
HISI_SAS_DEV_NORMAL,
|
||||||
|
};
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
HISI_SAS_INT_ABT_CMD = 0,
|
HISI_SAS_INT_ABT_CMD = 0,
|
||||||
HISI_SAS_INT_ABT_DEV = 1,
|
HISI_SAS_INT_ABT_DEV = 1,
|
||||||
@ -161,6 +167,7 @@ struct hisi_sas_phy {
|
|||||||
u8 in_reset;
|
u8 in_reset;
|
||||||
u8 reserved[2];
|
u8 reserved[2];
|
||||||
u32 phy_type;
|
u32 phy_type;
|
||||||
|
u32 code_violation_err_count;
|
||||||
enum sas_linkrate minimum_linkrate;
|
enum sas_linkrate minimum_linkrate;
|
||||||
enum sas_linkrate maximum_linkrate;
|
enum sas_linkrate maximum_linkrate;
|
||||||
};
|
};
|
||||||
@ -194,6 +201,7 @@ struct hisi_sas_device {
|
|||||||
struct hisi_sas_dq *dq;
|
struct hisi_sas_dq *dq;
|
||||||
struct list_head list;
|
struct list_head list;
|
||||||
enum sas_device_type dev_type;
|
enum sas_device_type dev_type;
|
||||||
|
enum dev_status dev_status;
|
||||||
int device_id;
|
int device_id;
|
||||||
int sata_idx;
|
int sata_idx;
|
||||||
spinlock_t lock; /* For protecting slots */
|
spinlock_t lock; /* For protecting slots */
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "hisi_sas.h"
|
#include "hisi_sas.h"
|
||||||
|
#include "../libsas/sas_internal.h"
|
||||||
#define DRV_NAME "hisi_sas"
|
#define DRV_NAME "hisi_sas"
|
||||||
|
|
||||||
#define DEV_IS_GONE(dev) \
|
#define DEV_IS_GONE(dev) \
|
||||||
@ -707,6 +708,7 @@ static struct hisi_sas_device *hisi_sas_alloc_dev(struct domain_device *device)
|
|||||||
|
|
||||||
hisi_hba->devices[i].device_id = i;
|
hisi_hba->devices[i].device_id = i;
|
||||||
sas_dev = &hisi_hba->devices[i];
|
sas_dev = &hisi_hba->devices[i];
|
||||||
|
sas_dev->dev_status = HISI_SAS_DEV_INIT;
|
||||||
sas_dev->dev_type = device->dev_type;
|
sas_dev->dev_type = device->dev_type;
|
||||||
sas_dev->hisi_hba = hisi_hba;
|
sas_dev->hisi_hba = hisi_hba;
|
||||||
sas_dev->sas_device = device;
|
sas_dev->sas_device = device;
|
||||||
@ -731,6 +733,8 @@ static int hisi_sas_init_device(struct domain_device *device)
|
|||||||
struct hisi_sas_tmf_task tmf_task;
|
struct hisi_sas_tmf_task tmf_task;
|
||||||
int retry = HISI_SAS_SRST_ATA_DISK_CNT;
|
int retry = HISI_SAS_SRST_ATA_DISK_CNT;
|
||||||
struct hisi_hba *hisi_hba = dev_to_hisi_hba(device);
|
struct hisi_hba *hisi_hba = dev_to_hisi_hba(device);
|
||||||
|
struct device *dev = hisi_hba->dev;
|
||||||
|
struct sas_phy *local_phy;
|
||||||
|
|
||||||
switch (device->dev_type) {
|
switch (device->dev_type) {
|
||||||
case SAS_END_DEVICE:
|
case SAS_END_DEVICE:
|
||||||
@ -746,6 +750,31 @@ static int hisi_sas_init_device(struct domain_device *device)
|
|||||||
case SAS_SATA_PM:
|
case SAS_SATA_PM:
|
||||||
case SAS_SATA_PM_PORT:
|
case SAS_SATA_PM_PORT:
|
||||||
case SAS_SATA_PENDING:
|
case SAS_SATA_PENDING:
|
||||||
|
/*
|
||||||
|
* send HARD RESET to clear previous affiliation of
|
||||||
|
* STP target port
|
||||||
|
*/
|
||||||
|
local_phy = sas_get_local_phy(device);
|
||||||
|
if (!scsi_is_sas_phy_local(local_phy)) {
|
||||||
|
unsigned long deadline = ata_deadline(jiffies, 20000);
|
||||||
|
struct sata_device *sata_dev = &device->sata_dev;
|
||||||
|
struct ata_host *ata_host = sata_dev->ata_host;
|
||||||
|
struct ata_port_operations *ops = ata_host->ops;
|
||||||
|
struct ata_port *ap = sata_dev->ap;
|
||||||
|
struct ata_link *link;
|
||||||
|
unsigned int classes;
|
||||||
|
|
||||||
|
ata_for_each_link(link, ap, EDGE)
|
||||||
|
rc = ops->hardreset(link, &classes,
|
||||||
|
deadline);
|
||||||
|
}
|
||||||
|
sas_put_local_phy(local_phy);
|
||||||
|
if (rc) {
|
||||||
|
dev_warn(dev, "SATA disk hardreset fail: 0x%x\n",
|
||||||
|
rc);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
while (retry-- > 0) {
|
while (retry-- > 0) {
|
||||||
rc = hisi_sas_softreset_ata_disk(device);
|
rc = hisi_sas_softreset_ata_disk(device);
|
||||||
if (!rc)
|
if (!rc)
|
||||||
@ -808,6 +837,7 @@ static int hisi_sas_dev_found(struct domain_device *device)
|
|||||||
rc = hisi_sas_init_device(device);
|
rc = hisi_sas_init_device(device);
|
||||||
if (rc)
|
if (rc)
|
||||||
goto err_out;
|
goto err_out;
|
||||||
|
sas_dev->dev_status = HISI_SAS_DEV_NORMAL;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err_out:
|
err_out:
|
||||||
@ -980,7 +1010,8 @@ static void hisi_sas_do_release_task(struct hisi_hba *hisi_hba, struct sas_task
|
|||||||
spin_lock_irqsave(&task->task_state_lock, flags);
|
spin_lock_irqsave(&task->task_state_lock, flags);
|
||||||
task->task_state_flags &=
|
task->task_state_flags &=
|
||||||
~(SAS_TASK_STATE_PENDING | SAS_TASK_AT_INITIATOR);
|
~(SAS_TASK_STATE_PENDING | SAS_TASK_AT_INITIATOR);
|
||||||
task->task_state_flags |= SAS_TASK_STATE_DONE;
|
if (!slot->is_internal && task->task_proto != SAS_PROTOCOL_SMP)
|
||||||
|
task->task_state_flags |= SAS_TASK_STATE_DONE;
|
||||||
spin_unlock_irqrestore(&task->task_state_lock, flags);
|
spin_unlock_irqrestore(&task->task_state_lock, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1713,20 +1744,23 @@ static int hisi_sas_clear_aca(struct domain_device *device, u8 *lun)
|
|||||||
static int hisi_sas_debug_I_T_nexus_reset(struct domain_device *device)
|
static int hisi_sas_debug_I_T_nexus_reset(struct domain_device *device)
|
||||||
{
|
{
|
||||||
struct sas_phy *local_phy = sas_get_local_phy(device);
|
struct sas_phy *local_phy = sas_get_local_phy(device);
|
||||||
int rc, reset_type = (device->dev_type == SAS_SATA_DEV ||
|
struct hisi_sas_device *sas_dev = device->lldd_dev;
|
||||||
(device->tproto & SAS_PROTOCOL_STP)) ? 0 : 1;
|
|
||||||
struct hisi_hba *hisi_hba = dev_to_hisi_hba(device);
|
struct hisi_hba *hisi_hba = dev_to_hisi_hba(device);
|
||||||
struct sas_ha_struct *sas_ha = &hisi_hba->sha;
|
struct sas_ha_struct *sas_ha = &hisi_hba->sha;
|
||||||
struct asd_sas_phy *sas_phy = sas_ha->sas_phy[local_phy->number];
|
struct asd_sas_phy *sas_phy = sas_ha->sas_phy[local_phy->number];
|
||||||
struct hisi_sas_phy *phy = container_of(sas_phy,
|
struct hisi_sas_phy *phy = container_of(sas_phy,
|
||||||
struct hisi_sas_phy, sas_phy);
|
struct hisi_sas_phy, sas_phy);
|
||||||
DECLARE_COMPLETION_ONSTACK(phyreset);
|
DECLARE_COMPLETION_ONSTACK(phyreset);
|
||||||
|
int rc, reset_type;
|
||||||
|
|
||||||
if (scsi_is_sas_phy_local(local_phy)) {
|
if (scsi_is_sas_phy_local(local_phy)) {
|
||||||
phy->in_reset = 1;
|
phy->in_reset = 1;
|
||||||
phy->reset_completion = &phyreset;
|
phy->reset_completion = &phyreset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
reset_type = (sas_dev->dev_status == HISI_SAS_DEV_INIT ||
|
||||||
|
!dev_is_sata(device)) ? 1 : 0;
|
||||||
|
|
||||||
rc = sas_phy_reset(local_phy, reset_type);
|
rc = sas_phy_reset(local_phy, reset_type);
|
||||||
sas_put_local_phy(local_phy);
|
sas_put_local_phy(local_phy);
|
||||||
|
|
||||||
@ -1742,8 +1776,13 @@ static int hisi_sas_debug_I_T_nexus_reset(struct domain_device *device)
|
|||||||
/* report PHY down if timed out */
|
/* report PHY down if timed out */
|
||||||
if (!ret)
|
if (!ret)
|
||||||
hisi_sas_phy_down(hisi_hba, sas_phy->id, 0);
|
hisi_sas_phy_down(hisi_hba, sas_phy->id, 0);
|
||||||
} else
|
} else if (sas_dev->dev_status != HISI_SAS_DEV_INIT) {
|
||||||
|
/*
|
||||||
|
* If in init state, we rely on caller to wait for link to be
|
||||||
|
* ready; otherwise, delay.
|
||||||
|
*/
|
||||||
msleep(2000);
|
msleep(2000);
|
||||||
|
}
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
@ -2125,9 +2164,18 @@ static int hisi_sas_write_gpio(struct sas_ha_struct *sha, u8 reg_type,
|
|||||||
|
|
||||||
static void hisi_sas_phy_disconnected(struct hisi_sas_phy *phy)
|
static void hisi_sas_phy_disconnected(struct hisi_sas_phy *phy)
|
||||||
{
|
{
|
||||||
|
struct asd_sas_phy *sas_phy = &phy->sas_phy;
|
||||||
|
struct sas_phy *sphy = sas_phy->phy;
|
||||||
|
struct sas_phy_data *d = sphy->hostdata;
|
||||||
|
|
||||||
phy->phy_attached = 0;
|
phy->phy_attached = 0;
|
||||||
phy->phy_type = 0;
|
phy->phy_type = 0;
|
||||||
phy->port = NULL;
|
phy->port = NULL;
|
||||||
|
|
||||||
|
if (d->enable)
|
||||||
|
sphy->negotiated_linkrate = SAS_LINK_RATE_UNKNOWN;
|
||||||
|
else
|
||||||
|
sphy->negotiated_linkrate = SAS_PHY_DISABLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
void hisi_sas_phy_down(struct hisi_hba *hisi_hba, int phy_no, int rdy)
|
void hisi_sas_phy_down(struct hisi_hba *hisi_hba, int phy_no, int rdy)
|
||||||
@ -2253,6 +2301,7 @@ int hisi_sas_alloc(struct hisi_hba *hisi_hba)
|
|||||||
for (i = 0; i < HISI_SAS_MAX_DEVICES; i++) {
|
for (i = 0; i < HISI_SAS_MAX_DEVICES; i++) {
|
||||||
hisi_hba->devices[i].dev_type = SAS_PHY_UNUSED;
|
hisi_hba->devices[i].dev_type = SAS_PHY_UNUSED;
|
||||||
hisi_hba->devices[i].device_id = i;
|
hisi_hba->devices[i].device_id = i;
|
||||||
|
hisi_hba->devices[i].dev_status = HISI_SAS_DEV_INIT;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < hisi_hba->queue_count; i++) {
|
for (i = 0; i < hisi_hba->queue_count; i++) {
|
||||||
|
@ -868,6 +868,7 @@ hisi_sas_device *alloc_dev_quirk_v2_hw(struct domain_device *device)
|
|||||||
|
|
||||||
hisi_hba->devices[i].device_id = i;
|
hisi_hba->devices[i].device_id = i;
|
||||||
sas_dev = &hisi_hba->devices[i];
|
sas_dev = &hisi_hba->devices[i];
|
||||||
|
sas_dev->dev_status = HISI_SAS_DEV_INIT;
|
||||||
sas_dev->dev_type = device->dev_type;
|
sas_dev->dev_type = device->dev_type;
|
||||||
sas_dev->hisi_hba = hisi_hba;
|
sas_dev->hisi_hba = hisi_hba;
|
||||||
sas_dev->sas_device = device;
|
sas_dev->sas_device = device;
|
||||||
|
@ -129,6 +129,7 @@
|
|||||||
#define PHY_CTRL_RESET_MSK (0x1 << PHY_CTRL_RESET_OFF)
|
#define PHY_CTRL_RESET_MSK (0x1 << PHY_CTRL_RESET_OFF)
|
||||||
#define CMD_HDR_PIR_OFF 8
|
#define CMD_HDR_PIR_OFF 8
|
||||||
#define CMD_HDR_PIR_MSK (0x1 << CMD_HDR_PIR_OFF)
|
#define CMD_HDR_PIR_MSK (0x1 << CMD_HDR_PIR_OFF)
|
||||||
|
#define SERDES_CFG (PORT_BASE + 0x1c)
|
||||||
#define SL_CFG (PORT_BASE + 0x84)
|
#define SL_CFG (PORT_BASE + 0x84)
|
||||||
#define AIP_LIMIT (PORT_BASE + 0x90)
|
#define AIP_LIMIT (PORT_BASE + 0x90)
|
||||||
#define SL_CONTROL (PORT_BASE + 0x94)
|
#define SL_CONTROL (PORT_BASE + 0x94)
|
||||||
@ -181,6 +182,8 @@
|
|||||||
#define CHL_INT1_DMAC_RX_AXI_RD_ERR_OFF 22
|
#define CHL_INT1_DMAC_RX_AXI_RD_ERR_OFF 22
|
||||||
#define CHL_INT2 (PORT_BASE + 0x1bc)
|
#define CHL_INT2 (PORT_BASE + 0x1bc)
|
||||||
#define CHL_INT2_SL_IDAF_TOUT_CONF_OFF 0
|
#define CHL_INT2_SL_IDAF_TOUT_CONF_OFF 0
|
||||||
|
#define CHL_INT2_RX_DISP_ERR_OFF 28
|
||||||
|
#define CHL_INT2_RX_CODE_ERR_OFF 29
|
||||||
#define CHL_INT2_RX_INVLD_DW_OFF 30
|
#define CHL_INT2_RX_INVLD_DW_OFF 30
|
||||||
#define CHL_INT2_STP_LINK_TIMEOUT_OFF 31
|
#define CHL_INT2_STP_LINK_TIMEOUT_OFF 31
|
||||||
#define CHL_INT0_MSK (PORT_BASE + 0x1c0)
|
#define CHL_INT0_MSK (PORT_BASE + 0x1c0)
|
||||||
@ -523,6 +526,7 @@ static void init_reg_v3_hw(struct hisi_hba *hisi_hba)
|
|||||||
}
|
}
|
||||||
hisi_sas_phy_write32(hisi_hba, i, PROG_PHY_LINK_RATE,
|
hisi_sas_phy_write32(hisi_hba, i, PROG_PHY_LINK_RATE,
|
||||||
prog_phy_link_rate);
|
prog_phy_link_rate);
|
||||||
|
hisi_sas_phy_write32(hisi_hba, i, SERDES_CFG, 0xffc00);
|
||||||
hisi_sas_phy_write32(hisi_hba, i, SAS_RX_TRAIN_TIMER, 0x13e80);
|
hisi_sas_phy_write32(hisi_hba, i, SAS_RX_TRAIN_TIMER, 0x13e80);
|
||||||
hisi_sas_phy_write32(hisi_hba, i, CHL_INT0, 0xffffffff);
|
hisi_sas_phy_write32(hisi_hba, i, CHL_INT0, 0xffffffff);
|
||||||
hisi_sas_phy_write32(hisi_hba, i, CHL_INT1, 0xffffffff);
|
hisi_sas_phy_write32(hisi_hba, i, CHL_INT1, 0xffffffff);
|
||||||
@ -544,6 +548,8 @@ static void init_reg_v3_hw(struct hisi_hba *hisi_hba)
|
|||||||
hisi_sas_phy_write32(hisi_hba, i, STP_LINK_TIMER, 0x7f7a120);
|
hisi_sas_phy_write32(hisi_hba, i, STP_LINK_TIMER, 0x7f7a120);
|
||||||
hisi_sas_phy_write32(hisi_hba, i, CON_CFG_DRIVER, 0x2a0a01);
|
hisi_sas_phy_write32(hisi_hba, i, CON_CFG_DRIVER, 0x2a0a01);
|
||||||
hisi_sas_phy_write32(hisi_hba, i, SAS_SSP_CON_TIMER_CFG, 0x32);
|
hisi_sas_phy_write32(hisi_hba, i, SAS_SSP_CON_TIMER_CFG, 0x32);
|
||||||
|
hisi_sas_phy_write32(hisi_hba, i, SAS_EC_INT_COAL_TIME,
|
||||||
|
0x30f4240);
|
||||||
/* used for 12G negotiate */
|
/* used for 12G negotiate */
|
||||||
hisi_sas_phy_write32(hisi_hba, i, COARSETUNE_TIME, 0x1e);
|
hisi_sas_phy_write32(hisi_hba, i, COARSETUNE_TIME, 0x1e);
|
||||||
hisi_sas_phy_write32(hisi_hba, i, AIP_LIMIT, 0x2ffff);
|
hisi_sas_phy_write32(hisi_hba, i, AIP_LIMIT, 0x2ffff);
|
||||||
@ -1344,7 +1350,8 @@ static void prep_abort_v3_hw(struct hisi_hba *hisi_hba,
|
|||||||
|
|
||||||
static irqreturn_t phy_up_v3_hw(int phy_no, struct hisi_hba *hisi_hba)
|
static irqreturn_t phy_up_v3_hw(int phy_no, struct hisi_hba *hisi_hba)
|
||||||
{
|
{
|
||||||
int i, res;
|
int i;
|
||||||
|
irqreturn_t res;
|
||||||
u32 context, port_id, link_rate;
|
u32 context, port_id, link_rate;
|
||||||
struct hisi_sas_phy *phy = &hisi_hba->phy[phy_no];
|
struct hisi_sas_phy *phy = &hisi_hba->phy[phy_no];
|
||||||
struct asd_sas_phy *sas_phy = &phy->sas_phy;
|
struct asd_sas_phy *sas_phy = &phy->sas_phy;
|
||||||
@ -1575,6 +1582,39 @@ static void handle_chl_int1_v3_hw(struct hisi_hba *hisi_hba, int phy_no)
|
|||||||
hisi_sas_phy_write32(hisi_hba, phy_no, CHL_INT1, irq_value);
|
hisi_sas_phy_write32(hisi_hba, phy_no, CHL_INT1, irq_value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void phy_get_events_v3_hw(struct hisi_hba *hisi_hba, int phy_no)
|
||||||
|
{
|
||||||
|
struct hisi_sas_phy *phy = &hisi_hba->phy[phy_no];
|
||||||
|
struct asd_sas_phy *sas_phy = &phy->sas_phy;
|
||||||
|
struct sas_phy *sphy = sas_phy->phy;
|
||||||
|
unsigned long flags;
|
||||||
|
u32 reg_value;
|
||||||
|
|
||||||
|
spin_lock_irqsave(&phy->lock, flags);
|
||||||
|
|
||||||
|
/* loss dword sync */
|
||||||
|
reg_value = hisi_sas_phy_read32(hisi_hba, phy_no, ERR_CNT_DWS_LOST);
|
||||||
|
sphy->loss_of_dword_sync_count += reg_value;
|
||||||
|
|
||||||
|
/* phy reset problem */
|
||||||
|
reg_value = hisi_sas_phy_read32(hisi_hba, phy_no, ERR_CNT_RESET_PROB);
|
||||||
|
sphy->phy_reset_problem_count += reg_value;
|
||||||
|
|
||||||
|
/* invalid dword */
|
||||||
|
reg_value = hisi_sas_phy_read32(hisi_hba, phy_no, ERR_CNT_INVLD_DW);
|
||||||
|
sphy->invalid_dword_count += reg_value;
|
||||||
|
|
||||||
|
/* disparity err */
|
||||||
|
reg_value = hisi_sas_phy_read32(hisi_hba, phy_no, ERR_CNT_DISP_ERR);
|
||||||
|
sphy->running_disparity_error_count += reg_value;
|
||||||
|
|
||||||
|
/* code violation error */
|
||||||
|
reg_value = hisi_sas_phy_read32(hisi_hba, phy_no, ERR_CNT_CODE_ERR);
|
||||||
|
phy->code_violation_err_count += reg_value;
|
||||||
|
|
||||||
|
spin_unlock_irqrestore(&phy->lock, flags);
|
||||||
|
}
|
||||||
|
|
||||||
static void handle_chl_int2_v3_hw(struct hisi_hba *hisi_hba, int phy_no)
|
static void handle_chl_int2_v3_hw(struct hisi_hba *hisi_hba, int phy_no)
|
||||||
{
|
{
|
||||||
u32 irq_msk = hisi_sas_phy_read32(hisi_hba, phy_no, CHL_INT2_MSK);
|
u32 irq_msk = hisi_sas_phy_read32(hisi_hba, phy_no, CHL_INT2_MSK);
|
||||||
@ -1582,6 +1622,9 @@ static void handle_chl_int2_v3_hw(struct hisi_hba *hisi_hba, int phy_no)
|
|||||||
struct hisi_sas_phy *phy = &hisi_hba->phy[phy_no];
|
struct hisi_sas_phy *phy = &hisi_hba->phy[phy_no];
|
||||||
struct pci_dev *pci_dev = hisi_hba->pci_dev;
|
struct pci_dev *pci_dev = hisi_hba->pci_dev;
|
||||||
struct device *dev = hisi_hba->dev;
|
struct device *dev = hisi_hba->dev;
|
||||||
|
static const u32 msk = BIT(CHL_INT2_RX_DISP_ERR_OFF) |
|
||||||
|
BIT(CHL_INT2_RX_CODE_ERR_OFF) |
|
||||||
|
BIT(CHL_INT2_RX_INVLD_DW_OFF);
|
||||||
|
|
||||||
irq_value &= ~irq_msk;
|
irq_value &= ~irq_msk;
|
||||||
if (!irq_value)
|
if (!irq_value)
|
||||||
@ -1602,6 +1645,25 @@ static void handle_chl_int2_v3_hw(struct hisi_hba *hisi_hba, int phy_no)
|
|||||||
hisi_sas_notify_phy_event(phy, HISI_PHYE_LINK_RESET);
|
hisi_sas_notify_phy_event(phy, HISI_PHYE_LINK_RESET);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (pci_dev->revision > 0x20 && (irq_value & msk)) {
|
||||||
|
struct asd_sas_phy *sas_phy = &phy->sas_phy;
|
||||||
|
struct sas_phy *sphy = sas_phy->phy;
|
||||||
|
|
||||||
|
phy_get_events_v3_hw(hisi_hba, phy_no);
|
||||||
|
|
||||||
|
if (irq_value & BIT(CHL_INT2_RX_INVLD_DW_OFF))
|
||||||
|
dev_info(dev, "phy%d invalid dword cnt: %u\n", phy_no,
|
||||||
|
sphy->invalid_dword_count);
|
||||||
|
|
||||||
|
if (irq_value & BIT(CHL_INT2_RX_CODE_ERR_OFF))
|
||||||
|
dev_info(dev, "phy%d code violation cnt: %u\n", phy_no,
|
||||||
|
phy->code_violation_err_count);
|
||||||
|
|
||||||
|
if (irq_value & BIT(CHL_INT2_RX_DISP_ERR_OFF))
|
||||||
|
dev_info(dev, "phy%d disparity error cnt: %u\n", phy_no,
|
||||||
|
sphy->running_disparity_error_count);
|
||||||
|
}
|
||||||
|
|
||||||
if ((irq_value & BIT(CHL_INT2_RX_INVLD_DW_OFF)) &&
|
if ((irq_value & BIT(CHL_INT2_RX_INVLD_DW_OFF)) &&
|
||||||
(pci_dev->revision == 0x20)) {
|
(pci_dev->revision == 0x20)) {
|
||||||
u32 reg_value;
|
u32 reg_value;
|
||||||
@ -2230,31 +2292,6 @@ static u32 get_phys_state_v3_hw(struct hisi_hba *hisi_hba)
|
|||||||
return hisi_sas_read32(hisi_hba, PHY_STATE);
|
return hisi_sas_read32(hisi_hba, PHY_STATE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void phy_get_events_v3_hw(struct hisi_hba *hisi_hba, int phy_no)
|
|
||||||
{
|
|
||||||
struct hisi_sas_phy *phy = &hisi_hba->phy[phy_no];
|
|
||||||
struct asd_sas_phy *sas_phy = &phy->sas_phy;
|
|
||||||
struct sas_phy *sphy = sas_phy->phy;
|
|
||||||
u32 reg_value;
|
|
||||||
|
|
||||||
/* loss dword sync */
|
|
||||||
reg_value = hisi_sas_phy_read32(hisi_hba, phy_no, ERR_CNT_DWS_LOST);
|
|
||||||
sphy->loss_of_dword_sync_count += reg_value;
|
|
||||||
|
|
||||||
/* phy reset problem */
|
|
||||||
reg_value = hisi_sas_phy_read32(hisi_hba, phy_no, ERR_CNT_RESET_PROB);
|
|
||||||
sphy->phy_reset_problem_count += reg_value;
|
|
||||||
|
|
||||||
/* invalid dword */
|
|
||||||
reg_value = hisi_sas_phy_read32(hisi_hba, phy_no, ERR_CNT_INVLD_DW);
|
|
||||||
sphy->invalid_dword_count += reg_value;
|
|
||||||
|
|
||||||
/* disparity err */
|
|
||||||
reg_value = hisi_sas_phy_read32(hisi_hba, phy_no, ERR_CNT_DISP_ERR);
|
|
||||||
sphy->running_disparity_error_count += reg_value;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static int disable_host_v3_hw(struct hisi_hba *hisi_hba)
|
static int disable_host_v3_hw(struct hisi_hba *hisi_hba)
|
||||||
{
|
{
|
||||||
struct device *dev = hisi_hba->dev;
|
struct device *dev = hisi_hba->dev;
|
||||||
|
@ -798,7 +798,7 @@ EXPORT_SYMBOL_GPL(iscsi_conn_send_pdu);
|
|||||||
* @datalen: len of buffer
|
* @datalen: len of buffer
|
||||||
*
|
*
|
||||||
* iscsi_cmd_rsp sets up the scsi_cmnd fields based on the PDU and
|
* iscsi_cmd_rsp sets up the scsi_cmnd fields based on the PDU and
|
||||||
* then completes the command and task.
|
* then completes the command and task. called under back_lock
|
||||||
**/
|
**/
|
||||||
static void iscsi_scsi_cmd_rsp(struct iscsi_conn *conn, struct iscsi_hdr *hdr,
|
static void iscsi_scsi_cmd_rsp(struct iscsi_conn *conn, struct iscsi_hdr *hdr,
|
||||||
struct iscsi_task *task, char *data,
|
struct iscsi_task *task, char *data,
|
||||||
@ -894,6 +894,9 @@ out:
|
|||||||
* @conn: iscsi connection
|
* @conn: iscsi connection
|
||||||
* @hdr: iscsi pdu
|
* @hdr: iscsi pdu
|
||||||
* @task: scsi command task
|
* @task: scsi command task
|
||||||
|
*
|
||||||
|
* iscsi_data_in_rsp sets up the scsi_cmnd fields based on the data received
|
||||||
|
* then completes the command and task. called under back_lock
|
||||||
**/
|
**/
|
||||||
static void
|
static void
|
||||||
iscsi_data_in_rsp(struct iscsi_conn *conn, struct iscsi_hdr *hdr,
|
iscsi_data_in_rsp(struct iscsi_conn *conn, struct iscsi_hdr *hdr,
|
||||||
@ -978,6 +981,16 @@ static int iscsi_send_nopout(struct iscsi_conn *conn, struct iscsi_nopin *rhdr)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* iscsi_nop_out_rsp - SCSI NOP Response processing
|
||||||
|
* @task: scsi command task
|
||||||
|
* @nop: the nop structure
|
||||||
|
* @data: where to put the data
|
||||||
|
* @datalen: length of data
|
||||||
|
*
|
||||||
|
* iscsi_nop_out_rsp handles nop response from use or
|
||||||
|
* from user space. called under back_lock
|
||||||
|
**/
|
||||||
static int iscsi_nop_out_rsp(struct iscsi_task *task,
|
static int iscsi_nop_out_rsp(struct iscsi_task *task,
|
||||||
struct iscsi_nopin *nop, char *data, int datalen)
|
struct iscsi_nopin *nop, char *data, int datalen)
|
||||||
{
|
{
|
||||||
@ -1750,7 +1763,9 @@ int iscsi_queuecommand(struct Scsi_Host *host, struct scsi_cmnd *sc)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
prepd_reject:
|
prepd_reject:
|
||||||
|
spin_lock_bh(&session->back_lock);
|
||||||
iscsi_complete_task(task, ISCSI_TASK_REQUEUE_SCSIQ);
|
iscsi_complete_task(task, ISCSI_TASK_REQUEUE_SCSIQ);
|
||||||
|
spin_unlock_bh(&session->back_lock);
|
||||||
reject:
|
reject:
|
||||||
spin_unlock_bh(&session->frwd_lock);
|
spin_unlock_bh(&session->frwd_lock);
|
||||||
ISCSI_DBG_SESSION(session, "cmd 0x%x rejected (%d)\n",
|
ISCSI_DBG_SESSION(session, "cmd 0x%x rejected (%d)\n",
|
||||||
@ -1758,7 +1773,9 @@ reject:
|
|||||||
return SCSI_MLQUEUE_TARGET_BUSY;
|
return SCSI_MLQUEUE_TARGET_BUSY;
|
||||||
|
|
||||||
prepd_fault:
|
prepd_fault:
|
||||||
|
spin_lock_bh(&session->back_lock);
|
||||||
iscsi_complete_task(task, ISCSI_TASK_REQUEUE_SCSIQ);
|
iscsi_complete_task(task, ISCSI_TASK_REQUEUE_SCSIQ);
|
||||||
|
spin_unlock_bh(&session->back_lock);
|
||||||
fault:
|
fault:
|
||||||
spin_unlock_bh(&session->frwd_lock);
|
spin_unlock_bh(&session->frwd_lock);
|
||||||
ISCSI_DBG_SESSION(session, "iscsi: cmd 0x%x is not queued (%d)\n",
|
ISCSI_DBG_SESSION(session, "iscsi: cmd 0x%x is not queued (%d)\n",
|
||||||
@ -3075,8 +3092,9 @@ fail_mgmt_tasks(struct iscsi_session *session, struct iscsi_conn *conn)
|
|||||||
state = ISCSI_TASK_ABRT_SESS_RECOV;
|
state = ISCSI_TASK_ABRT_SESS_RECOV;
|
||||||
if (task->state == ISCSI_TASK_PENDING)
|
if (task->state == ISCSI_TASK_PENDING)
|
||||||
state = ISCSI_TASK_COMPLETED;
|
state = ISCSI_TASK_COMPLETED;
|
||||||
|
spin_lock_bh(&session->back_lock);
|
||||||
iscsi_complete_task(task, state);
|
iscsi_complete_task(task, state);
|
||||||
|
spin_unlock_bh(&session->back_lock);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -129,12 +129,17 @@ static void iscsi_tcp_segment_map(struct iscsi_segment *segment, int recv)
|
|||||||
BUG_ON(sg->length == 0);
|
BUG_ON(sg->length == 0);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
* We always map for the recv path.
|
||||||
|
*
|
||||||
* If the page count is greater than one it is ok to send
|
* If the page count is greater than one it is ok to send
|
||||||
* to the network layer's zero copy send path. If not we
|
* to the network layer's zero copy send path. If not we
|
||||||
* have to go the slow sendmsg path. We always map for the
|
* have to go the slow sendmsg path.
|
||||||
* recv path.
|
*
|
||||||
|
* Same goes for slab pages: skb_can_coalesce() allows
|
||||||
|
* coalescing neighboring slab objects into a single frag which
|
||||||
|
* triggers one of hardened usercopy checks.
|
||||||
*/
|
*/
|
||||||
if (page_count(sg_page(sg)) >= 1 && !recv)
|
if (!recv && page_count(sg_page(sg)) >= 1 && !PageSlab(sg_page(sg)))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (recv) {
|
if (recv) {
|
||||||
|
@ -4090,7 +4090,7 @@ lpfc_new_io_buf(struct lpfc_hba *phba, int num_to_alloc)
|
|||||||
/* Sanity check to ensure our sizing is right for both SCSI and NVME */
|
/* Sanity check to ensure our sizing is right for both SCSI and NVME */
|
||||||
if (sizeof(struct lpfc_io_buf) > LPFC_COMMON_IO_BUF_SZ) {
|
if (sizeof(struct lpfc_io_buf) > LPFC_COMMON_IO_BUF_SZ) {
|
||||||
lpfc_printf_log(phba, KERN_ERR, LOG_FCP,
|
lpfc_printf_log(phba, KERN_ERR, LOG_FCP,
|
||||||
"6426 Common buffer size %ld exceeds %d\n",
|
"6426 Common buffer size %zd exceeds %d\n",
|
||||||
sizeof(struct lpfc_io_buf),
|
sizeof(struct lpfc_io_buf),
|
||||||
LPFC_COMMON_IO_BUF_SZ);
|
LPFC_COMMON_IO_BUF_SZ);
|
||||||
return 0;
|
return 0;
|
||||||
@ -10052,7 +10052,7 @@ lpfc_sli4_pci_mem_setup(struct lpfc_hba *phba)
|
|||||||
{
|
{
|
||||||
struct pci_dev *pdev = phba->pcidev;
|
struct pci_dev *pdev = phba->pcidev;
|
||||||
unsigned long bar0map_len, bar1map_len, bar2map_len;
|
unsigned long bar0map_len, bar1map_len, bar2map_len;
|
||||||
int error = -ENODEV;
|
int error;
|
||||||
uint32_t if_type;
|
uint32_t if_type;
|
||||||
|
|
||||||
if (!pdev)
|
if (!pdev)
|
||||||
@ -10071,7 +10071,7 @@ lpfc_sli4_pci_mem_setup(struct lpfc_hba *phba)
|
|||||||
*/
|
*/
|
||||||
if (pci_read_config_dword(pdev, LPFC_SLI_INTF,
|
if (pci_read_config_dword(pdev, LPFC_SLI_INTF,
|
||||||
&phba->sli4_hba.sli_intf.word0)) {
|
&phba->sli4_hba.sli_intf.word0)) {
|
||||||
return error;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* There is no SLI3 failback for SLI4 devices. */
|
/* There is no SLI3 failback for SLI4 devices. */
|
||||||
@ -10081,7 +10081,7 @@ lpfc_sli4_pci_mem_setup(struct lpfc_hba *phba)
|
|||||||
"2894 SLI_INTF reg contents invalid "
|
"2894 SLI_INTF reg contents invalid "
|
||||||
"sli_intf reg 0x%x\n",
|
"sli_intf reg 0x%x\n",
|
||||||
phba->sli4_hba.sli_intf.word0);
|
phba->sli4_hba.sli_intf.word0);
|
||||||
return error;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
if_type = bf_get(lpfc_sli_intf_if_type, &phba->sli4_hba.sli_intf);
|
if_type = bf_get(lpfc_sli_intf_if_type, &phba->sli4_hba.sli_intf);
|
||||||
@ -10105,7 +10105,7 @@ lpfc_sli4_pci_mem_setup(struct lpfc_hba *phba)
|
|||||||
dev_printk(KERN_ERR, &pdev->dev,
|
dev_printk(KERN_ERR, &pdev->dev,
|
||||||
"ioremap failed for SLI4 PCI config "
|
"ioremap failed for SLI4 PCI config "
|
||||||
"registers.\n");
|
"registers.\n");
|
||||||
goto out;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
phba->pci_bar0_memmap_p = phba->sli4_hba.conf_regs_memmap_p;
|
phba->pci_bar0_memmap_p = phba->sli4_hba.conf_regs_memmap_p;
|
||||||
/* Set up BAR0 PCI config space register memory map */
|
/* Set up BAR0 PCI config space register memory map */
|
||||||
@ -10116,7 +10116,7 @@ lpfc_sli4_pci_mem_setup(struct lpfc_hba *phba)
|
|||||||
if (if_type >= LPFC_SLI_INTF_IF_TYPE_2) {
|
if (if_type >= LPFC_SLI_INTF_IF_TYPE_2) {
|
||||||
dev_printk(KERN_ERR, &pdev->dev,
|
dev_printk(KERN_ERR, &pdev->dev,
|
||||||
"FATAL - No BAR0 mapping for SLI4, if_type 2\n");
|
"FATAL - No BAR0 mapping for SLI4, if_type 2\n");
|
||||||
goto out;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
phba->sli4_hba.conf_regs_memmap_p =
|
phba->sli4_hba.conf_regs_memmap_p =
|
||||||
ioremap(phba->pci_bar0_map, bar0map_len);
|
ioremap(phba->pci_bar0_map, bar0map_len);
|
||||||
@ -10124,7 +10124,7 @@ lpfc_sli4_pci_mem_setup(struct lpfc_hba *phba)
|
|||||||
dev_printk(KERN_ERR, &pdev->dev,
|
dev_printk(KERN_ERR, &pdev->dev,
|
||||||
"ioremap failed for SLI4 PCI config "
|
"ioremap failed for SLI4 PCI config "
|
||||||
"registers.\n");
|
"registers.\n");
|
||||||
goto out;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
lpfc_sli4_bar0_register_memmap(phba, if_type);
|
lpfc_sli4_bar0_register_memmap(phba, if_type);
|
||||||
}
|
}
|
||||||
@ -10170,6 +10170,7 @@ lpfc_sli4_pci_mem_setup(struct lpfc_hba *phba)
|
|||||||
if (!phba->sli4_hba.drbl_regs_memmap_p) {
|
if (!phba->sli4_hba.drbl_regs_memmap_p) {
|
||||||
dev_err(&pdev->dev,
|
dev_err(&pdev->dev,
|
||||||
"ioremap failed for SLI4 HBA doorbell registers.\n");
|
"ioremap failed for SLI4 HBA doorbell registers.\n");
|
||||||
|
error = -ENOMEM;
|
||||||
goto out_iounmap_conf;
|
goto out_iounmap_conf;
|
||||||
}
|
}
|
||||||
phba->pci_bar2_memmap_p = phba->sli4_hba.drbl_regs_memmap_p;
|
phba->pci_bar2_memmap_p = phba->sli4_hba.drbl_regs_memmap_p;
|
||||||
@ -10219,6 +10220,7 @@ lpfc_sli4_pci_mem_setup(struct lpfc_hba *phba)
|
|||||||
if (!phba->sli4_hba.dpp_regs_memmap_p) {
|
if (!phba->sli4_hba.dpp_regs_memmap_p) {
|
||||||
dev_err(&pdev->dev,
|
dev_err(&pdev->dev,
|
||||||
"ioremap failed for SLI4 HBA dpp registers.\n");
|
"ioremap failed for SLI4 HBA dpp registers.\n");
|
||||||
|
error = -ENOMEM;
|
||||||
goto out_iounmap_ctrl;
|
goto out_iounmap_ctrl;
|
||||||
}
|
}
|
||||||
phba->pci_bar4_memmap_p = phba->sli4_hba.dpp_regs_memmap_p;
|
phba->pci_bar4_memmap_p = phba->sli4_hba.dpp_regs_memmap_p;
|
||||||
@ -10249,7 +10251,7 @@ out_iounmap_ctrl:
|
|||||||
iounmap(phba->sli4_hba.ctrl_regs_memmap_p);
|
iounmap(phba->sli4_hba.ctrl_regs_memmap_p);
|
||||||
out_iounmap_conf:
|
out_iounmap_conf:
|
||||||
iounmap(phba->sli4_hba.conf_regs_memmap_p);
|
iounmap(phba->sli4_hba.conf_regs_memmap_p);
|
||||||
out:
|
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -11137,7 +11139,8 @@ lpfc_sli4_hba_unset(struct lpfc_hba *phba)
|
|||||||
lpfc_sli4_ras_dma_free(phba);
|
lpfc_sli4_ras_dma_free(phba);
|
||||||
|
|
||||||
/* Stop the SLI4 device port */
|
/* Stop the SLI4 device port */
|
||||||
phba->pport->work_port_events = 0;
|
if (phba->pport)
|
||||||
|
phba->pport->work_port_events = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -965,7 +965,7 @@ lpfc_nvme_io_cmd_wqe_cmpl(struct lpfc_hba *phba, struct lpfc_iocbq *pwqeIn,
|
|||||||
struct lpfc_nodelist *ndlp;
|
struct lpfc_nodelist *ndlp;
|
||||||
struct lpfc_nvme_fcpreq_priv *freqpriv;
|
struct lpfc_nvme_fcpreq_priv *freqpriv;
|
||||||
struct lpfc_nvme_lport *lport;
|
struct lpfc_nvme_lport *lport;
|
||||||
uint32_t code, status, idx, cpu;
|
uint32_t code, status, idx;
|
||||||
uint16_t cid, sqhd, data;
|
uint16_t cid, sqhd, data;
|
||||||
uint32_t *ptr;
|
uint32_t *ptr;
|
||||||
|
|
||||||
@ -1138,6 +1138,7 @@ out_err:
|
|||||||
lpfc_nvme_ktime(phba, lpfc_ncmd);
|
lpfc_nvme_ktime(phba, lpfc_ncmd);
|
||||||
}
|
}
|
||||||
if (phba->cpucheck_on & LPFC_CHECK_NVME_IO) {
|
if (phba->cpucheck_on & LPFC_CHECK_NVME_IO) {
|
||||||
|
uint32_t cpu;
|
||||||
idx = lpfc_ncmd->cur_iocbq.hba_wqidx;
|
idx = lpfc_ncmd->cur_iocbq.hba_wqidx;
|
||||||
cpu = smp_processor_id();
|
cpu = smp_processor_id();
|
||||||
if (cpu < LPFC_CHECK_CPU_CNT) {
|
if (cpu < LPFC_CHECK_CPU_CNT) {
|
||||||
|
@ -9881,7 +9881,7 @@ __lpfc_sli_issue_iocb_s4(struct lpfc_hba *phba, uint32_t ring_number,
|
|||||||
* The WQE can be either 64 or 128 bytes,
|
* The WQE can be either 64 or 128 bytes,
|
||||||
*/
|
*/
|
||||||
|
|
||||||
lockdep_assert_held(&phba->hbalock);
|
lockdep_assert_held(&pring->ring_lock);
|
||||||
|
|
||||||
if (piocb->sli4_xritag == NO_XRI) {
|
if (piocb->sli4_xritag == NO_XRI) {
|
||||||
if (piocb->iocb.ulpCommand == CMD_ABORT_XRI_CN ||
|
if (piocb->iocb.ulpCommand == CMD_ABORT_XRI_CN ||
|
||||||
|
@ -3924,12 +3924,12 @@ megasas_transition_to_ready(struct megasas_instance *instance, int ocr)
|
|||||||
/*
|
/*
|
||||||
* The cur_state should not last for more than max_wait secs
|
* The cur_state should not last for more than max_wait secs
|
||||||
*/
|
*/
|
||||||
for (i = 0; i < max_wait; i++) {
|
for (i = 0; i < max_wait * 50; i++) {
|
||||||
curr_abs_state = instance->instancet->
|
curr_abs_state = instance->instancet->
|
||||||
read_fw_status_reg(instance);
|
read_fw_status_reg(instance);
|
||||||
|
|
||||||
if (abs_state == curr_abs_state) {
|
if (abs_state == curr_abs_state) {
|
||||||
msleep(1000);
|
msleep(20);
|
||||||
} else
|
} else
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1652,6 +1652,8 @@ qla2x00_port_speed_store(struct device *dev, struct device_attribute *attr,
|
|||||||
}
|
}
|
||||||
|
|
||||||
rval = kstrtol(buf, 10, &type);
|
rval = kstrtol(buf, 10, &type);
|
||||||
|
if (rval)
|
||||||
|
return rval;
|
||||||
speed = type;
|
speed = type;
|
||||||
if (type == 40 || type == 80 || type == 160 ||
|
if (type == 40 || type == 80 || type == 160 ||
|
||||||
type == 320) {
|
type == 320) {
|
||||||
|
@ -193,6 +193,8 @@ qla_dfs_tgt_counters_show(struct seq_file *s, void *unused)
|
|||||||
|
|
||||||
for (i = 0; i < vha->hw->max_qpairs; i++) {
|
for (i = 0; i < vha->hw->max_qpairs; i++) {
|
||||||
qpair = vha->hw->queue_pair_map[i];
|
qpair = vha->hw->queue_pair_map[i];
|
||||||
|
if (!qpair)
|
||||||
|
continue;
|
||||||
qla_core_sbt_cmd += qpair->tgt_counters.qla_core_sbt_cmd;
|
qla_core_sbt_cmd += qpair->tgt_counters.qla_core_sbt_cmd;
|
||||||
core_qla_que_buf += qpair->tgt_counters.core_qla_que_buf;
|
core_qla_que_buf += qpair->tgt_counters.core_qla_que_buf;
|
||||||
qla_core_ret_ctio += qpair->tgt_counters.qla_core_ret_ctio;
|
qla_core_ret_ctio += qpair->tgt_counters.qla_core_ret_ctio;
|
||||||
|
@ -1132,7 +1132,7 @@ qla24xx_walk_and_build_prot_sglist(struct qla_hw_data *ha, srb_t *sp,
|
|||||||
/* if initiator doing write or target doing read */
|
/* if initiator doing write or target doing read */
|
||||||
if (direction_to_device) {
|
if (direction_to_device) {
|
||||||
for_each_sg(sgl, sg, tot_dsds, i) {
|
for_each_sg(sgl, sg, tot_dsds, i) {
|
||||||
dma_addr_t sle_phys = sg_phys(sg);
|
u64 sle_phys = sg_phys(sg);
|
||||||
|
|
||||||
/* If SGE addr + len flips bits in upper 32-bits */
|
/* If SGE addr + len flips bits in upper 32-bits */
|
||||||
if (MSD(sle_phys + sg->length) ^ MSD(sle_phys)) {
|
if (MSD(sle_phys + sg->length) ^ MSD(sle_phys)) {
|
||||||
@ -1178,7 +1178,7 @@ qla24xx_walk_and_build_prot_sglist(struct qla_hw_data *ha, srb_t *sp,
|
|||||||
|
|
||||||
ql_dbg(ql_dbg_tgt + ql_dbg_verbose, vha, 0xe023,
|
ql_dbg(ql_dbg_tgt + ql_dbg_verbose, vha, 0xe023,
|
||||||
"%s: sg[%x] (phys=%llx sglen=%x) ldma_sg_len: %x dif_bundl_len: %x ldma_needed: %x\n",
|
"%s: sg[%x] (phys=%llx sglen=%x) ldma_sg_len: %x dif_bundl_len: %x ldma_needed: %x\n",
|
||||||
__func__, i, sg_phys(sg), sglen, ldma_sg_len,
|
__func__, i, (u64)sg_phys(sg), sglen, ldma_sg_len,
|
||||||
difctx->dif_bundl_len, ldma_needed);
|
difctx->dif_bundl_len, ldma_needed);
|
||||||
|
|
||||||
while (sglen) {
|
while (sglen) {
|
||||||
|
@ -2764,6 +2764,12 @@ static void pqi_process_raid_io_error(struct pqi_io_request *io_request)
|
|||||||
sshdr.sense_key == HARDWARE_ERROR &&
|
sshdr.sense_key == HARDWARE_ERROR &&
|
||||||
sshdr.asc == 0x3e &&
|
sshdr.asc == 0x3e &&
|
||||||
sshdr.ascq == 0x1) {
|
sshdr.ascq == 0x1) {
|
||||||
|
struct pqi_ctrl_info *ctrl_info = shost_to_hba(scmd->device->host);
|
||||||
|
struct pqi_scsi_dev *device = scmd->device->hostdata;
|
||||||
|
|
||||||
|
if (printk_ratelimit())
|
||||||
|
scmd_printk(KERN_ERR, scmd, "received 'logical unit failure' from controller for scsi %d:%d:%d:%d\n",
|
||||||
|
ctrl_info->scsi_host->host_no, device->bus, device->target, device->lun);
|
||||||
pqi_take_device_offline(scmd->device, "RAID");
|
pqi_take_device_offline(scmd->device, "RAID");
|
||||||
host_byte = DID_NO_CONNECT;
|
host_byte = DID_NO_CONNECT;
|
||||||
}
|
}
|
||||||
|
@ -640,7 +640,7 @@ static int ufs_hi3670_init(struct ufs_hba *hba)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct ufs_hba_variant_ops ufs_hba_hi3660_vops = {
|
static const struct ufs_hba_variant_ops ufs_hba_hi3660_vops = {
|
||||||
.name = "hi3660",
|
.name = "hi3660",
|
||||||
.init = ufs_hi3660_init,
|
.init = ufs_hi3660_init,
|
||||||
.link_startup_notify = ufs_hisi_link_startup_notify,
|
.link_startup_notify = ufs_hisi_link_startup_notify,
|
||||||
@ -649,7 +649,7 @@ static struct ufs_hba_variant_ops ufs_hba_hi3660_vops = {
|
|||||||
.resume = ufs_hisi_resume,
|
.resume = ufs_hisi_resume,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct ufs_hba_variant_ops ufs_hba_hi3670_vops = {
|
static const struct ufs_hba_variant_ops ufs_hba_hi3670_vops = {
|
||||||
.name = "hi3670",
|
.name = "hi3670",
|
||||||
.init = ufs_hi3670_init,
|
.init = ufs_hi3670_init,
|
||||||
.link_startup_notify = ufs_hisi_link_startup_notify,
|
.link_startup_notify = ufs_hisi_link_startup_notify,
|
||||||
@ -669,13 +669,10 @@ MODULE_DEVICE_TABLE(of, ufs_hisi_of_match);
|
|||||||
static int ufs_hisi_probe(struct platform_device *pdev)
|
static int ufs_hisi_probe(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
const struct of_device_id *of_id;
|
const struct of_device_id *of_id;
|
||||||
struct ufs_hba_variant_ops *vops;
|
|
||||||
struct device *dev = &pdev->dev;
|
|
||||||
|
|
||||||
of_id = of_match_node(ufs_hisi_of_match, dev->of_node);
|
of_id = of_match_node(ufs_hisi_of_match, pdev->dev.of_node);
|
||||||
vops = (struct ufs_hba_variant_ops *)of_id->data;
|
|
||||||
|
|
||||||
return ufshcd_pltfrm_init(pdev, vops);
|
return ufshcd_pltfrm_init(pdev, of_id->data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ufs_hisi_remove(struct platform_device *pdev)
|
static int ufs_hisi_remove(struct platform_device *pdev)
|
||||||
|
@ -297,7 +297,7 @@ static void ufshcd_init_lanes_per_dir(struct ufs_hba *hba)
|
|||||||
* Returns 0 on success, non-zero value on failure
|
* Returns 0 on success, non-zero value on failure
|
||||||
*/
|
*/
|
||||||
int ufshcd_pltfrm_init(struct platform_device *pdev,
|
int ufshcd_pltfrm_init(struct platform_device *pdev,
|
||||||
struct ufs_hba_variant_ops *vops)
|
const struct ufs_hba_variant_ops *vops)
|
||||||
{
|
{
|
||||||
struct ufs_hba *hba;
|
struct ufs_hba *hba;
|
||||||
void __iomem *mmio_base;
|
void __iomem *mmio_base;
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
#include "ufshcd.h"
|
#include "ufshcd.h"
|
||||||
|
|
||||||
int ufshcd_pltfrm_init(struct platform_device *pdev,
|
int ufshcd_pltfrm_init(struct platform_device *pdev,
|
||||||
struct ufs_hba_variant_ops *vops);
|
const struct ufs_hba_variant_ops *vops);
|
||||||
void ufshcd_pltfrm_shutdown(struct platform_device *pdev);
|
void ufshcd_pltfrm_shutdown(struct platform_device *pdev);
|
||||||
|
|
||||||
#ifdef CONFIG_PM
|
#ifdef CONFIG_PM
|
||||||
|
@ -546,7 +546,7 @@ struct ufs_hba {
|
|||||||
int nutrs;
|
int nutrs;
|
||||||
int nutmrs;
|
int nutmrs;
|
||||||
u32 ufs_version;
|
u32 ufs_version;
|
||||||
struct ufs_hba_variant_ops *vops;
|
const struct ufs_hba_variant_ops *vops;
|
||||||
void *priv;
|
void *priv;
|
||||||
unsigned int irq;
|
unsigned int irq;
|
||||||
bool is_irq_enabled;
|
bool is_irq_enabled;
|
||||||
|
@ -586,7 +586,6 @@ static int virtscsi_device_reset(struct scsi_cmnd *sc)
|
|||||||
return FAILED;
|
return FAILED;
|
||||||
|
|
||||||
memset(cmd, 0, sizeof(*cmd));
|
memset(cmd, 0, sizeof(*cmd));
|
||||||
cmd->sc = sc;
|
|
||||||
cmd->req.tmf = (struct virtio_scsi_ctrl_tmf_req){
|
cmd->req.tmf = (struct virtio_scsi_ctrl_tmf_req){
|
||||||
.type = VIRTIO_SCSI_T_TMF,
|
.type = VIRTIO_SCSI_T_TMF,
|
||||||
.subtype = cpu_to_virtio32(vscsi->vdev,
|
.subtype = cpu_to_virtio32(vscsi->vdev,
|
||||||
@ -645,7 +644,6 @@ static int virtscsi_abort(struct scsi_cmnd *sc)
|
|||||||
return FAILED;
|
return FAILED;
|
||||||
|
|
||||||
memset(cmd, 0, sizeof(*cmd));
|
memset(cmd, 0, sizeof(*cmd));
|
||||||
cmd->sc = sc;
|
|
||||||
cmd->req.tmf = (struct virtio_scsi_ctrl_tmf_req){
|
cmd->req.tmf = (struct virtio_scsi_ctrl_tmf_req){
|
||||||
.type = VIRTIO_SCSI_T_TMF,
|
.type = VIRTIO_SCSI_T_TMF,
|
||||||
.subtype = VIRTIO_SCSI_T_TMF_ABORT_TASK,
|
.subtype = VIRTIO_SCSI_T_TMF_ABORT_TASK,
|
||||||
|
@ -1663,7 +1663,7 @@ static void tcmu_dev_kref_release(struct kref *kref)
|
|||||||
WARN_ON(!all_expired);
|
WARN_ON(!all_expired);
|
||||||
|
|
||||||
tcmu_blocks_release(&udev->data_blocks, 0, udev->dbi_max + 1);
|
tcmu_blocks_release(&udev->data_blocks, 0, udev->dbi_max + 1);
|
||||||
kfree(udev->data_bitmap);
|
bitmap_free(udev->data_bitmap);
|
||||||
mutex_unlock(&udev->cmdr_lock);
|
mutex_unlock(&udev->cmdr_lock);
|
||||||
|
|
||||||
call_rcu(&dev->rcu_head, tcmu_dev_call_rcu);
|
call_rcu(&dev->rcu_head, tcmu_dev_call_rcu);
|
||||||
@ -1794,11 +1794,12 @@ static int tcmu_netlink_event_send(struct tcmu_dev *udev,
|
|||||||
|
|
||||||
ret = genlmsg_multicast_allns(&tcmu_genl_family, skb, 0,
|
ret = genlmsg_multicast_allns(&tcmu_genl_family, skb, 0,
|
||||||
TCMU_MCGRP_CONFIG, GFP_KERNEL);
|
TCMU_MCGRP_CONFIG, GFP_KERNEL);
|
||||||
/* We don't care if no one is listening */
|
|
||||||
if (ret == -ESRCH)
|
/* Wait during an add as the listener may not be up yet */
|
||||||
ret = 0;
|
if (ret == 0 ||
|
||||||
if (!ret)
|
(ret == -ESRCH && cmd == TCMU_CMD_ADDED_DEVICE))
|
||||||
ret = tcmu_wait_genl_cmd_reply(udev);
|
return tcmu_wait_genl_cmd_reply(udev);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1870,9 +1871,7 @@ static int tcmu_configure_device(struct se_device *dev)
|
|||||||
info = &udev->uio_info;
|
info = &udev->uio_info;
|
||||||
|
|
||||||
mutex_lock(&udev->cmdr_lock);
|
mutex_lock(&udev->cmdr_lock);
|
||||||
udev->data_bitmap = kcalloc(BITS_TO_LONGS(udev->max_blocks),
|
udev->data_bitmap = bitmap_zalloc(udev->max_blocks, GFP_KERNEL);
|
||||||
sizeof(unsigned long),
|
|
||||||
GFP_KERNEL);
|
|
||||||
mutex_unlock(&udev->cmdr_lock);
|
mutex_unlock(&udev->cmdr_lock);
|
||||||
if (!udev->data_bitmap) {
|
if (!udev->data_bitmap) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
@ -1959,7 +1958,7 @@ err_register:
|
|||||||
vfree(udev->mb_addr);
|
vfree(udev->mb_addr);
|
||||||
udev->mb_addr = NULL;
|
udev->mb_addr = NULL;
|
||||||
err_vzalloc:
|
err_vzalloc:
|
||||||
kfree(udev->data_bitmap);
|
bitmap_free(udev->data_bitmap);
|
||||||
udev->data_bitmap = NULL;
|
udev->data_bitmap = NULL;
|
||||||
err_bitmap_alloc:
|
err_bitmap_alloc:
|
||||||
kfree(info->name);
|
kfree(info->name);
|
||||||
|
Loading…
Reference in New Issue
Block a user