Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S936172AbcKWLsf (ORCPT ); Wed, 23 Nov 2016 06:48:35 -0500 Received: from fllnx209.ext.ti.com ([198.47.19.16]:27697 "EHLO fllnx209.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935048AbcKWLsd (ORCPT ); Wed, 23 Nov 2016 06:48:33 -0500 Subject: Re: [PATCH 1/3] of: base: add support to get machine compatible string To: Sudeep Holla References: <1479811311-3080-1-git-send-email-bgolaszewski@baylibre.com> <1479811311-3080-2-git-send-email-bgolaszewski@baylibre.com> <5ce9fb9f-459a-562b-2e9f-85d35f9ec035@arm.com> <67a3c2c7-0cb9-9764-2710-6ee66fc4dde4@ti.com> <2a644b8c-d91e-5ab1-200b-00f749a36307@arm.com> CC: Bartosz Golaszewski , Kevin Hilman , Michael Turquette , Rob Herring , Frank Rowand , Mark Rutland , Peter Ujfalusi , Russell King , LKML , arm-soc , linux-drm , linux-devicetree , Jyri Sarha , Tomi Valkeinen , David Airlie , Laurent Pinchart , Robin Murphy From: Sekhar Nori Message-ID: Date: Wed, 23 Nov 2016 17:17:43 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.4.0 MIME-Version: 1.0 In-Reply-To: <2a644b8c-d91e-5ab1-200b-00f749a36307@arm.com> Content-Type: text/plain; charset="windows-1252" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2091 Lines: 63 On Wednesday 23 November 2016 03:35 PM, Sudeep Holla wrote: > > > On 23/11/16 07:49, Sekhar Nori wrote: >> On Tuesday 22 November 2016 09:16 PM, Sudeep Holla wrote: >>> Hi Sekhar, >>> >>> On 22/11/16 15:06, Sekhar Nori wrote: >>>> Hi Sudeep, >>>> >>>> On Tuesday 22 November 2016 04:23 PM, Sudeep Holla wrote: >>>>> >>>>> >>>>> On 22/11/16 10:41, Bartosz Golaszewski wrote: >>>>>> Add a function allowing to retrieve the compatible string of the root >>>>>> node of the device tree. >>>>>> >>>>> >>>>> Rob has queued [1] and it's in -next today. You can reuse that if you >>>>> are planning to target this for v4.11 or just use open coding in your >>>>> driver for v4.10 and target this move for v4.11 to avoid cross tree >>>>> dependencies as I already mentioned in your previous thread. >>>> >>>> I dont have your original patch in my mailbox, but I wonder if >>>> returning a pointer to property string for a node whose reference has >>>> already been released is safe to do? Probably not an issue for the root >>>> node, but still feels counter-intuitive. >>>> >>> >>> I am not sure if I understand the issue here. Are you referring a case >>> where of_root is freed ? >> >> Yes, right, thats what I was hinting at. Since you are giving up the >> reference to the device node before the function returns, the user can >> be left with a dangling reference. >> > > Yes I agree. So, the if(!of_node_get()) is just an expensive NULL pointer check. I think it is better to be explicit about it by not using of_node_get/put() at all. How about: +int of_machine_get_model_name(const char **model) +{ + int error; + + if (!of_root) + return -EINVAL; + + error = of_property_read_string(of_root, "model", model); + if (error) + error = of_property_read_string_index(of_root, "compatible", + 0, model); + return error; +} +EXPORT_SYMBOL(of_machine_get_model_name); I know the patch is already in -next so I guess it depends on how strongly Rob feels about this. Thanks, Sekhar