Received: by 10.223.185.116 with SMTP id b49csp2051168wrg; Thu, 15 Feb 2018 05:54:30 -0800 (PST) X-Google-Smtp-Source: AH8x225DowahBamZL6bGUVqb/n2GJiQ2RqHCupnDUbHghHRMw63BQcP1bM5s4j4+QjzUgYYWOEdQ X-Received: by 10.98.215.93 with SMTP id v29mr2683312pfl.85.1518702870697; Thu, 15 Feb 2018 05:54:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518702870; cv=none; d=google.com; s=arc-20160816; b=U4RbCUTUTAjrv6NQWcrThGn8QdCXo21UhEoye0yPEpyz9EWCCFL6zBN+SxHBQuKG2i wkBxtde3LodA6ydgN8zmI9Kou7Lm+WTkOJ9Vfvpwn/flSetXxY1yc5LaoKetRRmQrTgf H1aEkFox9/lZImjaTh7ubCdEXE+JJwzWRKDPU2tgk3OqGPCdW8OhtnECLlL9102P5RX+ t5LNG2XXNQJYqSfbA+q0lo835vOpnoKqCeUBAg4Gz7R9heqB3iXiFoUzClX4z0g3CUCb UZQKDxrxfnahu6cjmr/lxWJ1s1uLhfagiXZ4/2md+iGXUhwNGhBeBwpkM/85CHRrxzD6 NsGQ== 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=SJNzmd0jrstxCwktt1vKZXmu5g+m8jWvO9J03NzHNsU=; b=r0CYt9Zf9ziCXEYXnI+p+gKT3xgnNfDD+FYf0UN2Gotv39bKLO2TXjdYu7o+H33f/W Dg4pKjKzW6W2Al+UOJK05Rtkin6Pwgb0Q6Qx/HdTBPkBVjhVvdXMLY+Wz6xbI7w2lTLq fxGainyqjjR4u2syUnxnynqUAKy01k2yqVLe5RsobW3AlwZt1XoWbF4knbtssSr1N2nN fY9aCDnY4V0eL+FiF7xMZAnQQ1WfbuJfzttQkk1QRzixNAinJtV+7fl5g0qIxyXMbJ04 CrIyW+I9bfTgZDU7iTyBRj2U2CRpVZvsr7xK5p0dRTz1UqQwy0rninwSIaPWua1lhK4B jZyQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n3-v6si1298023pld.150.2018.02.15.05.54.15; Thu, 15 Feb 2018 05:54:30 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1032953AbeBONwg (ORCPT + 99 others); Thu, 15 Feb 2018 08:52:36 -0500 Received: from lb1-smtp-cloud9.xs4all.net ([194.109.24.22]:48384 "EHLO lb1-smtp-cloud9.xs4all.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1031501AbeBONwe (ORCPT ); Thu, 15 Feb 2018 08:52:34 -0500 Received: from [192.168.1.10] ([80.101.105.217]) by smtp-cloud9.xs4all.net with ESMTPA id mJxfeh5EQoWCOmJxgeTQit; Thu, 15 Feb 2018 14:52:33 +0100 Subject: Re: [PATCH v3 4/8] i2c: ov9650: use 64-bit arithmetic instead of 32-bit To: "Gustavo A. R. Silva" , Sakari Ailus , "Gustavo A. R. Silva" Cc: Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-kernel@vger.kernel.org References: <6f6fd607cf3428d6ab115f1deaa82c4963b170f1.1517929336.git.gustavo@embeddedor.com> <20180207215944.quwowjy52dclk7uc@valkosipuli.retiisi.org.uk> <3518830f-180c-2bf0-1319-eb4af8cc556f@embeddedor.com> From: Hans Verkuil Message-ID: <16032bbb-5063-4f94-bebd-3f512bed8199@xs4all.nl> Date: Thu, 15 Feb 2018 14:52:33 +0100 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: <3518830f-180c-2bf0-1319-eb4af8cc556f@embeddedor.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit X-CMAE-Envelope: MS4wfEN4/dHr28n7u/lJtf8T0KAyKnFzfyhPeOT65vlOcS+TbHqPeYPhQqP+Plkq+UXGZv4xZMTWIWdGTX1pegq6TaoJfzTCApOutCmqkrGXEamUumeA9NZ9 m3nV4VYoF710YLAeTaCirGyXWoG/1ZK8PqAQQ61R8KgaZnChY6XMf1mDIBCaH36L4UcUIt9qkTAHWkAn3cabUtVbq63R3lG7vS32eqff2ld/QsRin3kxu22z mMXexuqNOTVU+9uujG0Gb2r5IFLdU/xpeOkJRetdMn+9hH8QDcclqenMA+qQBCB1MTnDdqzI4w4uerog0PDcDPqeXYQ9AR725EeVGQ2N2i9t811OqGBmHCJa Sw/eTDWz Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 08/02/18 17:39, Gustavo A. R. Silva wrote: > Hi Sakari, > > On 02/07/2018 03:59 PM, Sakari Ailus wrote: >> Hi Gustavo, >> >> On Tue, Feb 06, 2018 at 10:47:50AM -0600, Gustavo A. R. Silva wrote: >>> Add suffix ULL to constants 10000 and 1000000 in order to give the >>> compiler complete information about the proper arithmetic to use. >>> Notice that these constants are used in contexts that expect >>> expressions of type u64 (64 bits, unsigned). >>> >>> The following expressions: >>> >>> (u64)(fi->interval.numerator * 10000) >>> (u64)(iv->interval.numerator * 10000) >>> fiv->interval.numerator * 1000000 / fiv->interval.denominator >>> >>> are currently being evaluated using 32-bit arithmetic. >>> >>> Notice that those casts to u64 for the first two expressions are only >>> effective after such expressions are evaluated using 32-bit arithmetic, >>> which leads to potential integer overflows. So based on those casts, it >>> seems that the original intention of the code is to actually use 64-bit >>> arithmetic instead of 32-bit. >>> >>> Also, notice that once the suffix ULL is added to the constants, the >>> outer casts to u64 are no longer needed. >>> >>> Addresses-Coverity-ID: 1324146 ("Unintentional integer overflow") >>> Fixes: 84a15ded76ec ("[media] V4L: Add driver for OV9650/52 image sensors") >>> Fixes: 79211c8ed19c ("remove abs64()") >>> Signed-off-by: Gustavo A. R. Silva >>> --- >>> Changes in v2: >>>   - Update subject and changelog to better reflect the proposed code changes. >>>   - Add suffix ULL to constants instead of casting variables. >>>   - Remove unnecessary casts to u64 as part of the code change. >>>   - Extend the same code change to other similar expressions. >>> >>> Changes in v3: >>>   - None. >>> >>>   drivers/media/i2c/ov9650.c | 9 +++++---- >>>   1 file changed, 5 insertions(+), 4 deletions(-) >>> >>> diff --git a/drivers/media/i2c/ov9650.c b/drivers/media/i2c/ov9650.c >>> index e519f27..e716e98 100644 >>> --- a/drivers/media/i2c/ov9650.c >>> +++ b/drivers/media/i2c/ov9650.c >>> @@ -1130,7 +1130,7 @@ static int __ov965x_set_frame_interval(struct ov965x *ov965x, >>>       if (fi->interval.denominator == 0) >>>           return -EINVAL; >>>   -    req_int = (u64)(fi->interval.numerator * 10000) / >>> +    req_int = fi->interval.numerator * 10000ULL / >>>           fi->interval.denominator; >> >> This has been addressed by your earlier patch "i2c: ov9650: fix potential integer overflow in >> __ov965x_set_frame_interval" I tweaked a little. It's not in media tree >> master yet. >> > > Yeah. Actually this patch is supposed to be an improved version of the one you mention. That is why this is version 3. > > Also, I wonder if the same issue you mention below regarding 32-bit ARM applies in this case too? > >>>         for (i = 0; i < ARRAY_SIZE(ov965x_intervals); i++) { >>> @@ -1139,7 +1139,7 @@ static int __ov965x_set_frame_interval(struct ov965x *ov965x, >>>           if (mbus_fmt->width != iv->size.width || >>>               mbus_fmt->height != iv->size.height) >>>               continue; >>> -        err = abs((u64)(iv->interval.numerator * 10000) / >>> +        err = abs(iv->interval.numerator * 10000ULL / >> >> This and the chunk below won't work on e.g. 32-bit ARM. do_div(), please. >> > > Thanks for pointing this out. > >>>                   iv->interval.denominator - req_int); >>>           if (err < min_err) { >>>               fiv = iv; >>> @@ -1148,8 +1148,9 @@ static int __ov965x_set_frame_interval(struct ov965x *ov965x, >>>       } >>>       ov965x->fiv = fiv; >>>   -    v4l2_dbg(1, debug, &ov965x->sd, "Changed frame interval to %u us\n", >>> -         fiv->interval.numerator * 1000000 / fiv->interval.denominator); >>> +    v4l2_dbg(1, debug, &ov965x->sd, "Changed frame interval to %llu us\n", >>> +         fiv->interval.numerator * 1000000ULL / >>> +         fiv->interval.denominator); > > I wonder if do_div should be used for the code above? Yes, do_div should be used. Hans > > I appreciate your feedback. > > Thank you!