Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp1822326ybk; Thu, 21 May 2020 16:31:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx1Mt82WvyFzEJMxQdRPxHYWymao3cAOo/VB5DExCEJavSA9nuzm09Nga5tJaRCe0fvQdt0 X-Received: by 2002:aa7:d3d6:: with SMTP id o22mr930026edr.310.1590103861290; Thu, 21 May 2020 16:31:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590103861; cv=none; d=google.com; s=arc-20160816; b=W9PTRb8XZwK3XKXwhvJjkkBXIAjVtVByiDE/3xkC0CfhAKaTJJnycCtFsQlQsc4eTz EEqvZ8lFXP47rnB4ysp8Wha/fnLnsueQNcl2OJ4JJ5DPshui+jKOdkZc+sf29eDB1o5g RkB9/jqcv70+E6+aN7QnBYd13ptbLd2nJdBPqyNfmVzIuYarFRlOwdX9A53OK6VjZ3fN Bym7Mr1yI62h19cFwOr57p+Oi9q0tdIytrn9urf9Rq5DnUrmoS6hcQeyStodTf5GqweO aTlIFJsgfx8v4noZheLkCxmUkVIK4sgwE6G/Dpi7X706wycoyTmBINXkuE8U70Jmadva ZQCw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=9+Y4GrdpClNs6dOQez6Q/Hq2GUKZ7fNwPhgdPdL175M=; b=qqYUwA9nhS7lKfJ+vWtveOzAVIyXA4WJ51Rp4qL8b6WA5+tGiHnsy7NB+iZ7WStcvL w2tCj3Y/+vQnKPfYUkrYfqtNn/IqDvqPr63IqcUsI4xhGk+Z8N73D6mJXDOAzgHu/9ww +CdvWxc6XYlc71BpP6FPvzq2KxvRNm/F/IsKumzw+2YldKYz0p24EiDsvRwVZmPWCJ6E pNjU4CriCb9QlNqiwgHEq2OlLjBgdNZ18VjgiaKKczYnt69XW5Y/ktjQRcXVsB8B3yrH DV1Hne3/uj2T92xqr1zVSpZYPOQBDJ7ByyrIVOqwyutI5q1w3GtgDZLrXkYaSSc0LiyV adxA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=bmUoelMo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r14si4175488ejs.548.2020.05.21.16.30.36; Thu, 21 May 2020 16:31:01 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=bmUoelMo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730774AbgEUX3K (ORCPT + 99 others); Thu, 21 May 2020 19:29:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54970 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730041AbgEUX3K (ORCPT ); Thu, 21 May 2020 19:29:10 -0400 Received: from bombadil.infradead.org (bombadil.infradead.org [IPv6:2607:7c80:54:e::133]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 29C66C061A0E; Thu, 21 May 2020 16:29:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=9+Y4GrdpClNs6dOQez6Q/Hq2GUKZ7fNwPhgdPdL175M=; b=bmUoelMosRe7hQUHZlH2tUXoEg pReNbQUridxcNh44KO8glMSsmIlRzgp5vwVfJjYirSM/LAxReB2EEpA+NU6Yja9F6wMdtAxwlmY2c octCCt9G7beTA4sx5i+obaKgJ+1KG13qUCPE4XSMCx638L8FYXmT/y97mXqr4cdKh1X+tFZIFQlV2 2bQyW6KPkz6KKNVTrfqauKKlBObAz6rne7fV95zdnvA9AusqZgdp1WTa89QE5R8jROfBEVhPCzZzz C151YNultnIGYtRsfPtcZkSM3RM1dtP0ikHJx8B4qQT6ncom9p5s79Shss0UCQ0oA8D7PCHMEwtzM F1H8CvhA==; Received: from willy by bombadil.infradead.org with local (Exim 4.92.3 #3 (Red Hat Linux)) id 1jbucd-0006Jt-0Q; Thu, 21 May 2020 23:29:07 +0000 Date: Thu, 21 May 2020 16:29:06 -0700 From: Matthew Wilcox To: Dave Chinner Cc: linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v4 07/36] fs: Add a filesystem flag for large pages Message-ID: <20200521232906.GF28818@bombadil.infradead.org> References: <20200515131656.12890-1-willy@infradead.org> <20200515131656.12890-8-willy@infradead.org> <20200521215523.GR2005@dread.disaster.area> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200521215523.GR2005@dread.disaster.area> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, May 22, 2020 at 07:55:23AM +1000, Dave Chinner wrote: > If you've got to dereference 4 layers deep to check a behaviour > flag, the object needs it's own flag. Can you just propagate this > to the address space when the inode is instantiated and the address > space initialised? Sure. I'll fold in something like this: +++ b/fs/inode.c @@ -181,6 +181,8 @@ int inode_init_always(struct super_block *sb, struct inode *inode) mapping->a_ops = &empty_aops; mapping->host = inode; mapping->flags = 0; + if (sb->s_type->fs_flags & FS_LARGE_PAGES) + __set_bit(AS_LARGE_PAGES, &mapping->flags); mapping->wb_err = 0; atomic_set(&mapping->i_mmap_writable, 0); #ifdef CONFIG_READ_ONLY_THP_FOR_FS +++ b/include/linux/pagemap.h @@ -29,6 +29,7 @@ enum mapping_flags { AS_EXITING = 4, /* final truncate in progress */ /* writeback related tags are not used */ AS_NO_WRITEBACK_TAGS = 5, + AS_LARGE_PAGES = 6, /* large pages supported */ }; /** @@ -118,7 +119,7 @@ static inline void mapping_set_gfp_mask(struct address_space *m, gfp_t mask) static inline bool mapping_large_pages(struct address_space *mapping) { - return mapping->host->i_sb->s_type->fs_flags & FS_LARGE_PAGES; + return test_bit(AS_LARGE_PAGES, &mapping->flags); } static inline int filemap_nr_thps(struct address_space *mapping)