Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp732383rwb; Fri, 23 Sep 2022 03:28:09 -0700 (PDT) X-Google-Smtp-Source: AMsMyM7C3CBDzhbzjU2eTSm5fzAC8WLMwv46+JJtTEOA6lpHm5HFn6VdDtf4eKB6BfuqR+7FYeas X-Received: by 2002:a05:6402:4411:b0:437:b723:72 with SMTP id y17-20020a056402441100b00437b7230072mr7963420eda.38.1663928889603; Fri, 23 Sep 2022 03:28:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663928889; cv=none; d=google.com; s=arc-20160816; b=AuIjYPCcEWcgSrMhpopG6VjAzL5t5uVLopa/Yeh+MG9gAdZJ7YiE2sQLlPqlzyrXs2 Bv3a9PDvlFgY6nda9a7RruAln4QgI/AZp5X4SbguCn2WNmciFlNytSKNl5c7PEDZ32Bv R04UDTBUfo87ExAiHR89uwbBTQDxjxxYgFC6Y50OhtGTWA7R8QhONO4Mn25AKpazfU2Y Ja7Hzv7bP2AgmmPfrxz4th08J1DaV82tr2zu+Qis0WAVBaUgIbzcccUh/YSUrrAtP8NO Mj3mnZRO8WEyYUFOcPXB1W9jL2sW1ddTAWxqvlGobTpsMwmqUy1OuUdLXCeRQTqHk0FF eplg== 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=kRehqAXSlVJY4hUdBIi16/tSKLw0pNibWNyvKUQWLVM=; b=JteD8+tUgSQPyr+qu2v+PUNnluQRqJG3BpweyUObR5cBOoIGmX0UlMjBhG/FCD9uG0 3bJuHG9KpjDn0daCgngtlquB+JNT0rlQxnCT8rdtqwRCvnaDe59HY+Ab3OKE3OI+z34U juJsYWC4RtB4v0tByyruGeci0ZWaKhMGfV42+jBryd8jwgiDBaqpGwn7cP1lgja7CExs e1bDrVnem0Nb3NrunZvqgLsdtuJA+RBwVGauZIls3PuV4xHbnq3UFw/o2i/Oqf8Foc4I jmulvyaeDbUnuw6Taf8DHZKxUUA2soVfOZbScbIQrOC8CF/z1+p5i1VNBdbmKz1Ei7Um 1/ZA== 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 a101-20020a509eee000000b0044e8330487esi6940837edf.264.2022.09.23.03.27.43; Fri, 23 Sep 2022 03:28:09 -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 S230292AbiIWKLR (ORCPT + 99 others); Fri, 23 Sep 2022 06:11:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53392 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232078AbiIWKKt (ORCPT ); Fri, 23 Sep 2022 06:10:49 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4F03C127561; Fri, 23 Sep 2022 03:10:44 -0700 (PDT) Received: from canpemm500004.china.huawei.com (unknown [172.30.72.56]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4MYnqX5WdnzlXNP; Fri, 23 Sep 2022 18:06:32 +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:10:42 +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: <93c7a2e5-60e8-bafc-b35d-60b7d5972b95@huawei.com> Date: Fri, 23 Sep 2022 18:10:41 +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: dggems704-chm.china.huawei.com (10.3.19.181) 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 > >> 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 NO, this code above will use my new helpers.(Unless we skip this part) diff --git a/include/scsi/libsas.h b/include/scsi/libsas.h index 635039557bdb..9283462704f0 100644 --- a/include/scsi/libsas.h +++ b/include/scsi/libsas.h @@ -673,8 +673,7 @@ static inline int sas_find_attathed_phy(struct expander_device *ex_dev, 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)) + if (sas_phy_match_dev_addr(dev, phy)) return phy_id; > >> +} >> + >>   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 > .