From nobody Fri Dec 19 13:52:00 2025 Received: from APC01-TYZ-obe.outbound.protection.outlook.com (mail-tyzapc01on2076.outbound.protection.outlook.com [40.107.117.76]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 96AE021C164 for ; Tue, 3 Sep 2024 08:40:55 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.117.76 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725352857; cv=fail; b=T1Pxt6gOe8Jtu2HxwLkOQbIJnyFiRBtixFBnkVGUMH4VPLlfk4T2zjKJ8F0CVJ6Ofo43I/eHUl52aVV9XryYPCPGjkhTtfmjaZ87FERzzEf3CL6yFxXiyxM20gfENzKnj2UuI185efnQuokmRmvhebiJppA5Y1GuSyi9Ka3lA0k= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725352857; c=relaxed/simple; bh=SvhU1fKm3jh8SZr2LRzTEhzy8e+YC7jTm8MVRHLBAvo=; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References: Content-Type:MIME-Version; b=AIV6Bu2O7PN90/R0rUDrbRifkkkcktK2isT5vL0+EO5N3wSmRH19P3+LsG2mBlF2lsYwUqalmrXXENxt2XYeeij+/SFaXMu6KWKy6D3tJbg9/uuqWjuTUuuogu/jGv6hZrqyWMhw/Qe75eMCtyLppObzrjbg6sGhWy29ISA6Bc4= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=vivo.com; spf=pass smtp.mailfrom=vivo.com; dkim=pass (2048-bit key) header.d=vivo.com header.i=@vivo.com header.b=W1003AVs; arc=fail smtp.client-ip=40.107.117.76 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=vivo.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=vivo.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=vivo.com header.i=@vivo.com header.b="W1003AVs" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=S3WLT1WbSB/ornFLzvioDvc4bwxx6GZdhYRl5EolU3likt/jogFLJswM8k28XSQJR/1BOsBO07OgAgzPtk5o21WKJJ7gwGqHsHvwREahvsF7UHjpKzo3Li/pQB2pjqRIg7RsZwYVaaybbIZno4yhw3lZsXPxGw1mHPIx4lskWi9azBNW6+M1Ks4wKOavs9spL3i0TlC2lNv/xEiyX10doVmpTvLKoWKOfSUwiT5FauEDk9bB/EPt17bd16LXp4XVApTD+I3rWLO1OJ/C5qgMYqzH/fUVEdPyfB/LwJfBi1XG68ewDOcNmb4w78j/KM7ayHHq9obRLLSpZaNQ3xP/Ng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=zV/wxBoWCpRDMX0E9pav3c5V0+kf6YRvt/E5k66a+Hw=; b=bd9liCJh6cjMOsRuh9W+DINAYboeG2eyCUIgBA0DLNqr2l6lNhIU5vLK82R3ickBm0SEDG6TeYlpo7DJp6BDAPb1tx3lhJfRlzYlovTRX0XejQUjZQrkWknnp4P8ofkg1FxDEmh5OQ/JFM/FC6tN3Jolt5rzFmu9HGt0z3o/RCAUY+TMD7pKcjJXXXm+L3WksBvmUR1Ocp/AhxSxR7f9ircABOlC53Y29XNz1Piny6dh6WnhMncGFbuFvskWbKWRpoB9F5cyROIFzEJyTc52/7iyrR+qOVSTE1vVBbbc3FoZwBCHLDedZSDDUZgQHFovHFfnwOippNPzZVG4u60u1A== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=vivo.com; dmarc=pass action=none header.from=vivo.com; dkim=pass header.d=vivo.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=vivo.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=zV/wxBoWCpRDMX0E9pav3c5V0+kf6YRvt/E5k66a+Hw=; b=W1003AVsPhq4g8w7i+uqAmWXft+n5QFZEzMCSucozxtQhVujdBPn6kc1qvInDl8gm710Y3ptx6IzL4nao8xTxiVG6RJApN4ZuAn/M3WqBPfArz/OUI5kmULla/WbibDWfdz93uKL0Y5eoniuLn3vrdwuBvvJxlLE+fNAbzv0Uhikh4OM+bMDYXMNJP2n88BRU0TavIFAjPuHUUd/ZZirsVtQ65WuV3nVyp3g2G2Y9viPOvOADsi2E2/NSpvVuny0+Nr5a7PNkg8IRRrYBJQy4bm6BFQTvodkLkkXw6HflEeCkd+fZNB5na499t++WVfEiDh3sC17zrUVG57teic8Uw== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=vivo.com; Received: from PSAPR06MB4486.apcprd06.prod.outlook.com (2603:1096:301:89::11) by KL1PR0601MB5536.apcprd06.prod.outlook.com (2603:1096:820:bd::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7918.24; Tue, 3 Sep 2024 08:40:50 +0000 Received: from PSAPR06MB4486.apcprd06.prod.outlook.com ([fe80::43cb:1332:afef:81e5]) by PSAPR06MB4486.apcprd06.prod.outlook.com ([fe80::43cb:1332:afef:81e5%6]) with mapi id 15.20.7918.024; Tue, 3 Sep 2024 08:40:50 +0000 From: Wu Bo To: linux-kernel@vger.kernel.org Cc: Jaegeuk Kim , Chao Yu , linux-f2fs-devel@lists.sourceforge.net, Wu Bo , Wu Bo Subject: [PATCH 04/13] f2fs: implement inline tail read & fiemap Date: Tue, 3 Sep 2024 02:54:48 -0600 Message-Id: X-Mailer: git-send-email 2.25.1 In-Reply-To: References: Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: SI2PR02CA0008.apcprd02.prod.outlook.com (2603:1096:4:194::12) To PSAPR06MB4486.apcprd06.prod.outlook.com (2603:1096:301:89::11) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PSAPR06MB4486:EE_|KL1PR0601MB5536:EE_ X-MS-Office365-Filtering-Correlation-Id: 5aa681ee-5f54-4db0-eadf-08dccbf41d63 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|52116014|376014|1800799024|38350700014; X-Microsoft-Antispam-Message-Info: =?us-ascii?Q?jxtvMRSi3/2ZflBTNdlD3Vy6wqYGk04y5dFusvwau2evd1dvrQgNc1uuFoAz?= =?us-ascii?Q?+Wxp1Gu6MJJ5RaJEwVToMTUuN1I8j9WRQ1lRDrRDZ4X/72j8VT2ddQXAPsI9?= =?us-ascii?Q?2SZqZJcLrB1brDiBe9fV7nYQsCLv65t1btN1uhgC/dz2O7VNo998tZDBesxj?= =?us-ascii?Q?2SDQUlyXxfnQbVfmelcwLsIQ7UBzKjQiWkgzFAk+r7B6l2OL4F0btKHDE3Bk?= =?us-ascii?Q?2EvhlGlS1O+yIqiDC9FZ/EbV/DnxL+n3RWRJ7LHirc/LMrDZwpKdQWE/jPa9?= =?us-ascii?Q?ZlOcK3TLJgI6vRpk7Yeu9UBBLEgcT7eLs3YtB4TfCQLBrQI12LIVacly29QD?= =?us-ascii?Q?4YoqNDaqBgx61IvpkO+sRyLLP6KZzxnhUktSxZYLEBpE27FTStUAgJC0FC/c?= =?us-ascii?Q?c+h/+6scciLc3lM5mSS9THY/oGTOwrBaBfsBd3gWfY6xYnl7BqvUg0zmNcU3?= =?us-ascii?Q?eMvmMUgM1x6NB4IkJpdnEKkzVbFtP2Rdn9+SSWLgIjTZKzBk1EfUIboAJH39?= =?us-ascii?Q?W9B6a7XynBpZAAXKNHSQqTk7WdlhzE+R0jZzLqX98rAyl24iVIlpF+fu1KSd?= =?us-ascii?Q?crv5RC4hcPHDRgkkXGjtIJgE0LcJNp60TnbPqn9nmHw/40m3D/MbdioINqRp?= =?us-ascii?Q?QfFOaCdWZTnaxJ0sTLx88gVMI0+Y70Ah3Sa81u9AOP0kaK8J2tiVqZV9eWAF?= =?us-ascii?Q?IKvzMavpCLX02qobf0zDbZtbjNCyCjup1TKGgdNkiY/wD6EKGw179jsDRIyV?= =?us-ascii?Q?OB5lOXhR3plT0gcnWMvBcgYNgmc9ypPVqHRjpt8inF3seK2yEg1SMkE7OBVa?= =?us-ascii?Q?8FSS3PpFy8eZvRl0vgFCs6Eq2nmdZGWvX7gUTqcs/+7RGtxbnTsz77uo6Val?= =?us-ascii?Q?R+261kifL0wNN/e3UuIf9igaHHuDsMXxy4zG10qsqDPgUK5dCvBtSslVN9yc?= =?us-ascii?Q?4/4pJoXJdte0fb9mNUc6HHwLCoKc0tlMlQ9ifDzXhKabd1V0XPFClLBLXxjc?= =?us-ascii?Q?MmQ3+gwJAIuvtBrqqvGT9vstWMlyOf3WhzMwaz+VLK8l4WRV24D2CdQV16s2?= =?us-ascii?Q?3KMcnw5qf/J+N5ea4a+RXVbjRtjyXIz5mP64Vt7NKnN3mHU7DMYbSyan2R4v?= =?us-ascii?Q?k3v88RjM21Ez7i3dONkiFDu9Zvw0cHxGbAZhGk0snJmC5sMuyeMnz6gBhKFr?= =?us-ascii?Q?lFe6Y0UmXKsEvGLE9XYhq4m5wLQhMO8HrJlcUNSOWIuqg2ryGCV1qQo9uGfI?= =?us-ascii?Q?2MxzeRyX/rvfMf596W+whnON2dkss6YiuE35xwf9ZP9M/swHuRa8Wk6RILYw?= =?us-ascii?Q?K4PZt5QIST19eSInQUT8Q7LtE6fWeQbxSO3dsNHxUR0Jc42FfJPVJMFLUrz6?= =?us-ascii?Q?6mdaJdSaC/lQwLjizYNjs/5kqKMxvM/EKGowkpDpJTMqhaDJmg=3D=3D?= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PSAPR06MB4486.apcprd06.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(366016)(52116014)(376014)(1800799024)(38350700014);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?kuolJJfL+zlLFetG9L5amaCKVk3LgMm6C+KIFYeh2bgyaOLMx480YNVeAXxc?= =?us-ascii?Q?Db5pNEk8h+cGM4T4VnJySmkhTBQIFEehQmsXeJ2DGF4CiLpO1VDAn912bFbf?= =?us-ascii?Q?m9MWljJArytIFPSjc9ups6igUry4luRQc18aD88fmOtyVY1nEuv33dBrXiKr?= =?us-ascii?Q?UH8C4Dg4ZeXJuIN2RUxf2Wwphd6D0rXKlhSuPR3r7XPorhTBEhRipKZvQ0Hs?= =?us-ascii?Q?zoQlUTK+bkfsA1P0sqa2hFCt1g0mg5ZJ7dM+4zjPVIPh5sOe8cnnY/XDc7jN?= =?us-ascii?Q?TBhOOO1J/DddsgN3mxMqoDn0cZzLsvnuXRMpI0gXB3NYU47561zr9FmoeT+D?= =?us-ascii?Q?h6o+dXvieJ5/b9Nn3N79nK1ajFKWR53mP17lLMNagNB4MzD+heHnk4PSC30/?= =?us-ascii?Q?P/mnUwgqIV4H5NT39tbHTFLW7Imazgs4WhRdO4r7mz85ziAeHJN2BmOy6LMs?= =?us-ascii?Q?rUFEVwTZI72ioyYA2RsQz2hVvaP7b1rs10gxiF2nn57rkRKd/TfykemEE6CN?= =?us-ascii?Q?airIsVsEyvSJQc7n6+oLWVky+LAaVAc3p6tZ2k0kJRSJcpMcQ90mDeT4h0nl?= =?us-ascii?Q?FsBXmASsKvrDFbchCMfmuSlAJjZEMSkZ6D3r5PY5n1LWpitkn/msXu+ShDIc?= =?us-ascii?Q?UQ5SDjQjqvYNFQaxB4KC6v5iUw4oF2a5XD0zW3yxtScrvJrVnyDJzmD/1+ZD?= =?us-ascii?Q?jwMz2i9jJEvS4i7OqFd6PsFf4+vTHBmvipYiu5rZR5334UTnbuqD208h4dpF?= =?us-ascii?Q?eetRTDLuCyfoG048VJKqsEffaEYdqHEL56mGZ4uX3SQSG3gJqGqNDHgyy1Qi?= =?us-ascii?Q?Bf7Cm1wPs0cGpakLxpT6PNyPv2Ni+Uq9jqzLiWG40E+KMIZU7mZWlaqwaERw?= =?us-ascii?Q?jyIVXyNv7/OpJk2aMR4kOSCk33w5CUnawCJEnFJ272yFjmTPC/6l0gsVfA9w?= =?us-ascii?Q?gz9pgzFlGYmEPPoI+GOD3BO92123SNxW6d1uHYbyieY37LvwMh0x72rW8PWG?= =?us-ascii?Q?ea0Yc06Y4eAyGaHh3IbMN3lU5lG5tg7faB7PG7DS13BH/Qz9EhWFOIPhMEjC?= =?us-ascii?Q?+8SK6i8mpwYYZs+B53Uiqr3uPvQ5oMHEMnYdYBdDLkv7eoQytqNZRwue8Sj8?= =?us-ascii?Q?sOBVtvcC1hDy1ydNxGdjR0lVUFS+RJ16D5Rw4MEfWbFvku0TZStVb362bP5n?= =?us-ascii?Q?FDVWC5nB+y2e5gsX2hB+voewP4dE90P9ClGWl5Ynx0HAwr3JbcDdNvEGzuDb?= =?us-ascii?Q?EDiP9wPg7Ejfwo/tOd1QKImYMbXO6jhws4ZBBHIX+0wCetIsr7+UC9SSiqaJ?= =?us-ascii?Q?a8bQ/jvfiI8rkRE2+HBS/KYWiXc61WcKeBTvm4D9TeUlrGfBLeuMmPgNIygf?= =?us-ascii?Q?14Df41lmjQ0iS9RIoCdusrQNZuIO25ZY3rzUcgcqhc1evF7QYg0GrPs1z9rJ?= =?us-ascii?Q?vmvVMsRz5tmtc36X7pthy75ypqc6rN3Voef2GH9jWH2XljdG/Vap3hKBfxCl?= =?us-ascii?Q?PgHY2ZJ4evS2RQTltczMaMWo0x/ZSv8Hsf8Mhn15Z0E9H/A2goq9lqR4slL3?= =?us-ascii?Q?UGGiQnrSaFz9jVsPQi4mfEe00Yuij96cw/gLFPdH?= X-OriginatorOrg: vivo.com X-MS-Exchange-CrossTenant-Network-Message-Id: 5aa681ee-5f54-4db0-eadf-08dccbf41d63 X-MS-Exchange-CrossTenant-AuthSource: PSAPR06MB4486.apcprd06.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Sep 2024 08:40:50.6561 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 923e42dc-48d5-4cbe-b582-1a797a6412ed X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: +z9U/wHB3saOYY+znAw42x3ITst/+riE/lFsifYUxyuNpAnGRcPffuuVfo+bxF+XVAJl9T3VqGMFDvCkPTsLZw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: KL1PR0601MB5536 Content-Type: text/plain; charset="utf-8" Expand the inline data read & fiemap to support inline tail. Signed-off-by: Wu Bo --- fs/f2fs/data.c | 31 ++++++++++++++++++++++++++++++- fs/f2fs/inline.c | 26 ++++++++++++-------------- 2 files changed, 42 insertions(+), 15 deletions(-) diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c index cd13b5703228..476325a26d4e 100644 --- a/fs/f2fs/data.c +++ b/fs/f2fs/data.c @@ -1922,9 +1922,11 @@ int f2fs_fiemap(struct inode *inode, struct fiemap_e= xtent_info *fieinfo, u64 logical =3D 0, phys =3D 0, size =3D 0; u32 flags =3D 0; int ret =3D 0; - bool compr_cluster =3D false, compr_appended; + bool compr_cluster =3D false, compr_appended, inline_tail =3D false; unsigned int cluster_size =3D F2FS_I(inode)->i_cluster_size; unsigned int count_in_cluster =3D 0; + loff_t i_size =3D i_size_read(inode); + pgoff_t end_index =3D i_size >> PAGE_SHIFT; loff_t maxbytes; =20 if (fieinfo->fi_flags & FIEMAP_FLAG_CACHE) { @@ -1983,6 +1985,16 @@ int f2fs_fiemap(struct inode *inode, struct fiemap_e= xtent_info *fieinfo, =20 /* HOLE */ if (!compr_cluster && !(map.m_flags & F2FS_MAP_FLAGS)) { + /* + * There is a reserved space between address array and inline + * data. So it must meet this hole state before inline data. + */ + if (f2fs_has_inline_tail(inode) && start_blk =3D=3D end_index + && f2fs_exist_data(inode)) { + inline_tail =3D true; + goto fill_extent; + } + start_blk =3D next_pgofs; =20 if (blks_to_bytes(inode, start_blk) < blks_to_bytes(inode, @@ -2000,6 +2012,7 @@ int f2fs_fiemap(struct inode *inode, struct fiemap_ex= tent_info *fieinfo, goto skip_fill; } =20 +fill_extent: if (size) { flags |=3D FIEMAP_EXTENT_MERGED; if (IS_ENCRYPTED(inode)) @@ -2013,6 +2026,13 @@ int f2fs_fiemap(struct inode *inode, struct fiemap_e= xtent_info *fieinfo, size =3D 0; } =20 + if (inline_tail) { + start =3D blks_to_bytes(inode, start_blk); + ret =3D f2fs_inline_data_fiemap(inode, fieinfo, start, len); + if (ret !=3D -EAGAIN) + goto out; + } + if (start_blk > last_blk) goto out; =20 @@ -2377,6 +2397,8 @@ static int f2fs_mpage_readpages(struct inode *inode, #endif unsigned nr_pages =3D rac ? readahead_count(rac) : 1; unsigned max_nr_pages =3D nr_pages; + loff_t i_size =3D i_size_read(inode); + pgoff_t end_index =3D i_size >> PAGE_SHIFT; pgoff_t index; int ret =3D 0; =20 @@ -2397,6 +2419,12 @@ static int f2fs_mpage_readpages(struct inode *inode, =20 index =3D folio_index(folio); =20 + if (f2fs_has_inline_tail(inode) && index =3D=3D end_index && + f2fs_exist_data(inode)) { + ret =3D f2fs_read_inline_data(inode, folio); + goto out; + } + #ifdef CONFIG_F2FS_FS_COMPRESSION if (!f2fs_compressed_file(inode)) goto read_single_page; @@ -2462,6 +2490,7 @@ static int f2fs_mpage_readpages(struct inode *inode, } #endif } +out: if (bio) f2fs_submit_read_bio(F2FS_I_SB(inode), bio, DATA); return ret; diff --git a/fs/f2fs/inline.c b/fs/f2fs/inline.c index 2e63e9389fd7..30b18053e784 100644 --- a/fs/f2fs/inline.c +++ b/fs/f2fs/inline.c @@ -86,8 +86,6 @@ void f2fs_do_read_inline_data(struct folio *folio, struct= page *ipage) if (folio_test_uptodate(folio)) return; =20 - f2fs_bug_on(F2FS_I_SB(inode), folio_index(folio)); - folio_zero_segment(folio, MAX_INLINE_DATA(inode), folio_size(folio)); =20 /* Copy the whole inline data block */ @@ -126,15 +124,12 @@ int f2fs_read_inline_data(struct inode *inode, struct= folio *folio) return PTR_ERR(ipage); } =20 - if (!f2fs_has_inline_data(inode)) { + if (!f2fs_has_inline_data(inode) && !f2fs_has_inline_tail(inode)) { f2fs_put_page(ipage, 1); return -EAGAIN; } =20 - if (folio_index(folio)) - folio_zero_segment(folio, 0, folio_size(folio)); - else - f2fs_do_read_inline_data(folio, ipage); + f2fs_do_read_inline_data(folio, ipage); =20 if (!folio_test_uptodate(folio)) folio_mark_uptodate(folio); @@ -814,7 +809,7 @@ int f2fs_read_inline_dir(struct file *file, struct dir_= context *ctx, int f2fs_inline_data_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, __u64 start, __u64 len) { - __u64 byteaddr, ilen; + __u64 byteaddr, ilen, offset; __u32 flags =3D FIEMAP_EXTENT_DATA_INLINE | FIEMAP_EXTENT_NOT_ALIGNED | FIEMAP_EXTENT_LAST; struct node_info ni; @@ -826,7 +821,8 @@ int f2fs_inline_data_fiemap(struct inode *inode, return PTR_ERR(ipage); =20 if ((S_ISREG(inode->i_mode) || S_ISLNK(inode->i_mode)) && - !f2fs_has_inline_data(inode)) { + !f2fs_has_inline_data(inode) && + !f2fs_has_inline_tail(inode)) { err =3D -EAGAIN; goto out; } @@ -836,12 +832,14 @@ int f2fs_inline_data_fiemap(struct inode *inode, goto out; } =20 - ilen =3D min_t(size_t, MAX_INLINE_DATA(inode), i_size_read(inode)); - if (start >=3D ilen) + ilen =3D min_t(size_t, MAX_INLINE_DATA(inode), + i_size_read(inode) & (PAGE_SIZE - 1)); + offset =3D start & (PAGE_SIZE - 1); + if (offset >=3D ilen) goto out; - if (start + len < ilen) - ilen =3D start + len; - ilen -=3D start; + if (offset + len < ilen) + ilen =3D offset + len; + ilen -=3D offset; =20 err =3D f2fs_get_node_info(F2FS_I_SB(inode), inode->i_ino, &ni, false); if (err) --=20 2.35.3