Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp775191rwb; Fri, 23 Sep 2022 04:07:20 -0700 (PDT) X-Google-Smtp-Source: AMsMyM4iHkhi4daITKgOa9lmEW48Fj9PxaiB7kOGGkFQnnL+5fvfhCaawHzz5/oQ5+xu1sDUgJKc X-Received: by 2002:a05:6a00:16d6:b0:53b:3e58:1c6f with SMTP id l22-20020a056a0016d600b0053b3e581c6fmr8563209pfc.7.1663931239739; Fri, 23 Sep 2022 04:07:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663931239; cv=none; d=google.com; s=arc-20160816; b=y52LR6nPS9g8Bfo2sB+sWnjoYM2b5JVJ1ADsUEfWQKKNPozS9b3ocKf1iqiCGn7+Yj RZtvZmnAUZreoF1CH7yBB3xevnai4q68GpSUhxMIuZeods1A8895umhDrwPQy9Vq9K/B pzKT/WHgrBekgy0skXuVLWs42+M+XyHQ0DRVKjcdfrH31kIW5OzQxpbVZMfr+uq1cRSN oaqC7Nm/V9yI1wehqT9NeJWydsj+zMxcAD2JeDum9iBFj7xaWFEzlkWzidYK2XB5cMkt O9Mi5zDBAO/YAUHF/A2gBy5CcrRblG3DAFaAy9wCcGH0rEJLoqJHz9d2vOqKkLZ9M8Ev 29Ow== 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=RKMDuSQIpsg34J0L1cQa8KOO0OQJWYxPXf+i1Pb6+mc=; b=HJNFgq41/BcyFg6DMk4+YC0i3oaooo30HhZ8A6oI42Rh6F/0VIfAr7GNsOpNARkMkJ 7lI3uP1Y/YxLpB6nv/aMMBJNcN1Cww5lk4tl4O1CUc58+SeRgpBcCXhtZPtA16nv/dm8 6yvMnzWcmPmOAviPgB9ES7QbeRSpL1SNU3zqI4UVjkR0R2YLciT3Q5eNVZaQUVs9kiV7 +WnT8YiB07b+TowDbLRxXzGGfgQ2eGWSwDF5VTCSpFE9NlkqBvppTf/i1HR9TQel+mYG s4Yz8xUcur9ZZo0PXDDIlSL/Ifi+ppREUYZOVL1R7QS+/hp66ODAhOBYp+tyE4Lw9/FS IODw== 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 f14-20020aa782ce000000b0054a22e82eaesi8547148pfn.301.2022.09.23.04.07.07; Fri, 23 Sep 2022 04:07:19 -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 S231199AbiIWKNw (ORCPT + 99 others); Fri, 23 Sep 2022 06:13:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57052 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231970AbiIWKNk (ORCPT ); Fri, 23 Sep 2022 06:13:40 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1E652128710; Fri, 23 Sep 2022 03:13:38 -0700 (PDT) Received: from canpemm500004.china.huawei.com (unknown [172.30.72.56]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4MYntD5JZqzMmxq; Fri, 23 Sep 2022 18:08:52 +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 18:13:35 +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> <3c1aa262-7e9b-cb6c-e8a1-a1a201050a10@huawei.com> <6c299e8f-80be-0276-c8b1-9df1946434da@huawei.com> From: Jason Yan Message-ID: Date: Fri, 23 Sep 2022 18:13:35 +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: <6c299e8f-80be-0276-c8b1-9df1946434da@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/23 18:00, John Garry wrote: > On 23/09/2022 10:44, Jason Yan wrote: >>>>           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. > > Please explain why. > > I would assume that if those helpers were only used in libsas code (and > not LLDDs) then they could be put in sas_internal.h and no need for export > Sorry, I did not make it clear. I mean we need to export sas_find_attathed_phy() below. Not the sas address comparation helpers. >> 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; > > I will note that this code does not use your new helpers > >> +} >> + >>   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 > .