Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp484318imm; Tue, 31 Jul 2018 23:31:45 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdypkhJl1J3dri+ltudN9quoIU8rwbQEweY7v3FZMl8nXKyp7Eoz1iJS0VeD4Y9rB5YQ2Fl X-Received: by 2002:a62:c505:: with SMTP id j5-v6mr24957046pfg.153.1533105105021; Tue, 31 Jul 2018 23:31:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533105105; cv=none; d=google.com; s=arc-20160816; b=EbxBxtrF9ZhKUqCkOvKbdSb2O6EkKZ9JipdC8vgfhMMyJpN0ld4zqEB3A/PSIfCYUO FyuTSz+6M6AuUiR1z3/2ij/dhOLT93Q2pxFnop2kTyewhLdowVhVIVQ0bo9ketilecH2 9zMALahPADxShR39Vw7XvqC+rOAxIYuucJBbNhYEGDWv8eYDmSxI4NLKvr4Pqk3pdX6n AC+T4PiH6s5ldDswYHxQAi8uO79RpjsCeZ8lUTS0c8OrB478MjTaKyoJcQEYNqBPCPZe LNN50nmqyl2MN5y/gZM1D2RwH2OkqESBh/y59Cc9cteJNlkDnhff5H0AX8g80VkhEQdY 51EQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=MwMxDqmZZbjY5TFpzl7hseeOZSJ6cntj805XVl3QJv0=; b=leVhHxzHw74d4dvhwofgZl9V3nkrrpaWiWS1yIYZ8ns5s7EkaI4qx3i6t2fJmRiG70 y/NgvQN3E4/q5MxjHTSj1O4jDTgNeCt48W8KprItiBtjvAcWLQ9Ftdj/kRAXmMLraDuG yoHny6pXrXf1jwwtACRJbKJGRSiUwHNYH6Rgg3x7lP5SYYxLndexSLP9FS8FrbHEMWvq awzlztsC3zsfaQNQXmQh5ni/Pt8vfbr7Fy9wFgiIheCDDc8gVAIDbnE4eYc3+9BQpgM1 EVxba4/6c28Bgn7P5pqJaxi5GQlKyYkZHyU6G65juRJtyqacgw5ey5StdBrZXDwWHHgz 3Z+A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j85-v6si16840040pfa.232.2018.07.31.23.31.30; Tue, 31 Jul 2018 23:31:44 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387494AbeHAIOj (ORCPT + 99 others); Wed, 1 Aug 2018 04:14:39 -0400 Received: from mx2.suse.de ([195.135.220.15]:51080 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2387419AbeHAIOj (ORCPT ); Wed, 1 Aug 2018 04:14:39 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay1.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 02FE4AEB9; Wed, 1 Aug 2018 06:30:34 +0000 (UTC) Subject: Re: [PATCH 2/3] scsi: fcoe: drop frames in ELS LOGO error path To: Johannes Thumshirn , "Martin K . Petersen" Cc: Linux Kernel Mailinglist , Linux SCSI Mailinglist , ard References: <20180731134603.20089-1-jthumshirn@suse.de> <20180731134603.20089-3-jthumshirn@suse.de> From: Hannes Reinecke Message-ID: Date: Wed, 1 Aug 2018 08:30:33 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20180731134603.20089-3-jthumshirn@suse.de> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 07/31/2018 03:46 PM, Johannes Thumshirn wrote: > Drop the frames in the ELS LOGO error path instead of just returning > an error. > > This fixes the following kmemleak report: > unreferenced object 0xffff880064cb1000 (size 424): > comm "kworker/0:2", pid 24, jiffies 4294904293 (age 68.504s) > hex dump (first 32 bytes): > 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ > 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ > backtrace: > [<(____ptrval____)>] _fc_frame_alloc+0x2c/0x180 [libfc] > [<(____ptrval____)>] fc_lport_enter_logo+0x106/0x360 [libfc] > [<(____ptrval____)>] fc_fabric_logoff+0x8c/0xc0 [libfc] > [<(____ptrval____)>] fcoe_if_destroy+0x79/0x3b0 [fcoe] > [<(____ptrval____)>] fcoe_destroy_work+0xd2/0x170 [fcoe] > [<(____ptrval____)>] process_one_work+0x7ff/0x1420 > [<(____ptrval____)>] worker_thread+0x87/0xef0 > [<(____ptrval____)>] kthread+0x2db/0x390 > [<(____ptrval____)>] ret_from_fork+0x35/0x40 > [<(____ptrval____)>] 0xffffffffffffffff > > which can be triggered by issuing > echo eth0 > /sys/bus/fcoe/ctlr_destroy > > Signed-off-by: Johannes Thumshirn > --- > drivers/scsi/fcoe/fcoe_ctlr.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/drivers/scsi/fcoe/fcoe_ctlr.c b/drivers/scsi/fcoe/fcoe_ctlr.c > index ceb35ebbeb8f..ffec695e0bfb 100644 > --- a/drivers/scsi/fcoe/fcoe_ctlr.c > +++ b/drivers/scsi/fcoe/fcoe_ctlr.c > @@ -754,9 +754,9 @@ int fcoe_ctlr_els_send(struct fcoe_ctlr *fip, struct fc_lport *lport, > case ELS_LOGO: > if (fip->mode == FIP_MODE_VN2VN) { > if (fip->state != FIP_ST_VNMP_UP) > - return -EINVAL; > + goto drop; > if (ntoh24(fh->fh_d_id) == FC_FID_FLOGI) > - return -EINVAL; > + goto drop; > } else { > if (fip->state != FIP_ST_ENABLED) > return 0; > Reviewed-by: Hannes Reinecke Cheers, Hannes -- Dr. Hannes Reinecke Teamlead Storage & Networking hare@suse.de +49 911 74053 688 SUSE LINUX GmbH, Maxfeldstr. 5, 90409 Nürnberg GF: F. Imendörffer, J. Smithard, J. Guild, D. Upmanyu, G. Norton HRB 21284 (AG Nürnberg)