Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp186286rwl; Sat, 25 Mar 2023 00:03:01 -0700 (PDT) X-Google-Smtp-Source: AKy350aV2H7iE293ltvUZDbTd7pi76dyvuIHje/mU3Eki8Sloz60hXGuQEFJjTVbuHs/hgTxDvum X-Received: by 2002:a17:902:e54d:b0:1a1:a90f:6766 with SMTP id n13-20020a170902e54d00b001a1a90f6766mr5992576plf.52.1679727781362; Sat, 25 Mar 2023 00:03:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1679727781; cv=none; d=google.com; s=arc-20160816; b=LnzIDCAvhaVypNFbAUU3TGz+RmACOcwWDqTlwF6YDqNtJFtWRTYdc8zRs/Us93e1Hj 9ww4V3C0eGcWzkIXbHu7Pi/07pK+knNyMorcgHeiNy0kZqAH5pIj7cjBuSIUz+4MhlbN N32vt4gMcssuuYrnLjfzk/KwX1PEJc6O3CIjwKyZGIEbEfCLqXsMV5XeaZ53C+vKLdWE cBjRRjCQ30kn4YO97Oi1aXN/0su5xvkwBT5aj6UglUNBE8gDtE3jvDq03z3Ms9XqB2aK 4G2O9IjktLDyU59tBrKYvgpE7IuOB6RIyk0nhyXWKogSLHIHnrCn+RzdkZ2l8HPUD2PG DBEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=QK8FF9dP/gizD1812fXEfMNqjGft09BlX3CJnJBxmTk=; b=Fo6x6iAGL8JyMOif1pDDDkpPftnlzbbj1OrT4rRMPmO3GrQi4i0550oguiRTrQvJ08 M6+jYHAanxz0qgpVdLtIOZ9C4Uw8MuB5CgrEFHM77NpQTTSahGHqPaTyniNWrF0dJj3j J379BNEvJEmhTlPOopLjVlHcGfkLQO/nFgRaLCV4DivcxlRX8mUFlouEIT68KeRGOUuS y2QU48H0Aj6vvhZ80ecP1zjWI15BHmAvY9v5EPw9UYEqe2ae08SYbWSKkSPtqU/0lHkt LWh/Qlx1zFzHyFkcW2iu2o9A+46IdwEXJFDWDJYiiW8veEpw8ywV8g184FlrIRmCgFjJ pdWA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b5-20020a170902d50500b001a216fddcffsi3596079plg.645.2023.03.25.00.02.43; Sat, 25 Mar 2023 00:03:01 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231867AbjCYG6G (ORCPT + 99 others); Sat, 25 Mar 2023 02:58:06 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47160 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231443AbjCYG6E (ORCPT ); Sat, 25 Mar 2023 02:58:04 -0400 Received: from szxga03-in.huawei.com (szxga03-in.huawei.com [45.249.212.189]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DB79E166FD for ; Fri, 24 Mar 2023 23:57:54 -0700 (PDT) Received: from dggpeml500016.china.huawei.com (unknown [172.30.72.53]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4Pk8yw2vn3zKncm; Sat, 25 Mar 2023 14:57:28 +0800 (CST) Received: from huawei.com (10.175.127.227) by dggpeml500016.china.huawei.com (7.185.36.70) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.21; Sat, 25 Mar 2023 14:57:53 +0800 From: zhanchengbin To: CC: , , , , zhanchengbin Subject: [PATCH 1/2] lib/ext2fs: add error handle in unix_flush and unix_write_byte Date: Sat, 25 Mar 2023 14:56:51 +0800 Message-ID: <20230325065652.2111384-2-zhanchengbin1@huawei.com> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20230325065652.2111384-1-zhanchengbin1@huawei.com> References: <20230325065652.2111384-1-zhanchengbin1@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.127.227] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To dggpeml500016.china.huawei.com (7.185.36.70) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-2.3 required=5.0 tests=RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-ext4@vger.kernel.org As you can see, a new error handling has been added for fsync, and the error handling for unix_write_byte function has reused the error handling of write_blk. Signed-off-by: zhanchengbin --- lib/ext2fs/ext2_io.h | 2 ++ lib/ext2fs/unix_io.c | 37 ++++++++++++++++++++++++++----------- 2 files changed, 28 insertions(+), 11 deletions(-) diff --git a/lib/ext2fs/ext2_io.h b/lib/ext2fs/ext2_io.h index 679184e3..becd7078 100644 --- a/lib/ext2fs/ext2_io.h +++ b/lib/ext2fs/ext2_io.h @@ -56,6 +56,8 @@ struct struct_io_channel { size_t size, int actual_bytes_written, errcode_t error); + errcode_t (*sync_error)(io_channel channel, + errcode_t error); int refcount; int flags; long reserved[14]; diff --git a/lib/ext2fs/unix_io.c b/lib/ext2fs/unix_io.c index 3171c736..283b4eb6 100644 --- a/lib/ext2fs/unix_io.c +++ b/lib/ext2fs/unix_io.c @@ -1250,7 +1250,8 @@ static errcode_t unix_write_byte(io_channel channel, unsigned long offset, #ifdef ALIGN_DEBUG printf("unix_write_byte: O_DIRECT fallback\n"); #endif - return EXT2_ET_UNIMPLEMENTED; + retval = EXT2_ET_UNIMPLEMENTED; + goto error_out; } #ifndef NO_IO_CACHE @@ -1258,19 +1259,30 @@ static errcode_t unix_write_byte(io_channel channel, unsigned long offset, * Flush out the cache completely */ if ((retval = flush_cached_blocks(channel, data, FLUSH_INVALIDATE))) - return retval; + goto error_out; #endif - if (lseek(data->dev, offset + data->offset, SEEK_SET) < 0) - return errno; + if (lseek(data->dev, offset + data->offset, SEEK_SET) < 0) { + retval = errno; + goto error_out; + } actual = write(data->dev, buf, size); - if (actual < 0) - return errno; - if (actual != size) - return EXT2_ET_SHORT_WRITE; - + if (actual < 0) { + retval = errno; + goto error_out; + } + if (actual != size) { + retval = EXT2_ET_SHORT_WRITE; + goto error_out; + } return 0; +error_out: + if (channel->write_error) + retval = (channel->write_error)(channel, + offset / channel->block_size, 0, buf, + size, actual, retval); + return retval; } /* @@ -1289,8 +1301,11 @@ static errcode_t unix_flush(io_channel channel) retval = flush_cached_blocks(channel, data, 0); #endif #ifdef HAVE_FSYNC - if (!retval && fsync(data->dev) != 0) - return errno; + if (!retval && fsync(data->dev) != 0) { + if (channel->sync_error) + retval = (channel->sync_error)(channel, errno); + return retval; + } #endif return retval; } -- 2.31.1