Commit f96d279f authored by zhengbin's avatar zhengbin Committed by Martin K. Petersen

scsi: fcoe: fix null-ptr-deref Read in fc_release_transport

In fcoe_if_init, if fc_attach_transport(&fcoe_vport_fc_functions)
fails, need to free the previously memory and return fail, otherwise
will trigger null-ptr-deref Read in fc_release_transport.

fcoe_exit
  fcoe_if_exit
    fc_release_transport(fcoe_vport_scsi_transport)

Link: https://lore.kernel.org/r/1566279789-58207-1-git-send-email-zhengbin13@huawei.comReported-by: default avatarHulk Robot <hulkci@huawei.com>
Reviewed-by: default avatarHannes Reinecke <hare@suse.com>
Signed-off-by: default avatarzhengbin <zhengbin13@huawei.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 7ce5eed0
...@@ -1250,15 +1250,21 @@ static int __init fcoe_if_init(void) ...@@ -1250,15 +1250,21 @@ static int __init fcoe_if_init(void)
/* attach to scsi transport */ /* attach to scsi transport */
fcoe_nport_scsi_transport = fcoe_nport_scsi_transport =
fc_attach_transport(&fcoe_nport_fc_functions); fc_attach_transport(&fcoe_nport_fc_functions);
if (!fcoe_nport_scsi_transport)
goto err;
fcoe_vport_scsi_transport = fcoe_vport_scsi_transport =
fc_attach_transport(&fcoe_vport_fc_functions); fc_attach_transport(&fcoe_vport_fc_functions);
if (!fcoe_vport_scsi_transport)
if (!fcoe_nport_scsi_transport) { goto err_vport;
printk(KERN_ERR "fcoe: Failed to attach to the FC transport\n");
return -ENODEV;
}
return 0; return 0;
err_vport:
fc_release_transport(fcoe_nport_scsi_transport);
err:
printk(KERN_ERR "fcoe: Failed to attach to the FC transport\n");
return -ENODEV;
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment