Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp489980rwb; Thu, 12 Jan 2023 23:50:31 -0800 (PST) X-Google-Smtp-Source: AMrXdXtPqkfV6QJMQg4Q6oFNvWhMubK7wmk37TlS3o0JmZwztTfYnJzfp3ZQTvh03q3cs3kBI5s1 X-Received: by 2002:a17:906:cd0b:b0:84d:463f:3787 with SMTP id oz11-20020a170906cd0b00b0084d463f3787mr16014307ejb.5.1673596231325; Thu, 12 Jan 2023 23:50:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673596231; cv=none; d=google.com; s=arc-20160816; b=0h5tF0vmDlko4pqZpaRA+mQUFOXHTHb5j1Fe/9lFRjCgfyCrGUvmRUce0W8L6v7U4V wuLJQGBmrJLITra3nQ6+ULZuRYLRAN+KrZiiQfT/OQcGJ2bx0gw4fgEyudAKOP34N+dI RH2MGIgXLGTdkIpAGjm31rlGGPu+vOwGYueN+cNPlq04ANoIAILuExyL9VefgUvp92PA ou4nKikd4udf+1rJ7i/40+4r/KCVP/5rVjCThxslMin96kDgpuNLEHK2eUd+wQXjcNIy 8fof/xga8wlr83SAi5DzUCDw6eFIE8ISc59SSLijF0+SqdYW6msfHmOu1+LDU6e6olP2 zE2A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :content-language:references:cc:to:subject:user-agent:mime-version :date:message-id; bh=ef3VRBIboeZKuVHNF4AjuPL6626cVsFCr5V4MnRvDi8=; b=fcObW1XFAn6B7aM3GTdhN74MJHPovZd+fJh6THh8aMDD0jI6Y69suwkhZ7jefQXfsv i7P8bhAM9kZFVf1iATOZkXTXGqwf3sMX6aNmNOwHuYR4qh/qQjtv3a+tW71Q1iRT5pXD 3qYK1t8KAz0A8niCLxKk8yLmP5Rk75L5IpaCEm3/BfRUtNfGITgk6JCx9KMsk4LMsyXw NiK2Q+7fa1bhbAzrLm/JcWLWjRdSSLCbWxi+9ierEnum9MMyuiHSNN1ToGGowZWX81NM m/3ryAqiJiARhp10fn1k+tA9y+nWgNn5RZO4NQfYs0sebsO2mLco2tLc8IOBAxArRpeY 4pFw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id bb6-20020a1709070a0600b0085a483a6fd9si9388489ejc.212.2023.01.12.23.50.19; Thu, 12 Jan 2023 23:50:31 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234010AbjAMHld (ORCPT + 50 others); Fri, 13 Jan 2023 02:41:33 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35142 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230473AbjAMHla (ORCPT ); Fri, 13 Jan 2023 02:41:30 -0500 Received: from out30-7.freemail.mail.aliyun.com (out30-7.freemail.mail.aliyun.com [115.124.30.7]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A7C8638AD for ; Thu, 12 Jan 2023 23:41:27 -0800 (PST) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R121e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018045176;MF=jefflexu@linux.alibaba.com;NM=1;PH=DS;RN=5;SR=0;TI=SMTPD_---0VZU0FMj_1673595681; Received: from 30.221.130.30(mailfrom:jefflexu@linux.alibaba.com fp:SMTPD_---0VZU0FMj_1673595681) by smtp.aliyun-inc.com; Fri, 13 Jan 2023 15:41:22 +0800 Message-ID: <144922ad-66a3-27e8-df85-4a58c175a630@linux.alibaba.com> Date: Fri, 13 Jan 2023 15:41:21 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.4.0 Subject: Re: [PATCH 1/2] erofs: clean up erofs_iget() To: Gao Xiang , linux-erofs@lists.ozlabs.org, Chao Yu , Yue Hu Cc: LKML References: <20230113065226.68801-1-hsiangkao@linux.alibaba.com> Content-Language: en-US From: Jingbo Xu In-Reply-To: <20230113065226.68801-1-hsiangkao@linux.alibaba.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-9.9 required=5.0 tests=BAYES_00, ENV_AND_HDR_SPF_MATCH,NICE_REPLY_A,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE, SPF_PASS,UNPARSEABLE_RELAY,USER_IN_DEF_SPF_WL autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 1/13/23 2:52 PM, Gao Xiang wrote: > Move inode hash function into inode.c and simplify erofs_iget(). > > Signed-off-by: Gao Xiang > --- > fs/erofs/inode.c | 40 +++++++++++++++++++++------------------- > fs/erofs/internal.h | 9 --------- > 2 files changed, 21 insertions(+), 28 deletions(-) > > diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c > index d3b8736fa124..57328691582e 100644 > --- a/fs/erofs/inode.c > +++ b/fs/erofs/inode.c > @@ -308,47 +308,49 @@ static int erofs_fill_inode(struct inode *inode) > } > > /* > - * erofs nid is 64bits, but i_ino is 'unsigned long', therefore > - * we should do more for 32-bit platform to find the right inode. > + * ino_t is 32-bits on 32-bit arch. We have to squash the 64-bit value down > + * so that it will fit. > */ > -static int erofs_ilookup_test_actor(struct inode *inode, void *opaque) > +static ino_t erofs_squash_ino(erofs_nid_t nid) > { > - const erofs_nid_t nid = *(erofs_nid_t *)opaque; > + ino_t ino = (ino_t)nid; > + > + if (sizeof(ino_t) < sizeof(erofs_nid_t)) > + ino ^= nid >> (sizeof(erofs_nid_t) - sizeof(ino_t)) * 8; Shouldn't we do: ino ^= nid >> sizeof(ino_t) * 8 ? -- Thanks, Jingbo