Received: by 2002:a05:6359:6284:b0:131:369:b2a3 with SMTP id se4csp2556719rwb; Sun, 6 Aug 2023 22:22:20 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFp9qcu3AcHx8Z6rAnV9MeRUjykwoc7vm+hWKfW5KiHIl8HsFMSZPL2lFROOaij8OQkv0Cp X-Received: by 2002:a17:907:a072:b0:99b:ea9d:61c9 with SMTP id ia18-20020a170907a07200b0099bea9d61c9mr6651481ejc.57.1691385740032; Sun, 06 Aug 2023 22:22:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691385740; cv=none; d=google.com; s=arc-20160816; b=y9JMlymbNpGizjBL7789RsenCpJ279DIJ+HjunfG8YneQVhI1SdEfjv3hezQ+l1fEc 32a15nKC6tAEQsdpaB22V1TvFyCn3mV245KkecrxvVg7z4lC6c18f2oJMO5rDebv2fUK 0Fvkv6JzJxHDhQ0IajfkI3XFmZ2rhRUEiZgdErvQAKSW7uI1F193fFI6zngXQo+idIto 2jO63Ukh0vboBMM8/Kij8gYy18d26OWiCJgow4OZ0CWwdN85SbkwHK10OVamyvc5lSwB NIMUkM77LDLkRVzRsvkBJ5AxPHxS7Jc8mkXrKmc7ZPvPepRzsw5MRWRRh5ieutoYRfio 9nlg== 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=cCwO/OYRkOoqE7MmVPCBy7tF3JFfrHf6DleKWXiAI+0=; fh=/KCV9oQbsuUi1vojoVWdg0W6hteTqLOeIyLuLbjAJwE=; b=nTvQG8bh+BOCPU7LWou40oC6LZaJ4ZVYNlC5zIw83YytKGYzMr8UnnswI8pEDO4gDG fk2UEL894RaePaVIgNavU761YIZWFh2FSCjUeG7rAG+Z6EIH0HGtpNuq2qvFOvI6ajWa ETP6Z4fIwhbNhVF82dTFVv3kvio7NZGhAJ8a0sH+a3JU2qp/vnIQ25E5XuRp0nNfJFyP M9CSUM4CMsid3jVsAxBzlNMhp22hLV4kUAgSp6ZDEbw0CXpYcnKxrSESiK+qAg/rU4it zdpvgLhp7koNatzghmYYJtEKVd6R8GOsV3VkwLoMR9ir+WxncDnZWJm5xCP94rku3NZu xYOA== 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 ec3-20020a170906b6c300b0099b4e5359besi5623718ejb.4.2023.08.06.22.21.56; Sun, 06 Aug 2023 22:22:20 -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 S229907AbjHGEnT (ORCPT + 99 others); Mon, 7 Aug 2023 00:43:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38172 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229513AbjHGEnS (ORCPT ); Mon, 7 Aug 2023 00:43:18 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 8954810FA for ; Sun, 6 Aug 2023 21:43:16 -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 EA2031FB; Sun, 6 Aug 2023 21:43:58 -0700 (PDT) Received: from [10.162.41.6] (a077893.blr.arm.com [10.162.41.6]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 114EE3F59C; Sun, 6 Aug 2023 21:43:11 -0700 (PDT) Message-ID: Date: Mon, 7 Aug 2023 10:13:08 +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: linux-arm-kernel@lists.infradead.org, suzuki.poulose@arm.com 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> From: Anshuman Khandual In-Reply-To: <20230803055652.1322801-5-anshuman.khandual@arm.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-8.3 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/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), .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 #include #include #include [1] https://lore.kernel.org/all/202308052123.uqR35d19-lkp@intel.com/ > .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 77cbb5c63878..94e67009848a 100644 > --- a/drivers/hwtracing/coresight/coresight-trbe.h > +++ b/drivers/hwtracing/coresight/coresight-trbe.h > @@ -12,6 +12,7 @@ > #include > #include > #include > +#include > #include > #include >