Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp2323024imm; Tue, 4 Sep 2018 02:23:34 -0700 (PDT) X-Google-Smtp-Source: ANB0VdYNcdEsdFE/ZDM7RxdiO7JBu+2+J+1WIXN7LkFmHYuA9tPYRqTSzwqJg9Vsidq2BxjdqbLD X-Received: by 2002:a62:c9:: with SMTP id 192-v6mr33512204pfa.99.1536053014625; Tue, 04 Sep 2018 02:23:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536053014; cv=none; d=google.com; s=arc-20160816; b=zHbgOOETaRkzk9NNK9cdA1wHYVgtTg2JN2GuCt+a2XTRqzr0gtudHDBO5+LUve7izg HH1H14Fcq3svEwzRuwq1zTUYBi9ARJC/of5G6z3BvIGfCRJ7mhDp7F22sZbchWxxO4yW N/1tBKSiSzJ9JnZ6sLtVq0JxOT5Y9xB45t5HGzyc/Sa2exw/YNfajH75fSFjY32siz/h 3aa6G6CzcTaMRagg691fkAm7prB3DqF0b7ioDzBz/TIQREytUMfaOoA2UYZeGTgWCpOO W1BibBxFgMDRb5WiLDJOVxMjBmo7KWQ6hobsGGWxUMO7LxcjhfmbNgpjNnjCkpBL4Kxc yuSg== 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:arc-authentication-results; bh=DUe766a6oQA9ykH9DIHYKw2vjVTfGakT70jFbdhpxI4=; b=S3VB0FA9RVvX2xrPHZZ0f/rNBnLDscLUb/EsWEGxrVfrAzxqX13VDRG6ppsabeYAvW dcNPVnBY/HMGV3Oaq/e7675FF/LE+NjsRdlt8iDzljFUOQ44NA5KwZPcLeBTOrO70Xs8 P8nLz4FyoAU2vKuy537IA6kjSIIOSCePT3qDZMEyPS7D+k5ZM8wTREmQkmA+s8vUhtqo cRxT1wqhb/fIFHquKsvmAHa7G0yQCLN8dLVlCTXwG83IIRmDFHKgRmfTyscNUY1h1Bm3 Z24p31b1R7/yRJCTnqDSzPC0UW0d6TRHWYNFTm/mX4qYVLY0MJFHVYOZxBQBKKpJeMRZ 7RYg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=cirrus.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e1-v6si18790769plt.325.2018.09.04.02.23.19; Tue, 04 Sep 2018 02:23:34 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=cirrus.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727420AbeIDNq3 (ORCPT + 99 others); Tue, 4 Sep 2018 09:46:29 -0400 Received: from mx0a-001ae601.pphosted.com ([67.231.149.25]:35576 "EHLO mx0b-001ae601.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726336AbeIDNq2 (ORCPT ); Tue, 4 Sep 2018 09:46:28 -0400 Received: from pps.filterd (m0077473.ppops.net [127.0.0.1]) by mx0a-001ae601.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w849J49b011214; Tue, 4 Sep 2018 04:21:57 -0500 Authentication-Results: ppops.net; spf=none smtp.mailfrom=rf@opensource.cirrus.com Received: from mail4.cirrus.com ([87.246.98.35]) by mx0a-001ae601.pphosted.com with ESMTP id 2m7r62kekj-3; Tue, 04 Sep 2018 04:21:57 -0500 Received: from EX17.ad.cirrus.com (unknown [172.20.9.81]) by mail4.cirrus.com (Postfix) with ESMTP id 097BC611C8B1; Tue, 4 Sep 2018 04:24:05 -0500 (CDT) Received: from imbe.wolfsonmicro.main (198.61.95.81) by EX17.ad.cirrus.com (172.20.9.81) with Microsoft SMTP Server id 14.3.408.0; Tue, 4 Sep 2018 10:21:56 +0100 Received: from [198.90.251.121] (edi-sw-dsktp006.ad.cirrus.com [198.90.251.121]) by imbe.wolfsonmicro.main (8.14.4/8.14.4) with ESMTP id w849Lpca023206; Tue, 4 Sep 2018 10:21:51 +0100 Subject: Re: [PATCH net-next v2 4/7] net: phy: mscc: read 'vsc8531,edge-slowdown' as an u32 [UNSCANNED] To: Quentin Schulz , Andrew Lunn CC: , , , , , , , , , References: <20180903084853.18092-1-quentin.schulz@bootlin.com> <20180903084853.18092-4-quentin.schulz@bootlin.com> <20180903132756.GD4445@lunn.ch> <20180903133746.wsvezy3rbdivnjfs@qschulz> <20180903200554.GJ4445@lunn.ch> <20180904072630.zc6sdz2xdti5nku4@qschulz> From: Richard Fitzgerald Message-ID: <6c189a8f-7168-3861-c964-b38631833451@opensource.cirrus.com> Date: Tue, 4 Sep 2018 10:21:51 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: <20180904072630.zc6sdz2xdti5nku4@qschulz> Content-Type: text/plain; charset="windows-1252"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 priorityscore=1501 malwarescore=0 suspectscore=0 phishscore=0 bulkscore=0 spamscore=0 clxscore=1011 lowpriorityscore=0 mlxscore=0 impostorscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1807170000 definitions=main-1809040098 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 04/09/18 08:26, Quentin Schulz wrote: > Hi Andrew, > > On Mon, Sep 03, 2018 at 10:05:54PM +0200, Andrew Lunn wrote: >>> Just to be sure, we're talking here about making sure the value stored >>> in the DT is not bigger than the specified value (here an u8)? If so, >>> that isn't the reason why I'm suggesting those two patches. >>> >>> Without /bits 8/ in the DT property, whatever were the values I put in >>> the property, I'd always get a 0. So I need to fix it either in the DT >>> (but Rob does not really like it) or in the driver. >> >> Hi Quentin >> >> Ah, you are fixing endian issues. That was not clear to me from the >> commit message. >> >> I don't know enough about how DT stores values in the blob. Is there >> type info? Can the DT core tell if a value in the blob is a u8 or a >> u32? It would be nice if it warned about reading a u8 from a u32 >> blob. >> > > From my quick research, the lower bound checking is performed by > of_property_read_u* functions but not the higher bound checking (the > internal function of_find_property_value_of_size allows higher bound > checking but it seems it's never used by those functions (see 0 in > sz_max of of_property_read_variable_u*_array)). > > sz_max is used by of_property_read_variable_u*_array to copy at a > maximum of sz_max values in the output buffer. If sz_max is 0, it takes > sz_min so it's an array of definite size. > So since sz_max is 0 for all calls to of_property_read_variable_u*_array > by of_property_read_u*_array, we basically know we'll get a buffer of > sz_min values but we don't actually make use of the higher bound > checking of of_find_property_value_of_size. > This was the original behaviour of the of_property_read_u*_array functions. If you look back at the of_property_read_u*_array implementations before my patch they passed max=0 to of_find_property_value_of_size. To avoid duplicating code I reimplemented the of_property_read_u*_array to use the new of_property_read_variable_u*_array hence they pass sz_max=0 to preserve the original behaviour that max=0 to of_find_property_value_of_size, so that I didn't break any code that might depend on that. > We could enforce this higher bound check by, instead of setting sz_max > to 0, setting sz_max to sz_min in calls to of_property_read_u*_array. > > But I guess there is a reason for sz_max being 0. Rob, Richard (commit > signer of this code) do you know why? Could you explain? > >> Anyway, this change still removes some bounds checking. Are they >> important? Do they need to be added back? >> > > The edge-slowdown and the vddmac values are compared against a const > array so we?re fine with those ones. > > For the led-X-mode, I added a constant for supported modes that gets > checked when retrieving the DT property. So we?re fine here too. > > Quentin >