• N
    [SCSI] target: Fix multi task->task_sg[] chaining logic bug · 4a8fcc2c
    Nicholas Bellinger 提交于
    This patch fixes a bug in transport_do_task_sg_chain() used by HW target
    mode modules with sg_chain() to provide a single sg_next() walkable memory
    layout for use with pci_map_sg() and friends.  This patch addresses an
    issue with mapping multiple small block max_sector tasks across multiple
    struct se_task->task_sg[] mappings for HW target mode operation.
    
    This was causing OOPs with (cmd->t_task->t_tasks_no > 1) I/O traffic for
    HW target drivers using transport_do_task_sg_chain(), and has been tested
    so far with tcm_fc(openfcoe), tcm_qla2xxx, and ib_srpt fabrics with
    t_tasks_no > 1 IBLOCK backends using a smaller max_sectors to trigger the
    original issue.
    Signed-off-by: NNicholas Bellinger <nab@linux-iscsi.org>
    Acked-by: NKiran Patil <kiran.patil@intel.com>
    Cc: stable@kernel.org
    Signed-off-by: NJames Bottomley <jbottomley@parallels.com>
    4a8fcc2c
target_core_transport.c 168.3 KB