Received: by 2002:a05:6359:6284:b0:131:369:b2a3 with SMTP id se4csp2901197rwb; Mon, 7 Aug 2023 05:29:30 -0700 (PDT) X-Google-Smtp-Source: AGHT+IF67VUvzWHOd1SMc50hW2EPimvqiSGVSejsjIlkekO6FoAHqOqbM3XjAhtSalaNHDzxD9yT X-Received: by 2002:a05:6a00:2e20:b0:687:4fcf:8fcd with SMTP id fc32-20020a056a002e2000b006874fcf8fcdmr9088845pfb.18.1691411369959; Mon, 07 Aug 2023 05:29:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691411369; cv=none; d=google.com; s=arc-20160816; b=g4HRRDZo5o4FM7fQgAq1ecr8+1d23lBwFmDMHNV1sG/vhVv6jXk97Bvzg1PXsXjjhn D51zpOwN0bVA0tWJyd2NeVFH3ORKtX96SE8scBSpjL16F9c9avQ/C2EFEJQIawVAlstv LDxg3tEA8OycF9ynGsQN2Ecd2Z6RBpajpt9Bk7MAUkyQ2cD4AEXfQYkp8+MqvvEJhT9i XYwolmgr5Bhjoee8rM+28OqTUE1AbCeJSYKR7O30MtYsfHakmUJMNeCR/WxSnAQpRPZg U5weK/gAN8BoW9TCq/5JaCv3V3q9a/cvDjP/pIGR+o/6my2pv/ziziw99ENPQLr/E/Vz zOow== 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:subject:user-agent:mime-version:date:message-id; bh=Q8XntDGiwONg4GOZ+tsCfTwPik+MI7rYNB1fMNpUVvY=; fh=XMDh11FGkFxPL8aai5YYSXPhUasHrfon5kK6ORJJwLI=; b=ZLyOnZSaMbmZ8knZYF6jJZIhvIgzGaPnTTY4m7G1unFyQgJLsQSyKgV7RZCe2ZG1RQ Q29XZHLS/gYxXoh+HO+0kRsxIbngsH2VRoVMhKWxMSiNTF5khX8irKpHkCpFvRzoITZU S7BUJxxKjh/gMvAEJrEIQQx16bixrndqvQExdjQyLE6aLMGlEfsDuIqi/PvUlAEjIlIe 0+ImKZfq+VZKMsY+THltNmI74olpQ5t8IHzVv3C0RbbuYMCQiUfEDAH1HZ4dhPQ6i/fE J3xgaxZJHZP9ocB7dCVxb826IFK6zPoUUH97V4fkw/ENvlet7+OEYRGyESG0HTwveOPI vQZA== 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 l191-20020a6388c8000000b00563b0cbe80dsi5467480pgd.877.2023.08.07.05.29.17; Mon, 07 Aug 2023 05:29:29 -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 S232715AbjHGLlo (ORCPT + 99 others); Mon, 7 Aug 2023 07:41:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46430 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232825AbjHGLlc (ORCPT ); Mon, 7 Aug 2023 07:41:32 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 5304F46BA for ; Mon, 7 Aug 2023 04:38:38 -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 578BA1FB; Mon, 7 Aug 2023 04:38:12 -0700 (PDT) Received: from [10.57.90.63] (unknown [10.57.90.63]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id A82633F59C; Mon, 7 Aug 2023 04:37:27 -0700 (PDT) Message-ID: <177702e7-e68f-fa7a-4507-48dc82fcc030@arm.com> Date: Mon, 7 Aug 2023 12:37:26 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.13.0 Subject: Re: [PATCH V3 4/4] coresight: trbe: Enable ACPI based TRBE devices To: Anshuman Khandual , 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> From: Suzuki K Poulose In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed 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 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 ? Suzuki