Received: by 2002:ab2:3141:0:b0:1ed:23cc:44d1 with SMTP id i1csp1047407lqg; Sat, 2 Mar 2024 12:54:53 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCUROOqbZ/+NDfR5u1tn27uxL7Oifwzg5E5jO3Mmv9xfacABRCM6LPAm9Rx9akPxz1t93z82zUCdiiiiFtvZkLdpzGEZ+zrJh/m1OF4xzQ== X-Google-Smtp-Source: AGHT+IFfypP2NZrK/jQtmgpClCAPymqfQ1czoGGZ7/pxW+rb9sZz2vfyaHupleM5SxJZLXjAuWvX X-Received: by 2002:a05:6402:1d91:b0:566:b09e:8d24 with SMTP id dk17-20020a0564021d9100b00566b09e8d24mr3099334edb.12.1709412893205; Sat, 02 Mar 2024 12:54:53 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1709412893; cv=pass; d=google.com; s=arc-20160816; b=UX4k/MV6GcdjaFb/wMVH6vqSvnGNkiaQ6W3pRoGZnjuUABGWRKq6LP65QC8eZ+XOJ+ QHM6LKesbF+fRs9BN0iYo8cHAhdR3mFZ9d3/9/h1eXU2ZgCGcmmvrdHpp0SZt/x4xFLV mUt89b5jnvQMYZGbSHi2FFYeM4aUD3nhX+r1eApFEoLQUXxhrasn787Rdyq2EzDFi2hC dZo1P134bUKvtzt8MC6M6A+oI18Df3qwf02jiAkRQnJdwwIccY8umETzT25hJ3+VUQ93 fjk8Ujgrl1MuxuV0LjTGvRbLGFgmY5QFGmdgNxSP5Wp+/u/gOxU3zNqnWz7D6UwQVufF v0Uw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from; bh=ZBSKuKp4/L7fVk+cXiqf5EMuK1YbZeQwz/LK/+WeZCA=; fh=jrcPHp5z4nDZM+RPUCW0WfJX9bfZoXLP56oUVGhS34k=; b=imlndyLlaUJYTnCAJkZS6scZ9s+RsSoQg2t7d3uSzAP0JkEgYKxWorYNp4oVTBXlHW W2jCK/N3OYM7IQ+tTyI3OMudbMPLENlwO23V1radnVk7UA9bR/e6QRcIs7/oguxllf8A 62g0UZB6nZE/gtLt9MMDbSpKQbtkw76L2+LJ6UE2VwB/e0knl2dC2Of3Hhr7Cet6NCIM Qen8MBQ2dqR8dc3vY/ZDHSl/aIYVTLAu3y9JcD5e6xqElONG6X0EQNmcEUirCsyIAa5h PRjWdxv4Rzyia7W9hDiPkvN6GcGM0dbeHwSDmezWM6jpXM2APXACRpmWKyFm0GpFZvHz p9JA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=pengutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-89593-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-89593-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id r3-20020aa7c143000000b00565edf98018si2618711edp.486.2024.03.02.12.54.53 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 02 Mar 2024 12:54:53 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-89593-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=pengutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-89593-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-89593-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id BF0331F21660 for ; Sat, 2 Mar 2024 20:54:52 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 96CFD2BAEB; Sat, 2 Mar 2024 20:54:45 +0000 (UTC) Received: from metis.whiteo.stw.pengutronix.de (metis.whiteo.stw.pengutronix.de [185.203.201.7]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 58726290A for ; Sat, 2 Mar 2024 20:54:40 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=185.203.201.7 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709412885; cv=none; b=MiUIGmYgTRXrjVvt93hUcDm16J0zNxgBtyqaPskq3ymKbaAHSme4SN7KBm6kFKJFSQ/bv5SVso6v/qu0hP7wHQ4qm2/nc4Cx34H5tmrCGtJTF7A4u5xPq/TCVotGgNGmI2pL7LcXDAnrq17+c1/crar+SRD3RgNyC5sw8bh2QUA= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709412885; c=relaxed/simple; bh=IKmYdj4+qwMGZYBGOtYVBzb4vztcCuUi25hMBgKz6lQ=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version:Content-Type; b=EyyQeU83xkUU3Cj3bMxiVQisbRJ18ii5yl5BaSQKtioM8+IUnYzDzGK87rPz6XCeSxObjpc8/RAcrARlU7pxajH0ovVCaPkgiQjohD+Et0IbCXlP+zXoISharaORrfMFZxMhqVj0gmzzY51+YezTFxmfPiuSm+Sk2GYAlbu/Twc= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=pengutronix.de; spf=pass smtp.mailfrom=pengutronix.de; arc=none smtp.client-ip=185.203.201.7 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=pengutronix.de Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=pengutronix.de Received: from drehscheibe.grey.stw.pengutronix.de ([2a0a:edc0:0:c01:1d::a2]) by metis.whiteo.stw.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1rgWNT-0003qv-1O; Sat, 02 Mar 2024 21:54:39 +0100 Received: from [2a0a:edc0:0:900:1d::77] (helo=ptz.office.stw.pengutronix.de) by drehscheibe.grey.stw.pengutronix.de with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.94.2) (envelope-from ) id 1rgWNR-0042FP-MN; Sat, 02 Mar 2024 21:54:37 +0100 Received: from ukl by ptz.office.stw.pengutronix.de with local (Exim 4.96) (envelope-from ) id 1rgWNR-00FZke-1w; Sat, 02 Mar 2024 21:54:37 +0100 From: =?UTF-8?q?Uwe=20Kleine-K=C3=B6nig?= To: Andrew Morton Cc: linux-kernel@vger.kernel.org, Biju Das , kernel@pengutronix.de Subject: [PATCH] mul_u64_u64_div_u64: Increase precision by conditionally swapping a and b Date: Sat, 2 Mar 2024 21:54:27 +0100 Message-ID: <20240302205426.639205-2-u.kleine-koenig@pengutronix.de> X-Mailer: git-send-email 2.43.0 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 X-Developer-Signature: v=1; a=openpgp-sha256; l=1309; i=u.kleine-koenig@pengutronix.de; h=from:subject; bh=IKmYdj4+qwMGZYBGOtYVBzb4vztcCuUi25hMBgKz6lQ=; b=owEBbQGS/pANAwAKAY+A+1h9Ev5OAcsmYgBl45IDwOnSs0mCE9Etx3kFkYz2Ja/J+WPkdYdy2 fK8RnVLafOJATMEAAEKAB0WIQQ/gaxpOnoeWYmt/tOPgPtYfRL+TgUCZeOSAwAKCRCPgPtYfRL+ TniMB/4gJTFXWZ47C2ialXL+jfKEZz9eqpGDo/hrlIIu9XmOVAbSNNMV/LNALdRiTukt5/0iuyY caa2L454igWD7Tb9jHAevyhASgBay/WwrNHPTVDPFhPhdCGB/wdDCtqClX8bOhtFn/KJU9cJmQ+ yVx0TRNVuMuck34uPVx4xBhVF/StG3Kz5woK1b7QsdYeYEj+tXbTGxzvzophta1J+c8i7zj5R1W 9cfEYd9hkAdqecIfTm8cTx+yC8rrVIAZ7LdA4odTobDKbVZ3bZfiMegBryHFkHIyDc4xjRpmkRZ KmsxVNgDjRx/7UajH+g5WqbKxhx9w05bqP2NYftw0tHnLP9W X-Developer-Key: i=u.kleine-koenig@pengutronix.de; a=openpgp; fpr=0D2511F322BFAB1C1580266BE2DCDD9132669BD6 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2a0a:edc0:0:c01:1d::a2 X-SA-Exim-Mail-From: ukl@pengutronix.de X-SA-Exim-Scanned: No (on metis.whiteo.stw.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org As indicated in the added comment, the algorithm works better if b is big. As multiplication is commutative, a and b can be swapped. Do this If a is bigger than b. Signed-off-by: Uwe Kleine-König --- lib/math/div64.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/lib/math/div64.c b/lib/math/div64.c index 55a81782e271..baf6f8681907 100644 --- a/lib/math/div64.c +++ b/lib/math/div64.c @@ -190,6 +190,23 @@ u64 mul_u64_u64_div_u64(u64 a, u64 b, u64 c) /* can a * b overflow ? */ if (ilog2(a) + ilog2(b) > 62) { + /* + * Note that the algorithm after the if block below might loose + * some precision and the result is more exact for b > a. So + * exchange a and b if a is bigger than b. + * + * For example with a = 43980465100800, b = 100000000, c = 1000000000 + * the below calculation doesn't modify b at all because div == 0 + * and then shift becomes 45 + 26 - 62 = 9 and so the result + * becomes 4398035251080. However with a and b swapped the exact + * result is calculated (i.e. 4398046510080). + */ + if (a > b) { + u64 tmp = a; + a = b; + b = tmp; + } + /* * (b * a) / c is equal to * base-commit: 1870cdc0e8dee32e3c221704a2977898ba4c10e8 -- 2.43.0