Received: by 10.223.185.116 with SMTP id b49csp3406525wrg; Sun, 18 Feb 2018 22:31:38 -0800 (PST) X-Google-Smtp-Source: AH8x227ZrUR9lk26pY8ioCtHdfR7Z2Gl3O9nWirgPgh7MWTzxMI13TUOkP4eRQ+snzu0PAN/vlG7 X-Received: by 10.101.76.78 with SMTP id l14mr11367926pgr.336.1519021898403; Sun, 18 Feb 2018 22:31:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519021898; cv=none; d=google.com; s=arc-20160816; b=wO8qOymxv5COXJUL7wAUYnEKfm/20ZziH8bvgEyAOTpBrKagy45RbNnG+Ct3TtzIc6 S5DJ3eguYS18Bzd5DDuk0TpmwYhE/u7GYm5KjHBJ9k0ivQEx6yhCLZEutV97u0gpTPcc APJi2HiuUoSNwupkyglSPlH98LumdLkGAe89kUaTtH0NEyDMGmk5p327wEQtVnDA6Ehw pSi01njGxaT+N6W6Mk8VazRl7WpPdEHvbdaGc0gp/h43Zb3iLxp54t9xcVDlD2MGngVK 3BT6Qv3iXsP2N7wYBom40LrePsumP0Fv+H4HKVH4eazMy7xUPh4xRZpXzw6eajNPjypt oW0A== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=hTvvoCdOtLO2//ltuMj/iak7f8mfc5STil6XiEXojGc=; b=jWthoAz2ZSXNybsui2YBKhdP7UbMvIEqJeXzQWWlVIJ7TtvBqUjwpNDjQR3IgkgVOk 2r9kOHoU2Gp2uEttfQuvVA2yqBbmSyci4PzbUFnhZzd86EnHdxsa3ZZBgsSv2oEokSWq 4zHskHYOGu3xvvnKRRPtocKwj9OuakKXqiTKMCW3tZgE5onOOjBgWKEBfGzdyEzyIETs SbVEGSgh8wSeo4LySSLih3oFxlYonLPbLzQGhS1Ekc7R6/BsL2uvKsyrOu5b5L58ThcF D+AIucC20My18XNFl2ZzKBaXtx0dsIUXG5x5NRE+UzJqdZUteH8/54QNQyUiXBrhYtMf JhMA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=pseW7Q69; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c16-v6si2495322pli.330.2018.02.18.22.31.23; Sun, 18 Feb 2018 22:31:38 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=pseW7Q69; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751406AbeBSGao (ORCPT + 99 others); Mon, 19 Feb 2018 01:30:44 -0500 Received: from mail-io0-f196.google.com ([209.85.223.196]:42992 "EHLO mail-io0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750988AbeBSGan (ORCPT ); Mon, 19 Feb 2018 01:30:43 -0500 Received: by mail-io0-f196.google.com with SMTP id u84so10194283iod.9; Sun, 18 Feb 2018 22:30:42 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=hTvvoCdOtLO2//ltuMj/iak7f8mfc5STil6XiEXojGc=; b=pseW7Q69552gRvGXzVRkJKBiTj51qv26Y+w098BuvPUamYQOVrWhQnJPTC+TF+fcYa Ibg9dxHXAQC+Ln76UnhyJqZhNnEHD+4PnFVt9Gu326ZFBxBfVXK8E5xuncdJPDe6gs0W +8/eq25Fk4fOLvC+ceLS/bbJzSWIVKN3t7nbObbw98WDgeN7xgbnO2C0pMD8/Wj+CjrH 3MKZa5ByiuPSSrcd9s2pgg+liJxF49aJYdWcI2yHRJWkoyvbwhUbqVN211Mg9KlTF8Gj hrOAt9Vkb3qcRJOgnqzzKR8hlfC8mg8qXgxNlzB2Y+VtVQs1BtB9MCBcKt0YO7S2VGjJ i+GQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=hTvvoCdOtLO2//ltuMj/iak7f8mfc5STil6XiEXojGc=; b=EdmxHxm0i6Xf4vJjnFSAXb07Xw/zeSWrN/T0qb2Lr0S6krl9YaB81cBHZEtVVzGAx8 02jSXwglj3j3vIAXWHd+2L2+757kCwylCfVRBXLMmf/ZYti9nkUgATciB/4IrL4/WvUh OYy6DSzAf4q6Sx2LiJYzpTo6koNzsP9Da63FHdTBOgg2FMp7ifRBa0GYgNQh3hW07Avn xjdYKOA1qv6ucpmFqW4JOkl1aAcWOttCne8NL3gTu8lVHb78ahrtXIH23vRslJwxrjua M6fjkw4I8gUbf1vUNqA+9nKetWGNHq6DAjiRFJ+HFPe0G31fTNT255igOmizy/fXyZIS JvLw== X-Gm-Message-State: APf1xPA5D8FlOKQNHMDa63uE9MyBJJwOr2knfeq3bFgZN2Guc25OZ2Wd LBPPBCmD9C9wrYr3iCVNIx8= X-Received: by 10.107.12.213 with SMTP id 82mr12132476iom.48.1519021842260; Sun, 18 Feb 2018 22:30:42 -0800 (PST) Received: from [192.168.1.70] (c-73-93-215-6.hsd1.ca.comcast.net. [73.93.215.6]) by smtp.gmail.com with ESMTPSA id f204sm950313itc.40.2018.02.18.22.30.40 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sun, 18 Feb 2018 22:30:41 -0800 (PST) Subject: Re: [PATCH v3 4/4] of: improve reporting invalid overlay target path To: Rob Herring Cc: pantelis.antoniou@konsulko.com, Pantelis Antoniou , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, geert@linux-m68k.org References: <1518672946-7310-1-git-send-email-frowand.list@gmail.com> <1518672946-7310-5-git-send-email-frowand.list@gmail.com> <20180219032141.lapcr32f4zqulvvb@rob-hp-laptop> From: Frank Rowand Message-ID: Date: Sun, 18 Feb 2018 22:30:40 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <20180219032141.lapcr32f4zqulvvb@rob-hp-laptop> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/18/18 19:21, Rob Herring wrote: > On Wed, Feb 14, 2018 at 09:35:46PM -0800, frowand.list@gmail.com wrote: >> From: Frank Rowand >> >> Errors while developing the patch to create of_overlay_fdt_apply() >> exposed inadequate error messages to debug problems when overlay >> devicetree fragment nodes contain an invalid target path. Improve >> the messages in find_target_node() to remedy this. >> >> Signed-off-by: Frank Rowand >> --- >> >> changes from v2: >> - add fragment node name as suggested by Geert >> - existing error message printed short node name, thus not >> discriminating between fragments; change to full node name >> - existing error message printed node address, which is devicetree >> internal debugging, not useful in an overlay apply error message; >> remove node address from message >> >> drivers/of/overlay.c | 22 ++++++++++++++++------ >> 1 file changed, 16 insertions(+), 6 deletions(-) >> >> diff --git a/drivers/of/overlay.c b/drivers/of/overlay.c >> index 5f6c5569e97d..852e566d7744 100644 >> --- a/drivers/of/overlay.c >> +++ b/drivers/of/overlay.c >> @@ -488,20 +488,30 @@ static int build_changeset(struct overlay_changeset *ovcs) >> */ >> static struct device_node *find_target_node(struct device_node *info_node) >> { >> + struct device_node *node; >> const char *path; >> u32 val; >> int ret; >> >> ret = of_property_read_u32(info_node, "target", &val); >> - if (!ret) >> - return of_find_node_by_phandle(val); >> + if (!ret) { >> + node = of_find_node_by_phandle(val); >> + if (!node) >> + pr_err("find target, node: %pOF, phandle 0x%x not found\n", > > I'm wondering if the core should print the error rather than having all > the callers do it. The question is whether there are cases where failing > is okay? I guess sometimes we use 0 to skip cells, but the core handle > not printing an error in that case. find_target_node() is overlay specific, and is only called from one location in overlay.c. There are no cases where failing is ok. This is used to find the target node that an overlay fragment is being applied to. If it fails then either the base devicetree or the overlay devicetree has an error. -Frank > Rob > >> + info_node, val); >> + return node; >> + } >> >> ret = of_property_read_string(info_node, "target-path", &path); >> - if (!ret) >> - return of_find_node_by_path(path); >> + if (!ret) { >> + node = of_find_node_by_path(path); >> + if (!node) >> + pr_err("find target, node: %pOF, path '%s' not found\n", >> + info_node, path); >> + return node; >> + } >> >> - pr_err("Failed to find target for node %p (%s)\n", >> - info_node, info_node->name); >> + pr_err("find target, node: %pOF, no target property\n", info_node); >> >> return NULL; >> } >> -- >> Frank Rowand >> >