Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp2411419imm; Mon, 16 Jul 2018 07:37:44 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcZLoOhtCkF/h1+KtEYMPVUQQBn5pRQccVBVtoDJWZQlRRGZBnK15pp3MPDWi3XpH/49dNN X-Received: by 2002:a63:8341:: with SMTP id h62-v6mr15278121pge.298.1531751864009; Mon, 16 Jul 2018 07:37:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531751863; cv=none; d=google.com; s=arc-20160816; b=oAz8exKzVY1aWZHeTWYtURfCaRYE6L4olYawurYOj9Zt5Q+F5QSgva+gHQGiI/VpoD /3j4OtYjwqh+1AcYF22jq0AHslzCFmANTQGN3j7kvXFOHl2VRM23bpeFPdVhrshqAZe1 Q8aE6kNpITssssK84m2gFf7lUGqFtFGYf8KuhdBARFToJ++nfwJ0xI4/RcHyW6lohtI7 qBvFF5f3N8bnk3TpMA0/0RDrF1kwUVJfG4M8NFRAWsyYQueKrTprKDAeqZqcaJyk2VGl 0ViC3g5DWGkaGStFSc52a8B/eWpb6dNsxGeZmUQA+CfzYTwqPxtxY0eZDi8nvzyk2drD D7fg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature :arc-authentication-results; bh=ztr7Z21S/QsVb7jxFRC/Icd17/WJ9yzh2+UlE6xLZus=; b=TyheHB68gW5StJKLr96temGf6jL3kPgwgfGGcNouFuQiM/zcUyLcLG1lx2GxTe+e1I OPKvO7FlZvkSA9U4TphzZ8/QFRDtq4x4nntbntIkso7acidiTlfO3jicI7H3zfI3Z9E9 pPr5kLueGdqQKsk/I2O2P5dD6mbkOC4rgDrOdmPEfKcBeMKVzWZLNdTH3ciW4VDYzS7T bmBae8w+7MaCpCRDyXtEj33WrHth7KTvFUoreAzvAO1zD4ewZeBStPIUQ0JqE1Ok9Ebb yJKv3V/hBjSIN7TDpZ8Ket4zVyePPniWB4u/m+kNyd2san3+tULrVhQSCktfKwFMQe6b U45g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=DBeKmgbh; 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=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s36-v6si29661177pld.278.2018.07.16.07.37.29; Mon, 16 Jul 2018 07:37:43 -0700 (PDT) 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=@kernel.org header.s=default header.b=DBeKmgbh; 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=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727595AbeGPPE3 (ORCPT + 99 others); Mon, 16 Jul 2018 11:04:29 -0400 Received: from mail.kernel.org ([198.145.29.99]:60088 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726571AbeGPPE3 (ORCPT ); Mon, 16 Jul 2018 11:04:29 -0400 Received: from mail-it0-f47.google.com (mail-it0-f47.google.com [209.85.214.47]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 55BEF2084A; Mon, 16 Jul 2018 14:36:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1531751806; bh=5qSEQRDihN5Np+PlgyQ8GgHncxRboBpB6cBhnROBW+E=; h=References:In-Reply-To:From:Date:Subject:To:Cc:From; b=DBeKmgbh2/HI0b5D1IQO0Jp9g4veMJgHd6CW9At1LpWpNqEdLLHlQnLrMgTHkuGej mjhXEMpRQfv9MR1ITxzmtx3hnx2gLmWOKxsr0D68YbJGiUWUNuh5uPAUNS9oXhVwe/ syjXgyCu8xQn1DkE2dNgG2iJb6q9QiSL1F5wBG10= Received: by mail-it0-f47.google.com with SMTP id h2-v6so19355691itj.1; Mon, 16 Jul 2018 07:36:46 -0700 (PDT) X-Gm-Message-State: AOUpUlE6hDzVzEle8m+PCy58UUs0LNEYlSzey9oqfX2Rq/netnWctvF/ DZcQ3coL48BiJkHOx65hHgE/+VQ+ZPKsQzVukg== X-Received: by 2002:a02:986d:: with SMTP id x42-v6mr14718167jaj.131.1531751805799; Mon, 16 Jul 2018 07:36:45 -0700 (PDT) MIME-Version: 1.0 References: <20180706113715.30053-1-mark.rutland@arm.com> In-Reply-To: From: Rob Herring Date: Mon, 16 Jul 2018 08:36:34 -0600 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH] of/fdt: avoid undefined behaviour in populate_properties() To: Frank Rowand Cc: Mark Rutland , "linux-kernel@vger.kernel.org" , devicetree@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jul 6, 2018 at 10:51 AM Frank Rowand wrote: > > On 07/06/18 04:37, Mark Rutland wrote: > > We unflatten a device tree in two passes: the first calculating the size > > of the unflattened tree, and the second performing the actual > > unflattening into a suitably-sized buffer. [...] > > @@ -187,7 +187,9 @@ static void populate_properties(const void *blob, > > int cur; > > bool has_name = false; > > > > - pprev = &np->properties; > > + if (!dryrun) > > + pprev = &np->properties; > > + > > for (cur = fdt_first_property_offset(blob, offset); > > cur >= 0; > > cur = fdt_next_property_offset(blob, cur)) { > > > > Please add a one line comment explaining why "if (!dryrun)" so that no one > decides to remove the test in the future as not needed. Otherwise, Please re-spin ASAP with the comment if you'd like this in 4.18. Rob