Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp1403811rdb; Wed, 20 Sep 2023 08:13:12 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHESYSkrHjSzxr+ilClqROz5xXI7y0y0ypQI7WQKRa2C/+IkHhW0HNuezi3GQKp3/MhzRbX X-Received: by 2002:a17:902:e744:b0:1c0:bf60:ba82 with SMTP id p4-20020a170902e74400b001c0bf60ba82mr2674934plf.5.1695222791757; Wed, 20 Sep 2023 08:13:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695222791; cv=none; d=google.com; s=arc-20160816; b=gBf/V8HHkUPcroV7iHt1sANVbWIzbk5slbwNmfHrMMu+h03tgkBKR0EYjm3rYn3XRc iXRObm5SYRB+UKX2Hw7buw7DBVV30sHAIoZPFkue0FFM4L/eG+mhBu6eAKYRnY0y/Fsw 8Pb0q0+g1CkwxLLDOUjmN56OtCpzEj7oxOJN/MOKW647RTNoTCJe46PsWKt7sy5UsqVE YrATgdrEkiFpV5c2YxyWvPkMdx1AO60mQIR8/xftlQHb7Ya2jT5IaapIJt6WQ6FwG+5V 0+5kq8+ne0vo7NzFEgCptuRZqQsQVzVP7NIhesOVEVG5dGTtq2fUwCc4MLHkLIWqrkR+ jg+A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=B8K5uU0lKh0mV9Am5xWE11xtP+nMtPYplAMywyoy+go=; fh=YGhRoq/7/InVpQBap66vnvhuW4I9osP5INz2nPlZcT8=; b=f4lycv42K8+8lyb3YAdSUF5weviPpqBpUiQBs6D1thwUpV4vENAwybAJEJEGh8YkVj L67qhMBB6+KduPT9sbZMUtW7ZfHZTCjROskRhtLHbt7/s89uzP+CPiyWPCicuda527Cv PreyvHA6tkBGph9oAhftAssx0xS+BkOc97PgUMV6uY0AM+5d5KS0Rp/h1xE3PPzciY/4 WVqzf9mtgO+R4HjT1H/IYtxnMD04dbO9k9bQXqu37QUmFwZYM+A6c/ZZYv76QloMERCa Y2m6qw0yttrvaRlK7iv7GHnqMZRAR+KkEslMoQ5X3eXdVUJhtSsDlDWZZjBFY+aIBxTw lnwQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=igMB+AMi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Return-Path: Received: from howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id f9-20020a170902684900b001bbdd44bbd0si11626581pln.176.2023.09.20.08.13.10 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 20 Sep 2023 08:13:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=igMB+AMi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id 6D34F8022A8F; Wed, 20 Sep 2023 07:03:30 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236533AbjITOD2 (ORCPT + 99 others); Wed, 20 Sep 2023 10:03:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43366 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236587AbjITODX (ORCPT ); Wed, 20 Sep 2023 10:03:23 -0400 Received: from madras.collabora.co.uk (madras.collabora.co.uk [IPv6:2a00:1098:0:82:1000:25:2eeb:e5ab]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4BC8BB9; Wed, 20 Sep 2023 07:03:13 -0700 (PDT) Received: from notapiano (unknown [IPv6:2600:4041:5b1a:cd00:524d:e95d:1a9c:492a]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-256) server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) (Authenticated sender: nfraprado) by madras.collabora.co.uk (Postfix) with ESMTPSA id 8A6936607201; Wed, 20 Sep 2023 15:03:10 +0100 (BST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1695218591; bh=0As1l5pUnNWGSkzZabr2JsNuZssFSpilRQkjdz8AJ1k=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=igMB+AMiayEFp612LIiv/IJGUNWjv/yfNcI67RWl3fmXUEAusqwBRIlxTDEnn2i74 okinKpYzPipz6KpaHM6vvNcdzoEXqnTJ2BgQiVicY1/H3HXJHGjSAysNjpxU7HhdCs F5ZGEAKOmET+xH7LYlgwLFAJMwlcvTf/KRpwxU2fn4JmBJ5QOlVGdMJrEJoPX7bOvB twcnEEonoCMblVmogccUDxSIVxOChfpO4MI6qbNxW0kQh0YGDbPdJRKLlZxhsddiz6 ZMNqYv8Rg1RsUg86xJu1pzQnOcJAVnrGWtuFpq4W0DC1i2LZFeNKUErHFMEZd6klRr Efc5V3eD7jPiw== Date: Wed, 20 Sep 2023 10:03:06 -0400 From: =?utf-8?B?TsOtY29sYXMgRi4gUi4gQS4=?= Prado To: Rob Herring , Frank Rowand , Shuah Khan Cc: Mark Brown , kernelci@lists.linux.dev, kernel@collabora.com, Guenter Roeck , Bjorn Andersson , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org Subject: Re: [PATCH v3 0/3] Add a test to catch unprobed Devicetree devices Message-ID: <97c368a1-9c76-490a-848e-eacd6411e810@notapiano> References: <20230828211424.2964562-1-nfraprado@collabora.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20230828211424.2964562-1-nfraprado@collabora.com> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_BLOCKED, 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 X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (howler.vger.email [0.0.0.0]); Wed, 20 Sep 2023 07:03:30 -0700 (PDT) On Mon, Aug 28, 2023 at 05:13:09PM -0400, N?colas F. R. A. Prado wrote: > > Regressions that cause a device to no longer be probed by a driver can > have a big impact on the platform's functionality, and despite being > relatively common there isn't currently any generic test to detect them. > As an example, bootrr [1] does test for device probe, but it requires > defining the expected probed devices for each platform. > > Given that the Devicetree already provides a static description of > devices on the system, it is a good basis for building such a test on > top. > > This series introduces a test to catch regressions that prevent devices > from probing. > > Patches 1 and 2 extend the existing dt-extract-compatibles to be able to > output only the compatibles that can be expected to match a Devicetree > node to a driver. Patch 2 adds a kselftest that walks over the > Devicetree nodes on the current platform and compares the compatibles to > the ones on the list, and on an ignore list, to point out devices that > failed to be probed. > > A compatible list is needed because not all compatibles that can show up > in a Devicetree node can be used to match to a driver, for example the > code for that compatible might use "OF_DECLARE" type macros and avoid > the driver framework, or the node might be controlled by a driver that > was bound to a different node. > > An ignore list is needed for the few cases where it's common for a > driver to match a device but not probe, like for the "simple-mfd" > compatible, where the driver only probes if that compatible is the > node's first compatible. > > The reason for parsing the kernel source instead of relying on > information exposed by the kernel at runtime (say, looking at modaliases > or introducing some other mechanism), is to be able to catch issues > where a config was renamed or a driver moved across configs, and the > .config used by the kernel not updated accordingly. We need to parse the > source to find all compatibles present in the kernel independent of the > current config being run. > > [1] https://github.com/kernelci/bootrr > > Changes in v3: > - Added DT selftest path to MAINTAINERS > - Enabled device probe test for nodes with 'status = "ok"' > - Added pass/fail/skip totals to end of test output > > Changes in v2: > - Extended dt-extract-compatibles script to be able to extract driver > matching compatibles, instead of adding a new one in Coccinelle > - Made kselftest output in the KTAP format > > N?colas F. R. A. Prado (3): > dt: dt-extract-compatibles: Handle cfile arguments in generator > function > dt: dt-extract-compatibles: Add flag for driver matching compatibles > kselftest: Add new test for detecting unprobed Devicetree devices > > MAINTAINERS | 1 + > scripts/dtc/dt-extract-compatibles | 74 +++++++++++++---- > tools/testing/selftests/Makefile | 1 + > tools/testing/selftests/dt/.gitignore | 1 + > tools/testing/selftests/dt/Makefile | 21 +++++ > .../selftests/dt/compatible_ignore_list | 1 + > tools/testing/selftests/dt/ktap_helpers.sh | 70 ++++++++++++++++ > .../selftests/dt/test_unprobed_devices.sh | 83 +++++++++++++++++++ > 8 files changed, 236 insertions(+), 16 deletions(-) > create mode 100644 tools/testing/selftests/dt/.gitignore > create mode 100644 tools/testing/selftests/dt/Makefile > create mode 100644 tools/testing/selftests/dt/compatible_ignore_list > create mode 100644 tools/testing/selftests/dt/ktap_helpers.sh > create mode 100755 tools/testing/selftests/dt/test_unprobed_devices.sh Hi Rob, gentle ping on this series. I take it you'll be merging this through your tree, so I've added Shuah's R-b that she supplied on v2 for the kselftest patch. Thanks, N?colas