Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp1717923rwl; Thu, 30 Mar 2023 00:04:13 -0700 (PDT) X-Google-Smtp-Source: AKy350aBFYhQBVrgE6voeJ0ck3U95qGbt3FzZCTLxpWlQ51iBye/wyGt5EDOZWkD1zBrsxtImPJn X-Received: by 2002:a17:903:3015:b0:1a1:9ff6:ca9 with SMTP id o21-20020a170903301500b001a19ff60ca9mr16056343pla.28.1680159852832; Thu, 30 Mar 2023 00:04:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680159852; cv=none; d=google.com; s=arc-20160816; b=USa3qz1JGhbFueRsEAi/TH0nMuuWFauung5UBLEgSl5dRs0MBN9AfGL7KkbMDK207w FpM3ehdXQlBsjpJoEU2Us75RjmgthP7BRfuUiFz9c2GXvJRSX83AlplKr9xYoHSKFB1r lROm++OgPy6oDX+d+7fEq/3+wRSX3EszwYmZ4t0TlzgAVUBwemDUkd0EkKUEtc0pZ3Jo aKQDh2RMxIEbmg64E94wjMRJHfcJRnoUdR59+ZJzsPcV4VD8wYatTM/oELEXaBNvs9pL c1aQTopbsdluInBEqeLz9E976vQLMu05YKU+Pym3YzMNnTn0uZL8n5kThE2/oRr376l7 rF1A== 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=ZsS9r86UtQ6bSuFEzT2czRAY9imE+x7fFmEAcze+3h7q3cR14IRt3B9D1Xbl6R0+wD ddkM9HPZ8jdvFtMergXLXa88C5Jjv7fCoyV81d4ZCsxAw3ByRE3cTGCqDH3OcPtL2GK0 nok7qbuZmV6mAYkKsD4eUU3OZUrsCCTzxAL1Re2aFnyTiL9NHC1kh4H2cq++nWc9du6v jZr0VOTW5q3p+/vepXCZQcLIGJKNMd9sjNDf6L+3ubLy3ei8jsJnWeXFw70D4yo9zKOi 3/R1nRfbdcUht/ZH12+yUdkF+KA/nM+d6USIYJF4NWNNYeMs/UOKjR+QoyKFUY6nqoFh g2nA== 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 jy8-20020a17090342c800b0019a95ab6b66si31873677plb.33.2023.03.30.00.03.54; Thu, 30 Mar 2023 00:04:12 -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 S229800AbjC3G5n (ORCPT + 99 others); Thu, 30 Mar 2023 02:57:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49036 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229864AbjC3G5m (ORCPT ); Thu, 30 Mar 2023 02:57:42 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7C4825240 for ; Wed, 29 Mar 2023 23:57:37 -0700 (PDT) Received: from dggpeml500016.china.huawei.com (unknown [172.30.72.53]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4PnDgz2vwBzKx7y; Thu, 30 Mar 2023 14:55:11 +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; Thu, 30 Mar 2023 14:57:34 +0800 From: zhanchengbin To: , CC: , , , , zhanchengbin Subject: [PATCH v2 1/2] lib/ext2fs: add error handle in unix_flush and unix_write_byte Date: Thu, 30 Mar 2023 14:56:55 +0800 Message-ID: <20230330065656.3275785-2-zhanchengbin1@huawei.com> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20230330065656.3275785-1-zhanchengbin1@huawei.com> References: <20230330065656.3275785-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: dggems706-chm.china.huawei.com (10.3.19.183) 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