Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp4014756imm; Mon, 17 Sep 2018 06:57:40 -0700 (PDT) X-Google-Smtp-Source: ANB0Vdaj2Mnkx/AaZc9E3dNbTwxvpE7loI7PM8xIL85piey1OyGRH7mAYoC3BJYUhYHRboblLB0T X-Received: by 2002:a17:902:6806:: with SMTP id h6-v6mr25431396plk.304.1537192660868; Mon, 17 Sep 2018 06:57:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537192660; cv=none; d=google.com; s=arc-20160816; b=D3IdjvsTdg5PRAbB6aSUs/WrzKoZzC13ZsSw2CwU2bKHIQOD8/SityCYLnDGjdr64K M+cnu38guM+oqjJsQ2aNkE5Z+D+1eztAnp8ULeaauy6uvej1KwtKjdZ63U2l4o0OD1FB WRRmzy7euwW2NN/GRw78uI7aAgHNxrUzaE1R/qwb8cPVZ5vI1+4WfuZvfCxcMEUBHgxe k7aR0agyvKRldYHhEcjyGjamzMSP3LCKlRMH5pAbErHoopdeN4/KmddX3OnN7wIJDruU XPMxqWP0ByT4elc34iDK4Cem0ukkunzYm0ltyfx3tmqwU+CU+zc6KzTRlbf8qG6NTA19 Xvhg== 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; bh=bW1e68nrF+cPHKitNXdALKLSMCY+oNSow/HW7yKBiDA=; b=LFanUkkDzxHIDCIGAEVAU+6bo9MhcuEvt+QTpeEY8cibrP7mHBYjsUC7cIOnWT2/0y uw4jdNwX1EpFRoCYp12a177Y25Noz4HOPMQmuR4u2ZLjEZlOEXbMHN5BOF30YwSaSX0w xaw6h5zf4k6+N1G/hVbQmbB/v6bvlUlvrsOcNEwXK+hXCWVeirR6cuhh5R8eZ55THC1U i78n3lKOI6VY4qjJtRWS/jSZkdMRfSqMx7uuDdGrPS8ObEYz6gHRrzDGU0kz2xUUULWu qNsjGHBE50v9zeqyezhWOt/3U1GNQVyL33IHkM3QOjyVvF350KeCr/zwalnkU/oMVNXF B51A== 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 u7-v6si15042208plz.353.2018.09.17.06.57.22; Mon, 17 Sep 2018 06:57:40 -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 S1728525AbeIQTWz (ORCPT + 99 others); Mon, 17 Sep 2018 15:22:55 -0400 Received: from mx2.suse.de ([195.135.220.15]:53184 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726865AbeIQTWz (ORCPT ); Mon, 17 Sep 2018 15:22:55 -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 1464BAD49; Mon, 17 Sep 2018 13:55:27 +0000 (UTC) Subject: Re: [PATCH 3/5] scsi: libsas: always unregister the old device if going to discover new To: Jason Yan , martin.petersen@oracle.com, jejb@linux.vnet.ibm.com Cc: linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org, john.garry@huawei.com, zhaohongjiang@huawei.com, dan.j.williams@intel.com, jthumshirn@suse.de, hch@lst.de, huangdaode@hisilicon.com, chenxiang66@hisilicon.com, miaoxie@huawei.com, Ewan Milne , Tomas Henzl References: <20180912082946.34814-1-yanaijie@huawei.com> <20180912082946.34814-4-yanaijie@huawei.com> From: Hannes Reinecke Message-ID: Date: Mon, 17 Sep 2018 15:55:26 +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: <20180912082946.34814-4-yanaijie@huawei.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 09/12/2018 10:29 AM, Jason Yan wrote: > If we went into sas_rediscover_dev() the attached_sas_addr was already > insured not to be zero. So it's unnecessary to check if the > attached_sas_addr is zero. > > And although if the sas address is not changed, we always have to > unregister the old device when we are going to register a new one. We > cannot just leave the device there and bring up the new. > > Signed-off-by: Jason Yan > CC: chenxiang > CC: John Garry > CC: Johannes Thumshirn > CC: Ewan Milne > CC: Christoph Hellwig > CC: Tomas Henzl > CC: Dan Williams > CC: Hannes Reinecke > Reviewed-by: Johannes Thumshirn > --- > drivers/scsi/libsas/sas_expander.c | 13 +++++-------- > 1 file changed, 5 insertions(+), 8 deletions(-) > > diff --git a/drivers/scsi/libsas/sas_expander.c b/drivers/scsi/libsas/sas_expander.c > index fadc99cb60df..52222940d398 100644 > --- a/drivers/scsi/libsas/sas_expander.c > +++ b/drivers/scsi/libsas/sas_expander.c > @@ -2054,14 +2054,11 @@ static int sas_rediscover_dev(struct domain_device *dev, int phy_id, bool last) > return res; > } > > - /* delete the old link */ > - if (SAS_ADDR(phy->attached_sas_addr) && > - SAS_ADDR(sas_addr) != SAS_ADDR(phy->attached_sas_addr)) { > - SAS_DPRINTK("ex %016llx phy 0x%x replace %016llx\n", > - SAS_ADDR(dev->sas_addr), phy_id, > - SAS_ADDR(phy->attached_sas_addr)); > - sas_unregister_devs_sas_addr(dev, phy_id, last); > - } > + /* we always have to delete the old device when we went here */ > + SAS_DPRINTK("ex %016llx phy 0x%x replace %016llx\n", > + SAS_ADDR(dev->sas_addr), phy_id, > + SAS_ADDR(phy->attached_sas_addr)); > + sas_unregister_devs_sas_addr(dev, phy_id, last); > > return sas_discover_new(dev, phy_id); > } > Reviewed-by: Hannes Reinecke Cheers, Hannes