mirror of https://gitee.com/openkylin/linux.git
SCSI fixes on 20150117
This is one fix for a Multiqueue sleeping in invalid context problem and a MAINTAINER file update for Qlogic. Signed-off-by: James Bottomley <JBottomley@Parallels.com> -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iQEcBAABAgAGBQJUusiiAAoJEDeqqVYsXL0MyrgH/iOi8ERmP0TJKZVEPeYacas6 YZeUw0ZsckpqgaE/PoRdkgGx6Slz4Nm2x+Dz1VEr1SWtGNIKLnAgHVP1S/Ee/4ws 0vVYd4VZ4OzT8FkjHRHeeeBj9EWSR0Zeh4eZu+eIilo9FOhJTHzy8R6vQxS9b3Hu GzuVm2MaQHmYaAVVMnbitwj41pczLzDwDzmTBqcoh8ak8ynBiFBFgWxg+ZDyJtcZ KRusp/nKJGuxoehHmgLI+Vor2jCrVpagyIbAqkHtn9OLZEtmaTkGrR42qlIedxZb cUNDVysmrI8lRhkwiVD7+mT4A377MMlfjO0qFCUc+bkz1xTyyP2ABLT8IhmpO4w= =5EBM -----END PGP SIGNATURE----- Merge tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi Pull SCSI fixes from James Bottomley: "This is one fix for a Multiqueue sleeping in invalid context problem and a MAINTAINER file update for Qlogic" * tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi: scsi: ->queue_rq can't sleep MAINTAINERS: Update maintainer list for qla4xxx
This commit is contained in:
commit
901b2082b5
|
@ -7747,8 +7747,7 @@ F: Documentation/scsi/LICENSE.qla2xxx
|
||||||
F: drivers/scsi/qla2xxx/
|
F: drivers/scsi/qla2xxx/
|
||||||
|
|
||||||
QLOGIC QLA4XXX iSCSI DRIVER
|
QLOGIC QLA4XXX iSCSI DRIVER
|
||||||
M: Vikas Chaudhary <vikas.chaudhary@qlogic.com>
|
M: QLogic-Storage-Upstream@qlogic.com
|
||||||
M: iscsi-driver@qlogic.com
|
|
||||||
L: linux-scsi@vger.kernel.org
|
L: linux-scsi@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
F: Documentation/scsi/LICENSE.qla4xxx
|
F: Documentation/scsi/LICENSE.qla4xxx
|
||||||
|
|
|
@ -591,7 +591,6 @@ static void scsi_free_sgtable(struct scsi_data_buffer *sdb, bool mq)
|
||||||
static int scsi_alloc_sgtable(struct scsi_data_buffer *sdb, int nents, bool mq)
|
static int scsi_alloc_sgtable(struct scsi_data_buffer *sdb, int nents, bool mq)
|
||||||
{
|
{
|
||||||
struct scatterlist *first_chunk = NULL;
|
struct scatterlist *first_chunk = NULL;
|
||||||
gfp_t gfp_mask = mq ? GFP_NOIO : GFP_ATOMIC;
|
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
BUG_ON(!nents);
|
BUG_ON(!nents);
|
||||||
|
@ -606,7 +605,7 @@ static int scsi_alloc_sgtable(struct scsi_data_buffer *sdb, int nents, bool mq)
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = __sg_alloc_table(&sdb->table, nents, SCSI_MAX_SG_SEGMENTS,
|
ret = __sg_alloc_table(&sdb->table, nents, SCSI_MAX_SG_SEGMENTS,
|
||||||
first_chunk, gfp_mask, scsi_sg_alloc);
|
first_chunk, GFP_ATOMIC, scsi_sg_alloc);
|
||||||
if (unlikely(ret))
|
if (unlikely(ret))
|
||||||
scsi_free_sgtable(sdb, mq);
|
scsi_free_sgtable(sdb, mq);
|
||||||
return ret;
|
return ret;
|
||||||
|
|
Loading…
Reference in New Issue