Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp368779ybv; Thu, 13 Feb 2020 01:58:43 -0800 (PST) X-Google-Smtp-Source: APXvYqxVUIe/fkGja0RRc/G7DhkDcQFRaQRK3BUOinCdm9dY+fH1ngqxT6i7XEy1kHBu+K4fdNPL X-Received: by 2002:aca:b808:: with SMTP id i8mr2268535oif.66.1581587923819; Thu, 13 Feb 2020 01:58:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581587923; cv=none; d=google.com; s=arc-20160816; b=M2VgDH8oOcFN1V0iG1fbQ0pC7WZbzbm+mH1Fi2FWflxBSf4QdmAynzPNfYzwea5h6a CdQAVKiVpF5g9Qg9/ymjflvObqe4m3zhbGLWzNBgcg6dXxAVBoRc9NeXRLgN5pbYw6p3 aPrllckQ7wqA2g9CYCuIeVXTPVkDyMWAvb+yobJ2L3RRFMzuo43XAUKOLFGzXjZRjyaf VbENdjpKEVwL8C60mClyJ76vLuBnb0mPnex2YL/hPHWGvlN9rqENUUxmdbD0SfRbvkZ3 QeQBbObF7zAhNLuuFgO/rr+x0JRWIVRHyqQytKvtF5l8NUoAa893gFEBWixWneqSUAQD 3nKw== 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 :content-language:accept-language:in-reply-to:references:message-id :date:thread-index:thread-topic:subject:cc:to:from; bh=/YUG9CZH1mLcYmYn2KMz+g5s34meC4rKgoh1HOk2RVc=; b=MTchptKMUD/pQmurBOpd66R6QCQMqMJuxs9sZ36mi7fQVcAtSir9MCE5R7fMlSgotF ZWlne+vmwV2oFqYm0PeFFOw3DPVGicWF8UgMpI9huw3xJwKsaRcAAZ0Tnl53CzoxmOXM Jwp+UyAaXh5G3M0ZX/xfdgQ/EdCj5A1aYILl8VBl/31Sz8qi7K97W0haAkAF7sibD526 WneBIsr/iLmOc8BQxogvzHQF0ZOxboxc6n2bWtZ5GOH/zjTjHXs2Q3DVL2hMFk5DBWEf iaqGVSpelGcTkTSAT7iGjazWPCsaKyj54nKnj5V2CVGyvUcHAFT1BjpfeROIv2hlG52S X65A== 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=aculab.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c130si1022188oib.182.2020.02.13.01.58.30; Thu, 13 Feb 2020 01:58:43 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=aculab.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729623AbgBMJ6W convert rfc822-to-8bit (ORCPT + 99 others); Thu, 13 Feb 2020 04:58:22 -0500 Received: from eu-smtp-delivery-151.mimecast.com ([146.101.78.151]:33328 "EHLO eu-smtp-delivery-151.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729531AbgBMJ6V (ORCPT ); Thu, 13 Feb 2020 04:58:21 -0500 Received: from AcuMS.aculab.com (156.67.243.126 [156.67.243.126]) (Using TLS) by relay.mimecast.com with ESMTP id uk-mta-31-urz-U1i-MRqONzuPEzu5jQ-1; Thu, 13 Feb 2020 09:58:16 +0000 Received: from AcuMS.Aculab.com (fd9f:af1c:a25b:0:43c:695e:880f:8750) by AcuMS.aculab.com (fd9f:af1c:a25b:0:43c:695e:880f:8750) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Thu, 13 Feb 2020 09:58:15 +0000 Received: from AcuMS.Aculab.com ([fe80::43c:695e:880f:8750]) by AcuMS.aculab.com ([fe80::43c:695e:880f:8750%12]) with mapi id 15.00.1347.000; Thu, 13 Feb 2020 09:58:15 +0000 From: David Laight To: 'Wolfram Sang' , "Gustavo A. R. Silva" CC: Thor Thayer , Andy Shevchenko , "linux-i2c@vger.kernel.org" , "linux-kernel@vger.kernel.org" Subject: RE: [PATCH v2] i2c: altera: Fix potential integer overflow Thread-Topic: [PATCH v2] i2c: altera: Fix potential integer overflow Thread-Index: AQHV4k1iLqSOpbmHb06oJubj/a823KgY4cbQ Date: Thu, 13 Feb 2020 09:58:15 +0000 Message-ID: References: <20200211144704.GA6461@embeddedor> <20200213090959.GA2123@ninjato> In-Reply-To: <20200213090959.GA2123@ninjato> Accept-Language: en-GB, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ms-exchange-transport-fromentityheader: Hosted x-originating-ip: [10.202.205.107] MIME-Version: 1.0 X-MC-Unique: urz-U1i-MRqONzuPEzu5jQ-1 X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: aculab.com Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Wolfram Sang > Sent: 13 February 2020 09:10 > > On Tue, Feb 11, 2020 at 08:47:04AM -0600, Gustavo A. R. Silva wrote: > > Factor out 100 from the equation and do 32-bit arithmetic (3 * clk_mhz / 10) > > instead of 64-bit. > > > > Notice that clk_mhz is MHz, so the multiplication will never wrap 32 bits > > and there is no need for div_u64(). > > Was there ever? With > > u32 clk_mhz = clk_get_rate(idev->i2c_clk) / 1000000; > > a later multiplication with 300 should not wrap u32? > > > /* SDA Hold Time, 300ns */ > > - writel(div_u64(300 * clk_mhz, 1000), idev->base + ALTR_I2C_SDA_HOLD); > > + writel(3 * clk_mhz / 10, idev->base + ALTR_I2C_SDA_HOLD); > > The change itself is OK, yet I wonder about the comment above: > > 'clk_mhz * 0.3' will not give a constant 300ns, or? Depends on the definition of the register. A count of zero may mean one clock period. So maybe it could have (3 * clk - 1)/10 instead of (3 * clk + 9)/10. OTOH nothing probably requires that much hold time. If that is the 'standard' Altera Avalon slave I2C 'megafunction' I2C master then it is probably so slow to use it can't matter. Most of those blocks are crap, they aren't even small. David - Registered Address Lakeside, Bramley Road, Mount Farm, Milton Keynes, MK1 1PT, UK Registration No: 1397386 (Wales)