scsi: fcoe: fix use-after-free in fcoe_ctlr_els_send
authorJohannes Thumshirn <jthumshirn@suse.de>
Tue, 31 Jul 2018 13:46:01 +0000 (15:46 +0200)
committerMartin K. Petersen <martin.petersen@oracle.com>
Thu, 2 Aug 2018 19:30:03 +0000 (15:30 -0400)
commit2d7d4fd35e6e15b47c13c70368da83add19f01e7
treed5ee11e647116774edbf2cfc46182acfb3c12700
parent15d258674b5c91b9c1ae11264624d5c0d0675e8f
scsi: fcoe: fix use-after-free in fcoe_ctlr_els_send

KASAN reports a use-after-free in fcoe_ctlr_els_send() when we're sending a
LOGO and have FIP debugging enabled. This is because we're first freeing
the skb and then printing the frame's DID. But the DID is a member of the
FC frame header which in turn is the skb's payload.

Exchange the debug print and kfree_skb() calls so we're not touching the
freed data.

Signed-off-by: Johannes Thumshirn <jthumshirn@suse.de>
Reviewed-by: Hannes Reinecke <hare@suse.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/fcoe/fcoe_ctlr.c