Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp775998ybb; Sat, 28 Mar 2020 09:47:38 -0700 (PDT) X-Google-Smtp-Source: ADFU+vsDE/DklRM9ntdKW1MYfb86mb7n6WxZWQHGrf8IlxfKzpZCYuVXjvvx3QpjPLTKgZ0e7+JR X-Received: by 2002:a05:6830:20d5:: with SMTP id z21mr3128957otq.237.1585414058348; Sat, 28 Mar 2020 09:47:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585414058; cv=none; d=google.com; s=arc-20160816; b=WEQeNnqtYPy2ZyY3/eSA/2ndgdp21Wh5jLbKrzpKmWe2ZQTLqIvIaQISKKE8fEIqtt lK4J5U6fhonnALuoF72c7E7WnnK4YeKhxQLt69OU4hDUfhPCNg442ZDRyVAgaYxOOoPg kkwWzz05eaIgPS/zvJOxcYiRnQBcrc2t2E/1qSD/OUT7zXicnXzQppmg6LWW67T1uVQd cNM/++6wcJhECbVmG4O/Htpv6U9QkUmtmfEkSgDO3GBfRgHERLFFyuAxLVfZgq23l86L VHf94O187ojUkDZ8dBrDGPJpSyVccvesOXsqpWYKGIYz85NjKX8bIkiIbrPpdJWm6oyi yL/w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:date:from:message-id; bh=gZdZ2dvHjtR6Klrnd4vUgMt0CNnRelFZ0/sANfzLpj8=; b=nupwV179fnqsf+E8UbboWhZft/mZL7lKWtE3zA8O9IlTApNII4LNAHzltRUvURC3eu Cw2kGOJ+5rcShPCFIaFDyFXejwRqJjvh0HUNdilAngEByNQ3XivcjbxLkvGVLPdnUMJv HIwAeFOT3uAxc51TsNEwfVXkmjXwVHlOfJUrStSENQ1QNIWnCbTfwQ15aLljJiVtSo82 JnEH1gThla4pBTmvvJB2DYgGDp0WKgnc31ITtzN40Ym2WquTqYsjdnUmLPAQc8R8Hg+F /Vbz16gdT9K6rHFWHd11bPPSKAO8J8J0ztKDYRUomkbTLohOuFgbESNV+NTlFx4V+HLy 4ecw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-ext4-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 m193si3884720oig.77.2020.03.28.09.47.13; Sat, 28 Mar 2020 09:47:38 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-ext4-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-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726445AbgC1Qqi (ORCPT + 99 others); Sat, 28 Mar 2020 12:46:38 -0400 Received: from mx.sdf.org ([205.166.94.20]:50263 "EHLO mx.sdf.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726389AbgC1QnO (ORCPT ); Sat, 28 Mar 2020 12:43:14 -0400 Received: from sdf.org (IDENT:lkml@sdf.lonestar.org [205.166.94.16]) by mx.sdf.org (8.15.2/8.14.5) with ESMTPS id 02SGh9lk016292 (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256 bits) verified NO); Sat, 28 Mar 2020 16:43:09 GMT Received: (from lkml@localhost) by sdf.org (8.15.2/8.12.8/Submit) id 02SGh9vH007105; Sat, 28 Mar 2020 16:43:09 GMT Message-Id: <202003281643.02SGh9vH007105@sdf.org> From: George Spelvin Date: Mon, 18 Mar 2019 21:32:20 -0400 Subject: [RFC PATCH v1 08/50] fs/ext4/ialloc.c: Replace % with reciprocal_scale() TO BE VERIFIED To: linux-kernel@vger.kernel.org, lkml@sdf.org Cc: "Theodore Ts'o" , Andreas Dilger , linux-ext4@vger.kernel.org Sender: linux-ext4-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-ext4@vger.kernel.org This came about as part of auditing prandom_u32() usage, but this is a special case: sometimes the starting value comes from prandom_u32, and sometimes it comes from a hash of a name. Does the name hash algorithm have to be stable? In that case, this change would alter it. But it appears to use s_hash_seed which is regenerated on "e2fsck -D", so maybe changing it isn't a big deal. Feedback needed. Signed-off-by: George Spelvin Cc: "Theodore Ts'o" Cc: Andreas Dilger Cc: linux-ext4@vger.kernel.org --- fs/ext4/ialloc.c | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/fs/ext4/ialloc.c b/fs/ext4/ialloc.c index 7db0c8814f2ec..a4ea89b3ed368 100644 --- a/fs/ext4/ialloc.c +++ b/fs/ext4/ialloc.c @@ -457,9 +457,8 @@ static int find_group_orlov(struct super_block *sb, struct inode *parent, grp = hinfo.hash; } else grp = prandom_u32(); - parent_group = (unsigned)grp % ngroups; - for (i = 0; i < ngroups; i++) { - g = (parent_group + i) % ngroups; + g = parent_group = reciprocal_scale(grp, ngroups); + for (i = 0; i < ngroups; i++, ++g == ngroups && (g = 0)) { get_orlov_stats(sb, g, flex_size, &stats); if (!stats.free_inodes) continue; -- 2.26.0