Received: by 2002:a05:6359:6284:b0:131:369:b2a3 with SMTP id se4csp2953283rwb; Mon, 7 Aug 2023 06:13:25 -0700 (PDT) X-Google-Smtp-Source: AGHT+IED5cfAOXUVEWOSfTUBVn4Iw7uPqryDGj1UF6ZlSA9HtD/zoexnbpweUUanznn2BhLP6LL7 X-Received: by 2002:a17:90a:8c02:b0:268:def:a322 with SMTP id a2-20020a17090a8c0200b002680defa322mr7157980pjo.9.1691414005381; Mon, 07 Aug 2023 06:13:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691414005; cv=none; d=google.com; s=arc-20160816; b=I3KS+epwK8lRXC212TbFm3onGDdUn12eNbptym3yi0XO6BzMoIY1PT8uOz8pMuRxyY ikSt2saV6vgGHOLOIBA59WkSu9XvzvwVFpYb0dRKtOnCRMXQUEtpEtd7LWF5oIQTTJrd ICON1sTwO6kYOEMLUqVQJ0y5JpTVzsu8I8TpVL/LXYaFPUvtEaxMBU5DBTLaZhdkkD4e cUgdotSa1SKK8JgK0ucUJYX1JgG4rtsPzKfyNfHGyWCccczrhblZ+FXWNdOr5Tgg/Vuw a/hABDGH3/BVJ/UPXGhxXb+1pz+xK7HGPyzzHhV4IYph8yYtdg8MHK6fMdEmDm3Uk8D/ fmuA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=DXXWmSgwI/N+VJPpm0C1KNhvqCT+2lMIovclbLZOXHg=; fh=DlWzJ1Vktw8btz8lbdXciSzFnx2mJzGwiUKrhPpIo84=; b=rjUu09Ao36P+R6371e5kPLaRX75ApBn7jNjkClKVUMZxRSAP12Hj6DawIyZoHN91ht +0jYYhLEL0lGJXZbvcvlvmZaK3JbgJbEzt7j6CR7Q8VGm3B+AcHK82HsuJfz8buzT2V6 T22yxq/g9RHWmbREsQxvJgrIqImPPE79DSu5irQqA6Qu8cp4TD63X2U2uvsdV9heiRw4 UkHnx5ucp0ZHkIhdSi/B4vGLQJZN0U5prxG5hcq4xl3Ma92eF7I4Wm8H60G4uG+//dB3 35TKwnZSnPdw9V0LWd/1a5+WKJedRTT+OEayAMzEVdMcKoTaN3lvyuo0StO9a1VFAEV7 cN6g== 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=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nn18-20020a17090b38d200b00267f1ec6b98si9179877pjb.127.2023.08.07.06.13.13; Mon, 07 Aug 2023 06:13:25 -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=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232988AbjHGL6P (ORCPT + 99 others); Mon, 7 Aug 2023 07:58:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34286 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232925AbjHGL6L (ORCPT ); Mon, 7 Aug 2023 07:58:11 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 17FA7130 for ; Mon, 7 Aug 2023 04:58:10 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 7C0BB1FB; Mon, 7 Aug 2023 04:58:52 -0700 (PDT) Received: from [10.163.52.193] (unknown [10.163.52.193]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id F35973F64C; Mon, 7 Aug 2023 04:58:04 -0700 (PDT) Message-ID: Date: Mon, 7 Aug 2023 17:28:00 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0 Subject: Re: [PATCH V3 4/4] coresight: trbe: Enable ACPI based TRBE devices Content-Language: en-US To: Suzuki K Poulose , linux-arm-kernel@lists.infradead.org Cc: Sami Mujawar , Catalin Marinas , Will Deacon , Mark Rutland , Mike Leach , Leo Yan , Alexander Shishkin , James Clark , coresight@lists.linaro.org, linux-kernel@vger.kernel.org References: <20230803055652.1322801-1-anshuman.khandual@arm.com> <20230803055652.1322801-5-anshuman.khandual@arm.com> <177702e7-e68f-fa7a-4507-48dc82fcc030@arm.com> From: Anshuman Khandual In-Reply-To: <177702e7-e68f-fa7a-4507-48dc82fcc030@arm.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-6.0 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE 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 8/7/23 17:07, Suzuki K Poulose wrote: > On 07/08/2023 05:43, Anshuman Khandual wrote: >> >> >> On 8/3/23 11:26, Anshuman Khandual wrote: >>> This detects and enables ACPI based TRBE devices via the dummy platform >>> device created earlier for this purpose. >>> >>> Cc: Suzuki K Poulose >>> Cc: Mike Leach >>> Cc: Leo Yan >>> Cc: Alexander Shishkin >>> Cc: coresight@lists.linaro.org >>> Cc: linux-arm-kernel@lists.infradead.org >>> Cc: linux-kernel@vger.kernel.org >>> Signed-off-by: Anshuman Khandual >>> --- >>>   drivers/hwtracing/coresight/coresight-trbe.c | 9 +++++++++ >>>   drivers/hwtracing/coresight/coresight-trbe.h | 1 + >>>   2 files changed, 10 insertions(+) >>> >>> diff --git a/drivers/hwtracing/coresight/coresight-trbe.c b/drivers/hwtracing/coresight/coresight-trbe.c >>> index e1d9d06e7725..f884883e9018 100644 >>> --- a/drivers/hwtracing/coresight/coresight-trbe.c >>> +++ b/drivers/hwtracing/coresight/coresight-trbe.c >>> @@ -1537,7 +1537,16 @@ static const struct of_device_id arm_trbe_of_match[] = { >>>   }; >>>   MODULE_DEVICE_TABLE(of, arm_trbe_of_match); >>>   +#ifdef CONFIG_ACPI >>> +static const struct platform_device_id arm_trbe_acpi_match[] = { >>> +    { ARMV8_TRBE_PDEV_NAME, 0 }, >>> +    { } >>> +}; >>> +MODULE_DEVICE_TABLE(platform, arm_trbe_acpi_match); >>> +#endif >>> + >>>   static struct platform_driver arm_trbe_driver = { >>> +    .id_table = arm_trbe_acpi_match, >> >> The build problem [1] reported on the first version of the series still exists >> here i.e arm_trbe_acpi_match is hidden without CONFIG_ACPI. I had assumed that >> CONFIG_CORESIGHT always enables CONFIG_ACPI, which is not the case. Following >> random config (with CONFIG_ACPI=n and CONFIG_CORESIGHT_TRBE=y) easily triggers >> the build problem. >> >> https://download.01.org/0day-ci/archive/20230805/202308052123.uqR35d19-lkp@intel.com/config >> >>   make CROSS_COMPILE=aarch64-linux-gnu- ARCH=arm64 -s -j 128 >> drivers/hwtracing/coresight/coresight-trbe.c:1563:23: error: implicit declaration of function ‘ACPI_PTR’ [-Werror=implicit-function-declaration] >>   1563 |   .acpi_match_table = ACPI_PTR(arm_trbe_acpi_match), >>        |                       ^~~~~~~~ >> drivers/hwtracing/coresight/coresight-trbe.c:1563:32: error: ‘arm_trbe_acpi_match’ undeclared here (not in a function); did you mean ‘arm_trbe_of_match’? >>   1563 |   .acpi_match_table = ACPI_PTR(arm_trbe_acpi_match), >>        |                                ^~~~~~~~~~~~~~~~~~~ >>        |                                arm_trbe_of_match >> >> Following config wrap around fixes the problem. >> >> --- a/drivers/hwtracing/coresight/coresight-trbe.c >> +++ b/drivers/hwtracing/coresight/coresight-trbe.c >> @@ -1557,7 +1557,9 @@ MODULE_DEVICE_TABLE(platform, arm_trbe_acpi_match); >>   #endif >>     static struct platform_driver arm_trbe_driver = { >> +#ifdef CONFIG_ACPI >>          .id_table = arm_trbe_acpi_match, >> +#endif >>          .driver = { >>                  .name = DRVNAME, >>                  .of_match_table = of_match_ptr(arm_trbe_of_match), >> >> Please not that unlike other coresight drivers, TRBE is not using 'acpi_device_id' >> based "acpi_match_table = ACPI_PTR" construct. But regardless, ACPI_PTR() seems to >> be an alternate (probably better) solution as well. >> >> --- a/drivers/hwtracing/coresight/coresight-trbe.c >> +++ b/drivers/hwtracing/coresight/coresight-trbe.c >> @@ -1557,7 +1557,7 @@ MODULE_DEVICE_TABLE(platform, arm_trbe_acpi_match); >>   #endif >>     static struct platform_driver arm_trbe_driver = { >> -       .id_table = arm_trbe_acpi_match, >> +       .id_table = ACPI_PTR(arm_trbe_acpi_match), > > This is preferred. > >>          .driver = { >>                  .name = DRVNAME, >>                  .of_match_table = of_match_ptr(arm_trbe_of_match), >> diff --git a/drivers/hwtracing/coresight/coresight-trbe.h b/drivers/hwtracing/coresight/coresight-trbe.h >> index 94e67009848a..fce1735d5c58 100644 >> --- a/drivers/hwtracing/coresight/coresight-trbe.h >> +++ b/drivers/hwtracing/coresight/coresight-trbe.h >> @@ -7,6 +7,7 @@ >>    * >>    * Author: Anshuman Khandual >>    */ >> +#include > > Shouldn't this be added in trbe.c ? Does trbe.h depend on any ACPI headers ? The convention we have followed till now is all include/linux/ headers required in TRBE driver is included via trbe.h not directly in trbe.c, just followed the same principle this time around for acpi.h and perf/arm_pmu.h as well.