Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp699190rwb; Fri, 23 Sep 2022 02:57:30 -0700 (PDT) X-Google-Smtp-Source: AMsMyM58/OqHoig2IVSZGXC2v0jduuKxibyJeA3qil4wx4k5JNiKFGG+EzQQwVAsHxSBtbIp8fKf X-Received: by 2002:a63:141:0:b0:43a:3851:b2ba with SMTP id 62-20020a630141000000b0043a3851b2bamr7219607pgb.90.1663927050030; Fri, 23 Sep 2022 02:57:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663927050; cv=none; d=google.com; s=arc-20160816; b=nbvcIW1N3tEvPjYzPCCuHZhP3AWw3walxpf5V4PXhmMMjCnGFxIfSzVK9VbaXiDNsj niWN+FMUOVfaiPT73DTTnRmvhSYkljgFW6+PHwcUNc/ihnAZgu2RI8efDE6E5cWjR4am Eo6ISJw74ozdai+tUCnLU/sCZf9e9nBb1AvPMeJq5cXWoLWFC41D6FsAcgdtv3rfAl9L 8/qmDGUntODjBTODKfunTBhAgCgS8HAMx3pbVP9TAo1cXlg2PiyK98R5HTR9URC835Sj PwIE+6B5sjK4NNwoofKaWujRga4+WMp9ZbeEQrTo8ES9wRpnFUTITZItuM/82es6HmMz zZqQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=OYFWGALssgvULXUzZydBkbMC28Yus1kWeLewLXRyYs8=; b=IOhQTs8MfWCmDX139EdJo/W/fmUcvxNuDPOxOhcZ1aKL+YfgIUZoKNz+j3J1sTK7vC vpl78k1o3e99plWZWRVlKM9rQuIIQObrD5psa+8scBJTDrOhyTtkASIaS0stgruoxkb8 7AP9jAeu3KEA5K/eOBc0z/9AOocVv3Bqt0pSrxJAdLPxujonaxfvm5KbrShv/3V5wY8c MAL/aPiLbHUEWY1ZbAKNDp0KmouFJNCKSTQsyNAc/QUEodKzz3vOuluPxSiRO1xkvDFz FCIvjz09ZIk6qbXltxz/9ZR9YV0Yh9XX6YhrUBMT3RycH/q+Ezr/ipi/BgfQLHz1zafm j+fw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id v6-20020a632f06000000b0043c07dae4ddsi6175453pgv.285.2022.09.23.02.57.18; Fri, 23 Sep 2022 02:57:30 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232021AbiIWJqr (ORCPT + 99 others); Fri, 23 Sep 2022 05:46:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37938 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231819AbiIWJp7 (ORCPT ); Fri, 23 Sep 2022 05:45:59 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6267B5FDA; Fri, 23 Sep 2022 02:44:34 -0700 (PDT) Received: from canpemm500004.china.huawei.com (unknown [172.30.72.55]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4MYnGs5qj0zpVMc; Fri, 23 Sep 2022 17:41:41 +0800 (CST) Received: from [10.174.179.14] (10.174.179.14) by canpemm500004.china.huawei.com (7.192.104.92) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Fri, 23 Sep 2022 17:44:32 +0800 Subject: Re: [PATCH 6/7] scsi: pm8001: use dev_and_phy_addr_same() instead of open coded To: John Garry , , CC: , , , , , References: <20220917104311.1878250-1-yanaijie@huawei.com> <20220917104311.1878250-7-yanaijie@huawei.com> <0034eff3-70a5-becb-0821-f9c36371e6d9@huawei.com> From: Jason Yan Message-ID: <3c1aa262-7e9b-cb6c-e8a1-a1a201050a10@huawei.com> Date: Fri, 23 Sep 2022 17:44:31 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.12.0 MIME-Version: 1.0 In-Reply-To: <0034eff3-70a5-becb-0821-f9c36371e6d9@huawei.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-Originating-IP: [10.174.179.14] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To canpemm500004.china.huawei.com (7.192.104.92) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2022/9/22 22:24, John Garry wrote: > On 17/09/2022 11:43, Jason Yan wrote: >> The sas address comparation of domain device and expander phy is open >> coded. Now we can replace it with dev_and_phy_addr_same(). >> >> Signed-off-by: Jason Yan >> --- >>   drivers/scsi/pm8001/pm8001_sas.c | 3 +-- >>   1 file changed, 1 insertion(+), 2 deletions(-) >> >> diff --git a/drivers/scsi/pm8001/pm8001_sas.c >> b/drivers/scsi/pm8001/pm8001_sas.c >> index 8e3f2f9ddaac..bb1b1722f3ee 100644 >> --- a/drivers/scsi/pm8001/pm8001_sas.c >> +++ b/drivers/scsi/pm8001/pm8001_sas.c >> @@ -649,8 +649,7 @@ static int pm8001_dev_found_notify(struct >> domain_device *dev) >>           for (phy_id = 0; phy_id < parent_dev->ex_dev.num_phys; > > This code seems the same between many libsas LLDDs - could we factor it > out into libsas? If so, then maybe those new helpers could be put in > sas_internal.h For the part of putting helpers in sas_internal.h, this needs to make the helpers exported. I think it's not worth to do this because they are very small. I'd still like to make them inline functions in libsas.h such as: diff --git a/include/scsi/libsas.h b/include/scsi/libsas.h index 2dbead74a2af..e9e76c898287 100644 --- a/include/scsi/libsas.h +++ b/include/scsi/libsas.h @@ -648,6 +648,22 @@ static inline bool sas_is_internal_abort(struct sas_task *task) return task->task_proto == SAS_PROTOCOL_INTERNAL_ABORT; } +static inline int sas_find_attathed_phy(struct expander_device *ex_dev, + struct domain_device *dev) +{ + struct ex_phy *phy; + int phy_id; + + for (phy_id = 0; phy_id < ex_dev->num_phys; phy_id++) { + phy = &ex_dev->ex_phy[phy_id]; + if (SAS_ADDR(phy->attached_sas_addr) + == SAS_ADDR(dev->sas_addr)) + return phy_id; + } + + return ex_dev->num_phys; +} + struct sas_domain_function_template { /* The class calls these to notify the LLDD of an event. */ void (*lldd_port_formed)(struct asd_sas_phy *); And the LLDDs change like: diff --git a/drivers/scsi/pm8001/pm8001_sas.c b/drivers/scsi/pm8001/pm8001_sas.c index 8e3f2f9ddaac..4e7350609b3d 100644 --- a/drivers/scsi/pm8001/pm8001_sas.c +++ b/drivers/scsi/pm8001/pm8001_sas.c @@ -645,16 +645,8 @@ static int pm8001_dev_found_notify(struct domain_device *dev) pm8001_device->dcompletion = &completion; if (parent_dev && dev_is_expander(parent_dev->dev_type)) { int phy_id; - struct ex_phy *phy; - for (phy_id = 0; phy_id < parent_dev->ex_dev.num_phys; - phy_id++) { - phy = &parent_dev->ex_dev.ex_phy[phy_id]; - if (SAS_ADDR(phy->attached_sas_addr) - == SAS_ADDR(dev->sas_addr)) { - pm8001_device->attached_phy = phy_id; - break; - } - } + + phy_id = sas_find_attathed_phy(&parent_dev->ex_dev, dev); if (phy_id == parent_dev->ex_dev.num_phys) { pm8001_dbg(pm8001_ha, FAIL, "Error: no attached dev:%016llx at ex:%016llx.\n", @@ -662,6 +654,7 @@ static int pm8001_dev_found_notify(struct domain_device *dev) SAS_ADDR(parent_dev->sas_addr)); res = -1; } + pm8001_device->attached_phy = phy_id; } else { if (dev->dev_type == SAS_SATA_DEV) { pm8001_device->attached_phy = So I wonder if you have any reasons to insist exporting the helper? > > Thanks, > John > >>           phy_id++) { >>               phy = &parent_dev->ex_dev.ex_phy[phy_id]; >> -            if (SAS_ADDR(phy->attached_sas_addr) >> -                == SAS_ADDR(dev->sas_addr)) { >> +            if (dev_and_phy_addr_same(dev, phy)) { >>                   pm8001_device->attached_phy = phy_id; >>                   break; >>               } > > .