Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp4105049pxt; Tue, 10 Aug 2021 20:30:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwH0HM0DPOHflmVz3jVwyB1zmnYSbSLFhEp3oXMdQec33cjFkQi29ZtBgCIjDfD9YImaZK2 X-Received: by 2002:a02:a196:: with SMTP id n22mr2801459jah.24.1628652653766; Tue, 10 Aug 2021 20:30:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628652653; cv=none; d=google.com; s=arc-20160816; b=UMPYBkcW9opHGNnqTZClVOsmsHw6sgW+2kXCNXmUp2+tgv4ZDiEG8ofuv2tnCIKBaj Z4Bxbf3iZAWBUayjtjRIbxNDmhFiPMd9IV0qNXQsPaJZd8UAeNoksAzwQzUduIViCZB+ dgxH4AYm3Z2O6sdXVQ43u1fjF/vzmXwMwmTJ6ob+bPnCsdcGSqSwORcqLUR4Mc5yPqKN SWP/PgY+zSRvWLjbvFeUDrrlmEa6KoBT3yxQusL7SwMOqDvb+uJxkJIfSOSL7KdBmgaL 24OiyOpN34IGil5scGOvK6a4lWSvPv36W+K2RhQV5CalzOfXCOp48TXyLwrRHDmnpt4N eJFg== 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 :mime-version:user-agent:date:message-id:from:references:to:subject; bh=h6eT7zjAyvfxGWJLaWVfFewxb2qLTbMrNEf3kj8Ej3c=; b=NRaflP5n7+GgmEHBCs5vVnQetA19HZdfCI1FaKSVVRO7RUKZQSghnOFSFFw11VhyAg ta2nxBg3bIXs/9aGu3RGWQ8IcPggDPIltxVoMzI2z2E+vje5OAOJ1d41YUeMi4bVg/2r AQrExsONkqzP4W/NODF3d9wU5SXbUxmz89QZ8q81HVSW8hisMdXHWaio5bXpR1Aq7HQG VBgR7km60Taxl+lYhuo8kmpcDFTwGXyHirDWWXs2kIm7CVpcqJFg2RYMeAYUvgIuHwU0 MynBm88vqjGncvlVKvQUG8JFh3gl/f6r/zmQdCjW7crtNMjLSu3Q/utgEN0vlOksd56T ePMg== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=vivo.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u15si26560611iot.89.2021.08.10.20.30.42; Tue, 10 Aug 2021 20:30:53 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=vivo.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232741AbhHKD3Y (ORCPT + 99 others); Tue, 10 Aug 2021 23:29:24 -0400 Received: from mail-m17656.qiye.163.com ([59.111.176.56]:46338 "EHLO mail-m17656.qiye.163.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232625AbhHKD3X (ORCPT ); Tue, 10 Aug 2021 23:29:23 -0400 Received: from [172.25.45.51] (unknown [58.251.74.232]) by mail-m17656.qiye.163.com (Hmail) with ESMTPA id C2186C40260; Wed, 11 Aug 2021 11:28:57 +0800 (CST) Subject: Re: [f2fs-dev] f2fs do DIO write make file corruption To: Chao Yu , linux-kernel@vger.kernel.org, linux-f2fs-devel@lists.sourceforge.net References: <5b68208b-fd94-bf4e-fc4b-d79d13abf1c6@vivo.com> <6519b8b7-1eb0-f286-7593-5c5ebbfb5554@kernel.org> From: Wu Bo Message-ID: <86e53ee7-13b5-5e8e-7c81-acb1736ebc8b@vivo.com> Date: Wed, 11 Aug 2021 11:28:57 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.12.0 MIME-Version: 1.0 In-Reply-To: <6519b8b7-1eb0-f286-7593-5c5ebbfb5554@kernel.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit X-HM-Spam-Status: e1kfGhgUHx5ZQUtXWQgPGg8OCBgUHx5ZQUlOS1dZCBgUCR5ZQVlLVUtZV1 kWDxoPAgseWUFZKDYvK1lXWShZQUhPN1dZLVlBSVdZDwkaFQgSH1lBWRpKGk1WT05DGkkdTx5LHU MYVRMBExYaEhckFA4PWVdZFhoPEhUdFFlBWU9LSFVKSktITUpVS1kG X-HM-Sender-Digest: e1kMHhlZQR0aFwgeV1kSHx4VD1lBWUc6NBQ6Sww5FT9NTCMQEhYxQwgc NB0KCUtVSlVKTUlDTU5JTkhDSUJIVTMWGhIXVRkUVQwOOw0SDRRVGBQWRVlXWRILWUFZTkNVSU5K VUxPVUlISVlXWQgBWUFITEtCNwY+ X-HM-Tid: 0a7b33418820da02kuwsc2186c40260 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 在 2021/8/11 11:03, Chao Yu 写道: > On 2021/8/11 10:48, Wu Bo wrote: >> I use the following command to create a file, the file may got >> corruption: >>     f2fs_io write 2 0 512 inc_num dio $path >> >> And when I use bio or to set the chunk size to 1 block, the file is >> normal. The commands as following: >>     f2fs_io write 2 0 512 inc_num buffered $path >>     f2fs_io write 1 0 512 inc_num dio $path >> >> I find this bug on old kernel version 4.14.117, and not find on version >> 4.19.152. So this bug is fixed. Can anyone can tell me which patch fixed >> this bug? > > Not sure, > > https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=linux-4.19.y&id=7bae8b6b73e46c307fa355ce086800b7ad6610f8 > This patch is applied. The issue occurs when f2fs dio try to preallocate multiple blocks and got scattered disk blocks. The log as following: my_f2fs_io-13425 [002] .... 395.583637: el0_irq_naked: 1:type:1,ino:40132,off:768,old_blk:0,new_blk:185764 my_f2fs_io-13425 [002] .... 395.583710: el0_irq_naked: 1:type:1,ino:40132,off:769,old_blk:0,new_blk:205824 my_f2fs_io-13425 [002] .... 395.583721: f2fs_map_blocks: dev = (259,23), ino = 40132, file offset = 768, start blkaddr = 0x2d5a4, len = 0x2, err = 0 my_f2fs_io-13425 [002] .... 395.583735: f2fs_map_blocks: dev = (259,23), ino = 40132, file offset = 768, start blkaddr = 0x2d5a4, len = 0x1, err = 0 my_f2fs_io-13425 [002] .... 395.583741: f2fs_map_blocks: dev = (259,23), ino = 40132, file offset = 769, start blkaddr = 0x32400, len = 0x1, err = 0 And if the blocks are continuously, the file data is normal: my_f2fs_io-13425 [002] .... 395.584037: el0_irq_naked: 1:type:1,ino:40132,off:770,old_blk:0,new_blk:205825 my_f2fs_io-13425 [002] .... 395.584066: el0_irq_naked: 1:type:1,ino:40132,off:771,old_blk:0,new_blk:205826 my_f2fs_io-13425 [002] .... 395.584077: f2fs_map_blocks: dev = (259,23), ino = 40132, file offset = 770, start blkaddr = 0x32401, len = 0x2, err = 0 my_f2fs_io-13425 [002] .... 395.584091: f2fs_map_blocks: dev = (259,23), ino = 40132, file offset = 770, start blkaddr = 0x32401, len = 0x2, err = 0 > > Thanks, > >> >> >> _______________________________________________ >> Linux-f2fs-devel mailing list >> Linux-f2fs-devel@lists.sourceforge.net >> https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel >> >