From patchwork Mon Aug 22 17:35:02 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Josef Bacik X-Patchwork-Id: 9293989 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 20601607F0 for ; Mon, 22 Aug 2016 17:35:46 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 0FCAB289E4 for ; Mon, 22 Aug 2016 17:35:46 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 01B9528A3E; Mon, 22 Aug 2016 17:35:45 +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=-6.8 required=2.0 tests=BAYES_00,DKIM_SIGNED, RCVD_IN_DNSWL_HI,T_DKIM_INVALID autolearn=ham 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 29991289E4 for ; Mon, 22 Aug 2016 17:35:45 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932233AbcHVRfi (ORCPT ); Mon, 22 Aug 2016 13:35:38 -0400 Received: from mx0a-00082601.pphosted.com ([67.231.145.42]:57175 "EHLO mx0a-00082601.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752999AbcHVRfg (ORCPT ); Mon, 22 Aug 2016 13:35:36 -0400 Received: from pps.filterd (m0044010.ppops.net [127.0.0.1]) by mx0a-00082601.pphosted.com (8.16.0.17/8.16.0.17) with SMTP id u7MHZ3U4026073; Mon, 22 Aug 2016 10:35:25 -0700 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=fb.com; h=from : to : subject : date : message-id : in-reply-to : references : mime-version : content-type; s=facebook; bh=eWsW5ls4qtIxPnztRvth5bwA6RbRt6FqNZQRox2mdgQ=; b=Q2MT++YWvUec0biD48Bm/ZI5ttlWi5aIG1yq59XY7lNbznDN2B0z2AK2z9yarzEyoI5m 5SETXF4htlOS5x56WxOJxR/UXtc/sowa3EKW8BeFPy5cDDizGVlnOVPZ1v4V0LsYB3N0 GRPXStniGuFCPwbPNrt1pa7wJ58DRBFZx7I= Received: from maileast.thefacebook.com ([199.201.65.23]) by mx0a-00082601.pphosted.com with ESMTP id 25049bgp8a-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Mon, 22 Aug 2016 10:35:24 -0700 Received: from NAM01-BN3-obe.outbound.protection.outlook.com (192.168.183.28) by o365-in.thefacebook.com (192.168.177.26) with Microsoft SMTP Server (TLS) id 14.3.294.0; Mon, 22 Aug 2016 13:35:22 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fb.onmicrosoft.com; s=selector1-fb-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=xvhJ7M+G3rNmlEFYb4FJLsx3w4jfwbiAcKxyU22qlVY=; b=Ebm7roje3EGeV/RT+tv37lzsfRMVC6o647VcUUF+IYf42lo5tJXMxCLmI0DIsy6sw/oHjHoLN0CtRlpiBi2/V7+JYeOqPqOi1gPnELz0YobUwgvhOReQKKhfAz6HgE6oxLBuO/AXuyd5l8tlSNOgc4J5w4nw3sTmPBXr9ctdQbc= Received: from localhost (107.15.72.49) by CY4PR15MB1317.namprd15.prod.outlook.com (10.172.177.22) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA_P384) id 15.1.587.9; Mon, 22 Aug 2016 17:35:20 +0000 From: Josef Bacik To: , , , , , , , Subject: [PATCH 3/3] writeback: introduce super_operations->write_metadata Date: Mon, 22 Aug 2016 13:35:02 -0400 Message-ID: <1471887302-12730-4-git-send-email-jbacik@fb.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1471887302-12730-1-git-send-email-jbacik@fb.com> References: <1471887302-12730-1-git-send-email-jbacik@fb.com> MIME-Version: 1.0 X-Originating-IP: [107.15.72.49] X-ClientProxiedBy: DM3PR13CA0027.namprd13.prod.outlook.com (10.164.193.37) To CY4PR15MB1317.namprd15.prod.outlook.com (10.172.177.22) X-MS-Office365-Filtering-Correlation-Id: 9d8a0af8-ed29-4262-1136-08d3cab2b076 X-Microsoft-Exchange-Diagnostics: 1; CY4PR15MB1317; 2:z0ROH+HBD8PTBAnvLsVL+w/TpZwvBQ56M0XPjCepg8PRchctkuu29nYClViyY/4U5OAK6w8+835k1KR4nIr9xG9N4l1iOX93TqtnvlNuTTdtuDrkfHFVqhbJxvs59ugbcvi3Vd9HaD/I5A6GIlPqDBHRGDDqapX2G8zJzWN2E7m0mj6JkdNe6o8xrO0TPQJX; 3:9T6VsNbLYgM/GCMHhkA1Q+TMbxanTd0fF+qclSJR1RqgDda7TIKPCDK1SeP9XrBXXySlaiRfsRTV8Cxx2hopJQO5PzuWyBUR3dYyLtjM8rWCUNjof9CQi/XzPXCt74ZA X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:CY4PR15MB1317; X-Microsoft-Exchange-Diagnostics: 1; CY4PR15MB1317; 25:upEk4Xx7nqDJiNBqEQPg8jWR5S/IsZ5hoxd74Yb/mgrC6siblew2O40mD8oEMBKPiegnUSnA+yd5XZ7byBtBAsIsx9a64VkpaVVH3VWPwclYNQK8rJZAkYlN8/olZd5uonw5OLZ/Tscu/LwMolA9CvFkSXZX+bdOYoZhwHZ+0vZz+q0VVj0S9nPZNLh/GAHsu9h7d3/PRKNb5yuUMBJk93goi7ZAB+WQ5qWDpMK5ZEls9O6VAzlLy8IBjiR5H9Ie3wm2X0sX3+Da6to7dc+ks0XlCBH5X+FId4Cp5gD91zp5ySxMkiM1f5nzCsaLgmrZM/5j0C9i/sTeTssKBb1U24ww6VlzGOctMubMHHaf3q+PCt6tEoKiDPjqH6L1KnwvUrOyJucveTISCgxSzWp3PikHjdSa3U3WnLLGGXO8Wn3nY7RH+nWWPYcbxruFy7VbG4Ssc95XEk4NePqthAnurxGLzWFf5hJcWGX3AUwUw/5bn75/9cJD1vqw9WpZnPXoBm8R7C2p0G31VJfJvzaX541tA4PBHqmgxevlDedCnBG1i+gDaUKkmi5gVgHEsc3g7nbEWt/cqytj8K6gTkQz6xu990S0YNadS9XOLAmggHTGrbdiEkLF13LWkbbOhalQYgYSP3I1FuIABUvBp9kCPyVX4trifmKFQrPubv8SQV/iHzd+ExX2k+rgr/aPyVBCjdd6Lyad8rRAj2NJAxRHhH3EmNk3X99cupRH8crQGpA= X-LD-Processed: 8ae927fe-1255-47a7-a2af-5f3a069daaa2,ExtAddr X-Microsoft-Exchange-Diagnostics: 1; CY4PR15MB1317; 31:3ifiqMG1/e/5RmBL2Hw1OVAc6tcKpGjEaS/Tm+tg3n9mWkmywAVtsEA/HN99p3IMehmJbZUHVHtyYJKx9rsd+A/mwTgnz9+n66m5zJmfCXxu0J5FOWQCaXeG3GFTF0TjFV4KE4wY4RzbNZupCZHMAztwz8AhUWUBmbN42flM7qNIJVhK4/oGpSoe8Klvq7dMzXaFiD8+nhX8o0oojslJ08L6P9wgQRfCxBN0fv6Kbl0=; 20:PZXFEuyAbYdZLEy6Cmfg9hXkIkcFdAJhf7iSgU9sju+xoWmnftfepZzkuSzwGCxF1cMDStcHI6TH5wAHwGmZQ2SWVYifm5D40zBniQmZw3WatI6DDj1x/SF/fJml5+voacwalEQ3+97V3DiGrewK+ltMymFJqzaYraYqw4Rw9w8=; 4:LM1ghJWCWz/921sjKaMPDCW+EGufaPOjlIDfPieUEq3CZmFi+Cw6ntZZzQiWRyNU3S5zfeXG2graNOTJAq+Tm4TvFv/XLznPTVroe7bY2v8S686wwOaS+t8a6lj+K8lcEt2M9HHNHB7fK57ShL0JG/peCFAZw2BkqgSYUvMIWNxANHNtRniISraIQxh8e4exsC8GoRIPrFPLgDhmEjTFyXl/cWWYoE8KIb7zUXnS49EvE5a5AgL9dlwT+JQXETLvghVEXbzKoyYcCQEDQR87lUXB0U/LFKMuVfZvg6LQ0ffrL8vmL8F9H0cIRuPk5gele5HS+SaZsi0CLQ8fQaUkPDh+v+UMb0M0tuwmQ7sM1DxgZEpH8phD93Ey9ej/kRy/OZdWmfu2/9mw96RPvYKpKzD83q00Lrq2Cr7OzS3yeHjAQ7P+qJvET6KkXPy6OdQA X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(67672495146484); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(6040176)(601004)(2401047)(8121501046)(5005006)(3002001)(10201501046); SRVR:CY4PR15MB1317; BCL:0; PCL:0; RULEID:; SRVR:CY4PR15MB1317; X-Forefront-PRVS: 00429279BA X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10019020)(4630300001)(6009001)(6069001)(7916002)(199003)(189002)(19580395003)(19580405001)(189998001)(42186005)(36756003)(586003)(3846002)(8676002)(92566002)(6116002)(7846002)(50226002)(7736002)(66066001)(97736004)(107886002)(68736007)(305945005)(5001770100001)(81156014)(5660300001)(47776003)(5003940100001)(81166006)(229853001)(106356001)(105586002)(76506005)(101416001)(77096005)(2950100001)(2201001)(76176999)(33646002)(2906002)(48376002)(50466002)(50986999)(575784001)(86362001)(4720700001); DIR:OUT; SFP:1102; SCL:1; SRVR:CY4PR15MB1317; H:localhost; FPR:; SPF:None; PTR:InfoNoRecords; A:1; MX:1; LANG:en; Received-SPF: None (protection.outlook.com: fb.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; CY4PR15MB1317; 23:5OaeE+ka9xyhVllcGvmNi063bp1h+AL4lgQZvvqFI?= =?us-ascii?Q?dxNt51/MO8JLifmfJ69XdxvrhEZvQKfcbB6Ug61+xXsyuTSZVfwfGoV+oSfb?= =?us-ascii?Q?2o8JGkL3HnGSjrB7B3k85otGVe2qUqoLGhApg6V0wDbZRAV1y6Kqw4UjNBts?= =?us-ascii?Q?ISiPbSe/soRq/OsyWoRKg1+3dqfHv8vp9GGSDilxmPDICBBjt+GxeaBApLz9?= =?us-ascii?Q?12klTiypXJERHxSDBT5PFTqAueL5ze4+WV4wJPa4y9jvaV7bYWk1xudno35m?= =?us-ascii?Q?ZTljcdEtJkA4ENOY97LtifyQJjYMB8GPrPf6towN/c2XEdkHT9ni7+WPACo5?= =?us-ascii?Q?RKKdsmmuxNv1Q1cTV28tdJCzxj/Fh8lGZgJX9fsx0ZHm/fMwmY/tsVLydHg4?= =?us-ascii?Q?1yMRDWuvmlvNgqezq/qZiNAmBUd1Z7xJ51T55QnZyTJkPDeOJrUV/Q36k3OG?= =?us-ascii?Q?JyprT1pPjO9+il/nQNlH896XfoA8VzDgN29M8RCf+JlHHrQl8nB/uzOk8JXA?= =?us-ascii?Q?L2mYS0fPRVY/xlNgPRMunLa+Zv3fK3BN6O0SuiAv+OjSbcw6GaxYngPZE2nK?= =?us-ascii?Q?pQzSxIoX0u0jwMvUmCyL3bhaDq0RJVL5nZ66zsoFTCiZ+cA+lAz9k4gad/bm?= =?us-ascii?Q?lPzbqhVYe/BD0pTV1mxRKsM+7oAiYJQuj5CScUoDGd3jqCjesLFVr/ZBZyM0?= =?us-ascii?Q?6Yo9K4LAqXOLldzzHjHZhCX3yNrwKVpscuBla/JCqzT2ib1DAfa7nKLhFq7Y?= =?us-ascii?Q?ky3e4pfxcmBvMakTjCTC03A0eYqWOR2F4+7KWT8ILyZtNtGYvUOWa02j3iI3?= =?us-ascii?Q?3fg8rFI+b7sKS9ChpkB7dM8rYSWWTjNzzsk9yp0W3IXyyDRH1rDNWcZ/+1bD?= =?us-ascii?Q?n9N8bMu1uIXKr9FIn53DBdniYm9Xx2Tyu15pnfnJlGn4W/6p9V7DuQcJddCt?= =?us-ascii?Q?eVqIfPhSCgFa+RUsyYvXqvOJBEu1l1muspziJoBuoD9wE0PFNayUFCK/Z3+h?= =?us-ascii?Q?LIEnerEoarBcEuSG35MuOeIMCe/F6cSljhVlol1RP1vKFbiacYAAeLcNjuNJ?= =?us-ascii?Q?9IozEe1GV0uquZSHqrLDQ9Q7cfXSB6yCCqOC2Zi6TYgsY+9Fnybh8fFNbnoj?= =?us-ascii?Q?Xsj8yvZhIQc29Si7nqxM8gkjhSvDqWA2ZWz+OFeiwJtG2UP0BQOqYOQu4BZN?= =?us-ascii?Q?H7igQtU1eRaVggJDLAwG8owreK6s1wYIwWq?= X-Microsoft-Exchange-Diagnostics: 1; CY4PR15MB1317; 6:z2TkarawOuXtkYLpFFo66MrJF/thM/t2rKP90SS7/un1K7rhS4E8olIBwAQVfcA2SUWuDlwxcW2dz/Je+2sqWp1BXpJ44QYcQCzK21ExZ2pSCn7kQSQjwBggnkdD17qhs9LBdyxTjd3IaIWc+O+8lO7m8720ha/tEOmRTCmswgiyDGizYMkPj2+hcwg7kLJmnO2HLj2TK1+MAYWL54f0+YrNK/CFVhxlBctyq6ryyfuz7+OkR0EsFLUfYLm6aM1oLvcbMRRtmW2FX+Pf6etY0mL2IO6wrzap1S4FfjLvdA0=; 5:k3oAcurWbiIXci/dOqd9e4x9xNioc6PDg9hij2w9ox/gbWjFIK/AN9ixiAjnZLmeqC+5UFiC7vGUuAX4SzlOSZkBjv8ErVSTtfZPtiQjI44iAUe0J5LO8jm/4cggOoEbspP834keI73dMY0YHf+Y1Q==; 24:jOCLG4weKQhvASimIEERC5vixsoQMQJReEcF+/OnXniq2YfQE/LjKN4t4y6h8cYt033Ze/AzVI8J0bUKvkFRUXXkVeujKI5wVpNZ6rz2MNQ=; 7:bP2gPo57auj7wFFfQ41P6CAbhTtYsqONEyEbfEt0KhUiRW+jw12attvY86vfdwSMEQXWclzLTx56j4VuspuP4x4iqgthuNEi9cEiTIpj35B17O6G8Znbi5iUNyqfv2BssyC1HjLjQ09xmRyu0QSHAttiDRL6Z6vCdDN4Viy1rIvX9Z2bz4cJlGcaEeUyO8PysegQ6MHfOzdBJ3BRPOARtS1tgPXw6ZXLjpMHxsJHyUauay9C64YdV7v0cCD0vrx3 SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; CY4PR15MB1317; 20:Uw5dcggyInDEr9mbA0FnU0Js4EN5osF4jgH+jFth/oVIwbH9GNQO5BxXZfVVjrzPFADlNBAaYnRMX/zJOSh2/9SaNdsrTYcSOlF3EFyPj8UzZI33Nf9kmB87ZBF6+fNoH3XIFXjUz6DHQnlaS00bJTmUm7M1PR8qtP7sD6muM2E= X-MS-Exchange-CrossTenant-OriginalArrivalTime: 22 Aug 2016 17:35:20.0797 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY4PR15MB1317 X-OriginatorOrg: fb.com X-Proofpoint-Spam-Reason: safe X-FB-Internal: Safe X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:, , definitions=2016-08-22_09:, , signatures=0 Sender: linux-btrfs-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-btrfs@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP Now that we have metadata counters in the VM, we need to provide a way to kick writeback on dirty metadata. Introduce super_operations->write_metadata. This allows file systems to deal with writing back any dirty metadata we need based on the writeback needs of the system. Since there is no inode to key off of we need a list in the bdi for dirty super blocks to be added. From there we can find any dirty sb's on the bdi we are currently doing writeback on and call into their ->write_metadata callback. Signed-off-by: Josef Bacik --- fs/fs-writeback.c | 58 +++++++++++++++++++++++++++++++++++++--- fs/super.c | 7 +++++ include/linux/backing-dev-defs.h | 2 ++ include/linux/fs.h | 4 +++ mm/backing-dev.c | 1 + 5 files changed, 69 insertions(+), 3 deletions(-) diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c index d329f89..b7d8946 100644 --- a/fs/fs-writeback.c +++ b/fs/fs-writeback.c @@ -1615,11 +1615,36 @@ static long writeback_sb_inodes(struct super_block *sb, return wrote; } +static long writeback_sb_metadata(struct super_block *sb, + struct bdi_writeback *wb, + struct wb_writeback_work *work) +{ + struct writeback_control wbc = { + .sync_mode = work->sync_mode, + .tagged_writepages = work->tagged_writepages, + .for_kupdate = work->for_kupdate, + .for_background = work->for_background, + .for_sync = work->for_sync, + .range_cyclic = work->range_cyclic, + .range_start = 0, + .range_end = LLONG_MAX, + }; + long write_chunk; + + write_chunk = writeback_chunk_size(wb, work); + wbc.nr_to_write = write_chunk; + sb->s_op->write_metadata(sb, &wbc); + work->nr_pages -= write_chunk - wbc.nr_to_write; + + return write_chunk - wbc.nr_to_write; +} + static long __writeback_inodes_wb(struct bdi_writeback *wb, struct wb_writeback_work *work) { unsigned long start_time = jiffies; long wrote = 0; + bool done = false; while (!list_empty(&wb->b_io)) { struct inode *inode = wb_inode(wb->b_io.prev); @@ -1639,11 +1664,38 @@ static long __writeback_inodes_wb(struct bdi_writeback *wb, /* refer to the same tests at the end of writeback_sb_inodes */ if (wrote) { - if (time_is_before_jiffies(start_time + HZ / 10UL)) - break; - if (work->nr_pages <= 0) + if (time_is_before_jiffies(start_time + HZ / 10UL) || + work->nr_pages <= 0) { + done = true; break; + } + } + } + + if (!done && wb_stat(wb, WB_METADATA_DIRTY)) { + LIST_HEAD(list); + + spin_unlock(&wb->list_lock); + spin_lock(&wb->bdi->sb_list_lock); + list_splice_init(&wb->bdi->dirty_sb_list, &list); + while (!list_empty(&list)) { + struct super_block *sb; + + sb = list_first_entry(&list, struct super_block, + s_bdi_list); + list_move_tail(&sb->s_bdi_list, + &wb->bdi->dirty_sb_list); + if (!sb->s_op->write_metadata) + continue; + if (!trylock_super(sb)) + continue; + spin_unlock(&wb->bdi->sb_list_lock); + wrote += writeback_sb_metadata(sb, wb, work); + spin_lock(&wb->bdi->sb_list_lock); + up_read(&sb->s_umount); } + spin_unlock(&wb->bdi->sb_list_lock); + spin_lock(&wb->list_lock); } /* Leave any unwritten inodes on b_io */ return wrote; diff --git a/fs/super.c b/fs/super.c index c2ff475..c1b1028 100644 --- a/fs/super.c +++ b/fs/super.c @@ -215,6 +215,7 @@ static struct super_block *alloc_super(struct file_system_type *type, int flags, spin_lock_init(&s->s_inode_list_lock); INIT_LIST_HEAD(&s->s_inodes_wb); spin_lock_init(&s->s_inode_wblist_lock); + INIT_LIST_HEAD(&s->s_bdi_list); if (list_lru_init_memcg(&s->s_dentry_lru)) goto fail; @@ -305,6 +306,8 @@ void deactivate_locked_super(struct super_block *s) { struct file_system_type *fs = s->s_type; if (atomic_dec_and_test(&s->s_active)) { + struct backing_dev_info *bdi = s->s_bdi; + cleancache_invalidate_fs(s); unregister_shrinker(&s->s_shrink); fs->kill_sb(s); @@ -317,6 +320,10 @@ void deactivate_locked_super(struct super_block *s) list_lru_destroy(&s->s_dentry_lru); list_lru_destroy(&s->s_inode_lru); + spin_lock(&bdi->sb_list_lock); + list_del_init(&s->s_bdi_list); + spin_unlock(&bdi->sb_list_lock); + put_filesystem(fs); put_super(s); } else { diff --git a/include/linux/backing-dev-defs.h b/include/linux/backing-dev-defs.h index 1200aae..ee6f27f 100644 --- a/include/linux/backing-dev-defs.h +++ b/include/linux/backing-dev-defs.h @@ -167,6 +167,8 @@ struct backing_dev_info { struct timer_list laptop_mode_wb_timer; + spinlock_t sb_list_lock; + struct list_head dirty_sb_list; #ifdef CONFIG_DEBUG_FS struct dentry *debug_dir; struct dentry *debug_stats; diff --git a/include/linux/fs.h b/include/linux/fs.h index f3f0b4c8..c063ac6 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h @@ -1430,6 +1430,8 @@ struct super_block { spinlock_t s_inode_wblist_lock; struct list_head s_inodes_wb; /* writeback inodes */ + + struct list_head s_bdi_list; }; /* Helper functions so that in most cases filesystems will @@ -1805,6 +1807,8 @@ struct super_operations { struct shrink_control *); long (*free_cached_objects)(struct super_block *, struct shrink_control *); + void (*write_metadata)(struct super_block *sb, + struct writeback_control *wbc); }; /* diff --git a/mm/backing-dev.c b/mm/backing-dev.c index b48d4e4..80ba94a 100644 --- a/mm/backing-dev.c +++ b/mm/backing-dev.c @@ -782,6 +782,7 @@ int bdi_init(struct backing_dev_info *bdi) bdi->max_prop_frac = FPROP_FRAC_BASE; INIT_LIST_HEAD(&bdi->bdi_list); INIT_LIST_HEAD(&bdi->wb_list); + INIT_LIST_HEAD(&bdi->dirty_sb_list); init_waitqueue_head(&bdi->wb_waitq); ret = cgwb_bdi_init(bdi);