Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp3894478ybv; Tue, 25 Feb 2020 09:11:23 -0800 (PST) X-Google-Smtp-Source: APXvYqxGZ0SYrQl2VFFVtW/hPiT1TCX1GKkbDO2loU1f0+NydGtCvT7zxlOhxrgp9elFkuLVPjQ/ X-Received: by 2002:aca:c256:: with SMTP id s83mr4494596oif.57.1582650683450; Tue, 25 Feb 2020 09:11:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582650683; cv=none; d=google.com; s=arc-20160816; b=bkWoKN9VQ6mOExKt1dPdSifys5rUgKvDAHoCbaXDjnw466Ompko1Xjsny5Rtg/0c4K Onrc11SeNakTIOob3qBZYVVpmKVhqBS/wenWgUFnd3vSf0JdOwHp3dI/hZHg46SWMDDq mLQGo1w82OJy2yjeT5XNVyowSqODv7Wq9mRVJkL6cQeQRX1N+gvdyf47E7nNBre46jkH sb23ohcqygYGKOSSaGW4gAQI5w6BWgl2tNKsL5yKX/iRC2E+Il5XwlFitVVGSMpm+H8I cMKPdKUjVnLYIvb4rl73R/V+L9KHkND2VHWIFyWpnT7JBZ4xP4GhiGLHwBxg0gdyu501 ZNmw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=+Ck3WWjhHxrBS9PLlazo497Erax7IVO/Sezp5Usx9Ug=; b=gtGOMJcR1wJJZSsVmtedR3GhNXCqWBttMk0DEEvednqZ0pRs+1C8LDzN6Gf4c3S4lR EGVG1MVhIbo2nDo77s+Cfv4scAdWpTU3t7jpHFy/O6rWnS1E/gEiD0a0iY12ZgwNnSym Nf5b4KvejJRq+yw/VukMYloGSuRpQNArFkJ+ndgh7S0scUNwf8VU+VT7M1oTqin+dEWM B70fjdahd0312IH/26KUhQ3fEqGJuT52TifTI+Jt2YxE2V/iMkFkxSsyJQI5R/pMlhPs DLDhysso1oIh+UcID/S2q44bxBoQ28+Mk2rMOQW+YEQROWhVxowLXpLQ0N8oRL3X+g/L B3mw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q5si8012678otc.104.2020.02.25.09.11.11; Tue, 25 Feb 2020 09:11:23 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731207AbgBYQpz (ORCPT + 99 others); Tue, 25 Feb 2020 11:45:55 -0500 Received: from hostingweb31-40.netsons.net ([89.40.174.40]:41069 "EHLO hostingweb31-40.netsons.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731203AbgBYQpy (ORCPT ); Tue, 25 Feb 2020 11:45:54 -0500 Received: from [109.168.11.45] (port=37076 helo=pc-ceresoli.dev.aim) by hostingweb31.netsons.net with esmtpa (Exim 4.92) (envelope-from ) id 1j6dLD-00DPYO-Q0; Tue, 25 Feb 2020 17:45:51 +0100 From: Luca Ceresoli To: devicetree@vger.kernel.org, Geert Uytterhoeven Cc: Pantelis Antoniou , Frank Rowand , Rob Herring , linux-kernel@vger.kernel.org, Luca Ceresoli , Geert Uytterhoeven Subject: [PATCH v2] of: overlay: log the error cause on resolver failure Date: Tue, 25 Feb 2020 17:45:40 +0100 Message-Id: <20200225164540.4520-1-luca@lucaceresoli.net> X-Mailer: git-send-email 2.25.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-AntiAbuse: This header was added to track abuse, please include it with any abuse report X-AntiAbuse: Primary Hostname - hostingweb31.netsons.net X-AntiAbuse: Original Domain - vger.kernel.org X-AntiAbuse: Originator/Caller UID/GID - [47 12] / [47 12] X-AntiAbuse: Sender Address Domain - lucaceresoli.net X-Get-Message-Sender-Via: hostingweb31.netsons.net: authenticated_id: luca+lucaceresoli.net/only user confirmed/virtual account not confirmed X-Authenticated-Sender: hostingweb31.netsons.net: luca@lucaceresoli.net X-Source: X-Source-Args: X-Source-Dir: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org For some of its error paths, of_resolve_phandles() only logs a very generic error which does not help much in finding the origin of the problem: OF: resolver: overlay phandle fixup failed: -22 Add error messages for all the error paths that don't have one. Now a specific message is always emitted, thus also remove the generic catch-all message emitted before returning. For example, in case a DT overlay has a fixup node that is not present in the base DT __symbols__, this error is now logged: OF: resolver: node gpio9 not found in base DT, fixup failed Signed-off-by: Luca Ceresoli Cc: Geert Uytterhoeven --- I don't know in detail the meaning of the adjust_local_phandle_references() and update_usages_of_a_phandle_reference() error paths, thus I have put pretty generic messages. Any suggestion on better wording would be welcome. Changed in v2: - add a message for each error path that does not have one yet --- drivers/of/resolver.c | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/drivers/of/resolver.c b/drivers/of/resolver.c index 83c766233181..a80d673621bc 100644 --- a/drivers/of/resolver.c +++ b/drivers/of/resolver.c @@ -291,8 +291,10 @@ int of_resolve_phandles(struct device_node *overlay) break; err = adjust_local_phandle_references(local_fixups, overlay, phandle_delta); - if (err) + if (err) { + pr_err("cannot adjust local phandle references\n"); goto out; + } overlay_fixups = NULL; @@ -321,11 +323,15 @@ int of_resolve_phandles(struct device_node *overlay) err = of_property_read_string(tree_symbols, prop->name, &refpath); - if (err) + if (err) { + pr_err("node %s not found in base DT, fixup failed\n", + prop->name); goto out; + } refnode = of_find_node_by_path(refpath); if (!refnode) { + pr_err("cannot find node for %s\n", refpath); err = -ENOENT; goto out; } @@ -334,13 +340,14 @@ int of_resolve_phandles(struct device_node *overlay) of_node_put(refnode); err = update_usages_of_a_phandle_reference(overlay, prop, phandle); - if (err) + if (err) { + pr_err("cannot update usages of a phandle reference (%s)\n", + prop->name); break; + } } out: - if (err) - pr_err("overlay phandle fixup failed: %d\n", err); of_node_put(tree_symbols); return err; -- 2.25.0