From patchwork Fri Apr 14 14:07:50 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Andrey Ryabinin X-Patchwork-Id: 9681319 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id 2534160132 for ; Fri, 14 Apr 2017 14:09:35 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 1760728695 for ; Fri, 14 Apr 2017 14:09:35 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 0BF01286AD; Fri, 14 Apr 2017 14:09:35 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-7.0 required=2.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, RCVD_IN_DNSWL_HI autolearn=unavailable version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 7F31328695 for ; Fri, 14 Apr 2017 14:09:34 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753816AbdDNOJU (ORCPT ); Fri, 14 Apr 2017 10:09:20 -0400 Received: from mail-eopbgr50104.outbound.protection.outlook.com ([40.107.5.104]:42301 "EHLO EUR03-VE1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751911AbdDNOIA (ORCPT ); Fri, 14 Apr 2017 10:08:00 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=virtuozzo.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=wRtShmi1xjuJ9edo6dPIeHn/i6dPYHHZfpLDPWNETu4=; b=IQV5JvZXKGMOuQKxOzP9OnounEK3YLw9OMYSbee32t9ZLqiKUVzY9ciGA++A4srkOv00uWsIGA1cwkc+m2CH3BO4Ty15unjEpLYSWFoEcyqHEhdshQnTNbGoQUc6kf0UkDCa9FBCivx+4vYoK09aZw9JdQGf+Am0aCfO1qEjhdo= Authentication-Results: zeniv.linux.org.uk; dkim=none (message not signed) header.d=none;zeniv.linux.org.uk; dmarc=none action=none header.from=virtuozzo.com; Received: from localhost.sw.ru (195.214.232.6) by HE1PR0801MB2732.eurprd08.prod.outlook.com (10.169.123.152) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1034.10; Fri, 14 Apr 2017 14:07:53 +0000 From: Andrey Ryabinin To: Alexander Viro , CC: Andrey Ryabinin , Konrad Rzeszutek Wilk , Eric Van Hensbergen , Ron Minnich , Latchesar Ionkov , Steve French , Matthew Wilcox , Ross Zwisler , Trond Myklebust , Anna Schumaker , Andrew Morton , Jan Kara , Jens Axboe , Johannes Weiner , Alexey Kuznetsov , Christoph Hellwig , , , , , , Subject: [PATCH 1/4] fs: fix data invalidation in the cleancache during direct IO Date: Fri, 14 Apr 2017 17:07:50 +0300 Message-ID: <20170414140753.16108-2-aryabinin@virtuozzo.com> X-Mailer: git-send-email 2.10.2 In-Reply-To: <20170414140753.16108-1-aryabinin@virtuozzo.com> References: <20170414140753.16108-1-aryabinin@virtuozzo.com> MIME-Version: 1.0 X-Originating-IP: [195.214.232.6] X-ClientProxiedBy: VI1PR08CA0039.eurprd08.prod.outlook.com (10.164.95.49) To HE1PR0801MB2732.eurprd08.prod.outlook.com (10.169.123.152) X-MS-Office365-Filtering-Correlation-Id: 46279b5b-441b-4b8b-ce72-08d4833fa65d X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001)(201703131423075)(201703031133081); SRVR:HE1PR0801MB2732; X-Microsoft-Exchange-Diagnostics: 1; HE1PR0801MB2732; 3:mUQdVQ/PM9KCL1YNahPyEb3OmdGkOSVmJd89RhUgTVxaGLcItYzcPbriMo0y1yZiCtGpf0rQLICsV3JrktB9wh6o2jSqqnnAKgAvYFASwcNAcZEG/C/dIk0zCymFSivj5th/Osk0JIDgNoQ0aeVh51iayHNgFcL/J0zpJMDVjPyvoyJi3FEOxI/jk5juc/qALH0+/dJpUWFuHUQUUdlqqAYJPAWQEJwYJQFJ5GwPxAfsns1IkHBHXrCkMNLFV201E6Jd5RJyuqy5ye6ycbzI0FPStBfFr/GmrfOJIw3WQCX10QbcpqyjDQEBqjZ1E2L6dhMQHYrAHQpnZN+vr3NbCQ==; 25:fxuxAgp6iMYGkB+xtvpoPylc4g1jxazKQQ5AXPD6IzCx+A19OyfAFxRrFAr8WVyUox/R1OFGNyIz5A9GZN/mVAHX8+bRuxkPcMT3TrtiA64WDDtqNhJw7d9+Y7TUbkY0jw9ix2J8Qm30G0soctHk/Dbt8M89TiL4zha5eSkixl6YVhlkBbM3QZU0fCeY4VunLoBXwcp1+fhSsRUnpJ6gwqZtns9AmrlU6J2sPT7P+sn6ScOn1Y1IS5TzkIihOf/hJtnd8reuk7N6voBHgPwPKFoRQMPR+giCWAfj0KBcYOjDYzqzdhj7nYkGGjCMCdC/Lp44F+JykhWX4lniNzh2Q3HArpugbDOB11uPnT4lE4A1fBIz+f9YhKjzLhwfNXVzcUjmhJOT9iRGRnE9Nx3ssue/wRaMuxRRrCvROGbGB/jvYlQn00XRU+NZVG3Fy5em4n5iQUvrbAzbxkNudEFd3g== X-Microsoft-Exchange-Diagnostics: 1; HE1PR0801MB2732; 31:8hvZaBlgyKsgoM+ci+b3TtlGQn2TFgtecVyOwfdE6CG7GKXgMjJq/tOAV2F0Ujx01wV3uUW+zidRQhgtwcgl8+2vo2/HSn8EX3RWBi1Aj5jZYw3hN3nMyY+8U/g9Xrm9wt3vNyoap6UGk8ZbO1wyxK9FXG2HeZqdEnPg7QAQAugh93q6t5JU8Qar59FZusBlyhGd/Ga3GqeeJYxJe4CfkEaOkln5gcn5ls+k5cotbJasvRH6LueLxggWbdvl+KZu; 20:C39DTR5DjNVzR8WeK5AXC0e0+6A3h4UFXhmtu+1NzGV6OMfBrJnHF3tKfJGND6VvYmmcDaHUDlyrC1T6JGSnQ+H3IqcdHbZYrR06uIYLbX6UtMcGxkOTUmuhcLINl1cTH5LPTSrZR5XB+uadvz+L6VCtiDX1q+VWt6qaPk0mbytFplbxhQ631cGs9Jn6BR9x7dtvdOY11SThI0/6RpGARu2hk+DWO2ZPnNL3TRpvGP7ie8HhbjD61J4RVtOuhWr190p7tjmAl598FwPWJ5BritesuciWQpGahWSeWqvQMT4pcMnKG7/esDmwLlGYji14E/21ZvJI7VvZwYAc0ghraFfNTd8klHVKdD4MbCuNQBZg5rL84tQrrSlhmwzdQjVTXseDRtbhC+iAZq/rMV1tPlwt+hF7TwPIaSp0WgjOMMI= X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(6040450)(601004)(2401047)(5005006)(8121501046)(10201501046)(3002001)(93006095)(93001095)(6041248)(20161123564025)(201703131423075)(201702281528075)(201703061421075)(20161123560025)(20161123555025)(20161123562025)(6072148); SRVR:HE1PR0801MB2732; BCL:0; PCL:0; RULEID:; SRVR:HE1PR0801MB2732; X-Microsoft-Exchange-Diagnostics: 1; HE1PR0801MB2732; 4:NhrK+eC3px9Ro/3vZRztBt4zsC2tw/ZPbKjNhxYTFNL33P9WoIf7xgKrvxof01OkJnr/pCMafao6zSUZLwk0H7vqFK7KesrFSJq9Cyw+ktc/XQGJGCJKvQjKWIpfgdiXwo+/p9wPMqqBzTh9QiaY4pBQpHf1k4lXAmSLSxIn+23tTE+LCkVompSF+1fUOPc6d5yJBLDtEvMdpUSEGxycEV/q88VH6tWe4cfYMOZOqJofO0eMIB7D1NZbNv88lpNkURzl+GcKa6sjK9rF5nrC9jFveoqeoRbVHr0tARjrrg/WF93IsYnlbzBplF7959gxTJm4ayVRey4f5USnrJeRg3NW2Bp/nNHA6DDvxDxhMBWRoO24uGAYPVspa/Tf4iGvcEjwrxXrcGJ6ssmONbz8pblJVdDp0wCQ8CjkTvDKVt5c7dvSsHoLbvu89ACpQalbTIUUEt3muaFvg1N8kVbD0gAYRLx2X+ItUVqdt3vO56Qz3HqW1mJlB9nfcaNC3iQViVkyShzDO01dbS68cpxAPov6FDHo9ATSwbzI3+1EDIaQw0yW37jo+d6mE55u2HNmXpMV7psBSpkNiWKZ1lodm9i4CQslC/TxU+EIu5fOJr84dVKcNadRmfy+O4zd4qKBAFfWIFBLO6kAaZBRi8cBOejkgPTwNuXxhZyXrqq7NzHjIYaUe1Ls4eYS0QcmydXlBkhf4LAnFB9DtQ+GqQs3ZA== X-Forefront-PRVS: 02778BF158 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10019020)(4630300001)(6069001)(6009001)(39410400002)(39400400002)(39830400002)(39450400003)(81166006)(6486002)(86362001)(54906002)(7736002)(575784001)(305945005)(50466002)(66066001)(47776003)(5003940100001)(50226002)(48376002)(2950100002)(1076002)(33646002)(53936002)(5660300001)(4326008)(6512007)(50986999)(76176999)(7416002)(25786009)(53416004)(6116002)(3846002)(8666007)(2906002)(36756003)(8676002)(42186005)(6506006)(189998001)(38730400002)(76506005); DIR:OUT; SFP:1102; SCL:1; SRVR:HE1PR0801MB2732; H:localhost.sw.ru; FPR:; SPF:None; MLV:sfv; LANG:en; X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; HE1PR0801MB2732; 23:lHIQIZWoxibhq6mirGyLdxXK8UoLi9x6VFyjFLW?= =?us-ascii?Q?TQqISvmUlbeS5JUF8MS1LEKaBGa2o9jYN37HcFL6FdvxZ/sMWHSn/OsuT5Jo?= =?us-ascii?Q?asQxt2qlNpYytn6eKBA2bkYettj9iDPxa1MqKJkZYFNODUQsBTnEYtZGiqNa?= =?us-ascii?Q?PY+Dnh8VAkJDPdoeWTXJ5dNQasKpM2l4lPvS190zzCLJP/nnRtscZ57d1wMM?= =?us-ascii?Q?jIgPj+aMiXkBAOUdGN815NYGymsHifC52I0sqopEd27Heyt1m7kgGjtLyB0y?= =?us-ascii?Q?/dO9T9JnM7jPnhS6N9HCokrQ86fcQksNkW4Z8J0gVx1LCWKXpdTEvHbZIh2q?= =?us-ascii?Q?nw3wHAxQnyRrTpoh0JuBTby3f4XTvESjKUtE2MXjIEU9mtezhHF6oVNrVTtO?= =?us-ascii?Q?2Wpfm91A9tIUEimwHDqPEi7Q9e14i2VJmtoTDsDKWUirB50xrvD5gfc/TiYP?= =?us-ascii?Q?Qdogns9v5QUK5llt2Cxqb9/2/aBXe8GWM2b3ljiHwW2kbeBZJFhpdzOgE/Cs?= =?us-ascii?Q?D6WvQgMMT6GWgr7F+jcE3KOyIjTAYJ6UeJH+UJq82b7XjUHIl3ur6x+ZDdJl?= =?us-ascii?Q?XehZxRybArH9J8exlml99xhjJ9Mb1BTrpbsOtU2qmkh2+5F7duounyyDDeJu?= =?us-ascii?Q?eM+Yhe8dlkdkrjQfe9h35EdDj60P0Oat00rHYIFOxQbSaoH39xilUVMO9o9j?= =?us-ascii?Q?QL4Rux63blNAzizIVig+GQ8iWh0XXmGpF5uyXlWC8JqRiSa07LUB2md0XWFe?= =?us-ascii?Q?MskIWSBWlLLv1MylV4eNCZQLB/04NdFu2FTFxWy+QxAdfWaXLKhtMsCmep4P?= =?us-ascii?Q?5/9AyBlIvLJpMwV4Pq8iEyFIvIEjxNeqjjOA9FD7xOh9Nd/IzX2c/XCwOx7j?= =?us-ascii?Q?8y3Cc9FiyE/5yGv2GT+qMrGPB6EwnnCoeFL2YX92IGLVzBNm6ttSaViefYpM?= =?us-ascii?Q?7UkRUJQataqjwd26i9KTtLyK4qakKAqYotwV3h1VkjyTruCBtsAatdq232ss?= =?us-ascii?Q?JUy/oj3z90ixWSc1mW4WfibvvF+URNckznjO5gm2zzrXLk+dlDagIZkxfdVa?= =?us-ascii?Q?lcwyaLEp7fyOf7cLQqEU9b/kQ+2/L?= X-Microsoft-Exchange-Diagnostics: 1; HE1PR0801MB2732; 6:GTIFw2OmjZQ17e127RWc/NvQDWCHUMxrH+sID4Af175kG/rA9rM1K+gHd4BBKMtd3her09tkIyLgEfPjYW3ey7hp1belVhL+X/Px4/D/sXct2mgGGU+zeqYyeCi190UvDVBICrezhggSIfZ14SFCFyvxRttM27O1zNSCX4u1kwyJSdWYMKyBpLi/o3fD0taiCtp8IBjhgv3ChxKev8gQr/DlbHmMt9d2d5wkZI3Urfat3aMB95NAqv4Fulcd6xn85ZlV4grIyxOG/e3rIbqIWfUZjSd66GItbqI02XrTRYGoa3mz1kkhpnLPmp0VudQ291k/u6oi0YE4O4rBpHKEC7k5WYeh+s4d+lSmDd/hzeni76cBTgeCeazlV2lnD2H9ACxGHyX64vhQSGDNe0K3/l31TstPIyJEfXYyABpOsLw/cNyb8QZ5PcV7L37+E2+s6Jse1N1qBA93TqNFF0kLYQ==; 5:vmfLPhAsS2DwzL9HnOfz7TbTEKC8PNVfQK+zzk1uCTFOX7lcLSE2ru/YyvEkUitYFBD/k+WpuN8t4tbDT4fidsd7kPqQnxwLwnPacjojhY9zyQgX71ZtQ7QNuxb7Rt/f8xCL1HPg0MRJSCe5FLniuw==; 24:V/choIzsv3XACV6B4NOjhuGlyjKynAysWF1UwbGV1/f7eSTA5IQmHq0xlrqMfI5mFr9X9i3Mk+4WseflvKBT8li1fmK7R79f9bOokU6OPSo= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; HE1PR0801MB2732; 7:wca9Xs0wyvU5eosO+EgOZvPsR2T9Zqo82b488kEbW7FdTXVC0xDM2geK4tU352rNy5L0yGsAkQmgnyaasveAK8DK1aGxK/HcuNugWjzlMXGd1Qql5HitVJEZIBEbXNPPOfXx9Mdwniy6iAAh8wosdc2ddKkGZ8acbV7Ftxh9xemeCAh7Yk76bb6mN63ly41xZMTA26FrVs2cEUWRYN/o2cMB6pmZo6/HQKq6Dc4V1qXSfK2TmL1iBsu8afXF8z06s/+fO/ecDZ1lKtN2yQwSdyoa5Jr7DyVHt0cE9N6EjzkiJ48R+n38C3V19gIITmnO9YpYrTYFvlZuuI010OSODQ==; 20:9oAnz7M9P6SfZeS0UKhzkzaPLeJ6kcH2AUWGIeBx2fruC8K6fJS6dQ7YpShFCXNiNesqw6pIBvOvaPNe4VIAvWJByuXUXaKYjOqbiXJB7NM1hWodF2BO90AVrKzKSRPstQKWDGxfa2Ik6ES6clFNWzbTi7IICHy/Q4WIKSdgl4U= X-OriginatorOrg: virtuozzo.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 14 Apr 2017 14:07:53.7175 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: HE1PR0801MB2732 Sender: linux-fsdevel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-fsdevel@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP Some direct write fs hooks call invalidate_inode_pages2[_range]() conditionally iff mapping->nrpages is not zero. If page cache is empty, buffered read following after direct IO write would get stale data from the cleancache. Also it doesn't feel right to check only for ->nrpages because invalidate_inode_pages2[_range] invalidates exceptional entries as well. Fix this by calling invalidate_inode_pages2[_range]() regardless of nrpages state. Fixes: c515e1fd361c ("mm/fs: add hooks to support cleancache") Signed-off-by: Andrey Ryabinin --- fs/9p/vfs_file.c | 2 +- fs/cifs/inode.c | 2 +- fs/dax.c | 2 +- fs/iomap.c | 16 +++++++--------- fs/nfs/direct.c | 6 ++---- fs/nfs/inode.c | 8 +++++--- mm/filemap.c | 26 +++++++++++--------------- 7 files changed, 28 insertions(+), 34 deletions(-) diff --git a/fs/9p/vfs_file.c b/fs/9p/vfs_file.c index 3de3b4a8..786d0de 100644 --- a/fs/9p/vfs_file.c +++ b/fs/9p/vfs_file.c @@ -423,7 +423,7 @@ v9fs_file_write_iter(struct kiocb *iocb, struct iov_iter *from) unsigned long pg_start, pg_end; pg_start = origin >> PAGE_SHIFT; pg_end = (origin + retval - 1) >> PAGE_SHIFT; - if (inode->i_mapping && inode->i_mapping->nrpages) + if (inode->i_mapping) invalidate_inode_pages2_range(inode->i_mapping, pg_start, pg_end); iocb->ki_pos += retval; diff --git a/fs/cifs/inode.c b/fs/cifs/inode.c index c3b2fa0..6539fa3 100644 --- a/fs/cifs/inode.c +++ b/fs/cifs/inode.c @@ -1857,7 +1857,7 @@ cifs_invalidate_mapping(struct inode *inode) { int rc = 0; - if (inode->i_mapping && inode->i_mapping->nrpages != 0) { + if (inode->i_mapping) { rc = invalidate_inode_pages2(inode->i_mapping); if (rc) cifs_dbg(VFS, "%s: could not invalidate inode %p\n", diff --git a/fs/dax.c b/fs/dax.c index 2e382fe..1e8cca0 100644 --- a/fs/dax.c +++ b/fs/dax.c @@ -1047,7 +1047,7 @@ dax_iomap_actor(struct inode *inode, loff_t pos, loff_t length, void *data, * into page tables. We have to tear down these mappings so that data * written by write(2) is visible in mmap. */ - if ((iomap->flags & IOMAP_F_NEW) && inode->i_mapping->nrpages) { + if ((iomap->flags & IOMAP_F_NEW)) { invalidate_inode_pages2_range(inode->i_mapping, pos >> PAGE_SHIFT, (end - 1) >> PAGE_SHIFT); diff --git a/fs/iomap.c b/fs/iomap.c index 0b457ff..7e1f947 100644 --- a/fs/iomap.c +++ b/fs/iomap.c @@ -880,16 +880,14 @@ iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter, flags |= IOMAP_WRITE; } - if (mapping->nrpages) { - ret = filemap_write_and_wait_range(mapping, start, end); - if (ret) - goto out_free_dio; + ret = filemap_write_and_wait_range(mapping, start, end); + if (ret) + goto out_free_dio; - ret = invalidate_inode_pages2_range(mapping, + ret = invalidate_inode_pages2_range(mapping, start >> PAGE_SHIFT, end >> PAGE_SHIFT); - WARN_ON_ONCE(ret); - ret = 0; - } + WARN_ON_ONCE(ret); + ret = 0; inode_dio_begin(inode); @@ -944,7 +942,7 @@ iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter, * one is a pretty crazy thing to do, so we don't support it 100%. If * this invalidation fails, tough, the write still worked... */ - if (iov_iter_rw(iter) == WRITE && mapping->nrpages) { + if (iov_iter_rw(iter) == WRITE) { int err = invalidate_inode_pages2_range(mapping, start >> PAGE_SHIFT, end >> PAGE_SHIFT); WARN_ON_ONCE(err); diff --git a/fs/nfs/direct.c b/fs/nfs/direct.c index aab32fc..183ab4d 100644 --- a/fs/nfs/direct.c +++ b/fs/nfs/direct.c @@ -1024,10 +1024,8 @@ ssize_t nfs_file_direct_write(struct kiocb *iocb, struct iov_iter *iter) result = nfs_direct_write_schedule_iovec(dreq, iter, pos); - if (mapping->nrpages) { - invalidate_inode_pages2_range(mapping, - pos >> PAGE_SHIFT, end); - } + invalidate_inode_pages2_range(mapping, + pos >> PAGE_SHIFT, end); nfs_end_io_direct(inode); diff --git a/fs/nfs/inode.c b/fs/nfs/inode.c index f489a5a..b727ec8 100644 --- a/fs/nfs/inode.c +++ b/fs/nfs/inode.c @@ -1118,10 +1118,12 @@ static int nfs_invalidate_mapping(struct inode *inode, struct address_space *map if (ret < 0) return ret; } - ret = invalidate_inode_pages2(mapping); - if (ret < 0) - return ret; } + + ret = invalidate_inode_pages2(mapping); + if (ret < 0) + return ret; + if (S_ISDIR(inode->i_mode)) { spin_lock(&inode->i_lock); memset(nfsi->cookieverf, 0, sizeof(nfsi->cookieverf)); diff --git a/mm/filemap.c b/mm/filemap.c index e9e5f7b..d233d59 100644 --- a/mm/filemap.c +++ b/mm/filemap.c @@ -2721,18 +2721,16 @@ generic_file_direct_write(struct kiocb *iocb, struct iov_iter *from) * about to write. We do this *before* the write so that we can return * without clobbering -EIOCBQUEUED from ->direct_IO(). */ - if (mapping->nrpages) { - written = invalidate_inode_pages2_range(mapping, + written = invalidate_inode_pages2_range(mapping, pos >> PAGE_SHIFT, end); - /* - * If a page can not be invalidated, return 0 to fall back - * to buffered write. - */ - if (written) { - if (written == -EBUSY) - return 0; - goto out; - } + /* + * If a page can not be invalidated, return 0 to fall back + * to buffered write. + */ + if (written) { + if (written == -EBUSY) + return 0; + goto out; } data = *from; @@ -2746,10 +2744,8 @@ generic_file_direct_write(struct kiocb *iocb, struct iov_iter *from) * so we don't support it 100%. If this invalidation * fails, tough, the write still worked... */ - if (mapping->nrpages) { - invalidate_inode_pages2_range(mapping, - pos >> PAGE_SHIFT, end); - } + invalidate_inode_pages2_range(mapping, + pos >> PAGE_SHIFT, end); if (written > 0) { pos += written;