update zfs submodule to 2.2.3 and refresh patches
mostly support for newer kernel-versions, and fixes for the BRT bugs discovered with 2.2.0 (BRT remains disabled by default). The update contains a fix for CVE-2020-24370 in lua (which is present in ZFS for channel-programs, which we do not use) - see: https://github.com/openzfs/zfs/pull/15847 for more details. One patch from Stefan Lendl was backported and is now in the ZFS 2.2 branch. Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
This commit is contained in:
		
							parent
							
								
									838cd1d173
								
							
						
					
					
						commit
						a5e0251015
					
				
							
								
								
									
										2
									
								
								debian/patches/0005-Enable-zed-emails.patch
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								debian/patches/0005-Enable-zed-emails.patch
									
									
									
									
										vendored
									
									
								
							| @ -13,7 +13,7 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | |||||||
|  1 file changed, 1 insertion(+), 1 deletion(-) |  1 file changed, 1 insertion(+), 1 deletion(-) | ||||||
| 
 | 
 | ||||||
| diff --git a/cmd/zed/zed.d/zed.rc b/cmd/zed/zed.d/zed.rc
 | diff --git a/cmd/zed/zed.d/zed.rc b/cmd/zed/zed.d/zed.rc
 | ||||||
| index 78dc1afc7..41d5539ea 100644
 | index bc269b155..e6d4b1703 100644
 | ||||||
| --- a/cmd/zed/zed.d/zed.rc
 | --- a/cmd/zed/zed.d/zed.rc
 | ||||||
| +++ b/cmd/zed/zed.d/zed.rc
 | +++ b/cmd/zed/zed.d/zed.rc
 | ||||||
| @@ -41,7 +41,7 @@ ZED_EMAIL_ADDR="root"
 | @@ -41,7 +41,7 @@ ZED_EMAIL_ADDR="root"
 | ||||||
|  | |||||||
| @ -51,10 +51,10 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | |||||||
|  1 file changed, 2 insertions(+), 1 deletion(-) |  1 file changed, 2 insertions(+), 1 deletion(-) | ||||||
| 
 | 
 | ||||||
| diff --git a/cmd/zpool/zpool_main.c b/cmd/zpool/zpool_main.c
 | diff --git a/cmd/zpool/zpool_main.c b/cmd/zpool/zpool_main.c
 | ||||||
| index 5507f9d3f..98970abfe 100644
 | index 69bf9649a..fd42ce7c1 100644
 | ||||||
| --- a/cmd/zpool/zpool_main.c
 | --- a/cmd/zpool/zpool_main.c
 | ||||||
| +++ b/cmd/zpool/zpool_main.c
 | +++ b/cmd/zpool/zpool_main.c
 | ||||||
| @@ -2478,7 +2478,8 @@ print_status_config(zpool_handle_t *zhp, status_cbdata_t *cb, const char *name,
 | @@ -2616,7 +2616,8 @@ print_status_config(zpool_handle_t *zhp, status_cbdata_t *cb, const char *name,
 | ||||||
|   |   | ||||||
|  	if (vs->vs_scan_removing != 0) { |  	if (vs->vs_scan_removing != 0) { | ||||||
|  		(void) printf(gettext("  (removing)")); |  		(void) printf(gettext("  (removing)")); | ||||||
|  | |||||||
| @ -1,131 +0,0 @@ | |||||||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Stefan Lendl <1321542+stfl@users.noreply.github.com> |  | ||||||
| Date: Fri, 12 Jan 2024 21:05:11 +0100 |  | ||||||
| Subject: [PATCH] fix(mount): do not truncate shares not zfs mount |  | ||||||
| 
 |  | ||||||
| When running zfs share -a resetting the exports.d/zfs.exports makes |  | ||||||
| sense the get a clean state. |  | ||||||
| Truncating was also called with zfs mount which would not populate the |  | ||||||
| file again. |  | ||||||
| Add test to verify shares persist after mount -a. |  | ||||||
| 
 |  | ||||||
| Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> |  | ||||||
| Signed-off-by: Stefan Lendl <s.lendl@proxmox.com> |  | ||||||
| Closes #15607 |  | ||||||
| Closes #15660 |  | ||||||
| ---
 |  | ||||||
|  cmd/zfs/zfs_main.c                            |  3 +- |  | ||||||
|  tests/runfiles/common.run                     |  3 +- |  | ||||||
|  tests/zfs-tests/tests/Makefile.am             |  1 + |  | ||||||
|  .../zfs_share/zfs_share_after_mount.ksh       | 62 +++++++++++++++++++ |  | ||||||
|  4 files changed, 67 insertions(+), 2 deletions(-) |  | ||||||
|  create mode 100755 tests/zfs-tests/tests/functional/cli_root/zfs_share/zfs_share_after_mount.ksh |  | ||||||
| 
 |  | ||||||
| diff --git a/cmd/zfs/zfs_main.c b/cmd/zfs/zfs_main.c
 |  | ||||||
| index 9939f206a..f67f6114d 100644
 |  | ||||||
| --- a/cmd/zfs/zfs_main.c
 |  | ||||||
| +++ b/cmd/zfs/zfs_main.c
 |  | ||||||
| @@ -7234,7 +7234,8 @@ share_mount(int op, int argc, char **argv)
 |  | ||||||
|  		pthread_mutex_init(&share_mount_state.sm_lock, NULL); |  | ||||||
|   |  | ||||||
|  		/* For a 'zfs share -a' operation start with a clean slate. */ |  | ||||||
| -		zfs_truncate_shares(NULL);
 |  | ||||||
| +		if (op == OP_SHARE)
 |  | ||||||
| +			zfs_truncate_shares(NULL);
 |  | ||||||
|   |  | ||||||
|  		/* |  | ||||||
|  		 * libshare isn't mt-safe, so only do the operation in parallel |  | ||||||
| diff --git a/tests/runfiles/common.run b/tests/runfiles/common.run
 |  | ||||||
| index f6e5367f5..a600140ea 100644
 |  | ||||||
| --- a/tests/runfiles/common.run
 |  | ||||||
| +++ b/tests/runfiles/common.run
 |  | ||||||
| @@ -316,7 +316,8 @@ tags = ['functional', 'cli_root', 'zfs_set']
 |  | ||||||
|  [tests/functional/cli_root/zfs_share] |  | ||||||
|  tests = ['zfs_share_001_pos', 'zfs_share_002_pos', 'zfs_share_003_pos', |  | ||||||
|      'zfs_share_004_pos', 'zfs_share_006_pos', 'zfs_share_008_neg', |  | ||||||
| -    'zfs_share_010_neg', 'zfs_share_011_pos', 'zfs_share_concurrent_shares']
 |  | ||||||
| +    'zfs_share_010_neg', 'zfs_share_011_pos', 'zfs_share_concurrent_shares',
 |  | ||||||
| +    'zfs_share_after_mount']
 |  | ||||||
|  tags = ['functional', 'cli_root', 'zfs_share'] |  | ||||||
|   |  | ||||||
|  [tests/functional/cli_root/zfs_snapshot] |  | ||||||
| diff --git a/tests/zfs-tests/tests/Makefile.am b/tests/zfs-tests/tests/Makefile.am
 |  | ||||||
| index c20b428db..3798194f0 100644
 |  | ||||||
| --- a/tests/zfs-tests/tests/Makefile.am
 |  | ||||||
| +++ b/tests/zfs-tests/tests/Makefile.am
 |  | ||||||
| @@ -912,6 +912,7 @@ nobase_dist_datadir_zfs_tests_tests_SCRIPTS += \
 |  | ||||||
|  	functional/cli_root/zfs_share/zfs_share_012_pos.ksh \ |  | ||||||
|  	functional/cli_root/zfs_share/zfs_share_013_pos.ksh \ |  | ||||||
|  	functional/cli_root/zfs_share/zfs_share_concurrent_shares.ksh \ |  | ||||||
| +	functional/cli_root/zfs_share/zfs_share_after_mount.ksh \
 |  | ||||||
|  	functional/cli_root/zfs_snapshot/cleanup.ksh \ |  | ||||||
|  	functional/cli_root/zfs_snapshot/setup.ksh \ |  | ||||||
|  	functional/cli_root/zfs_snapshot/zfs_snapshot_001_neg.ksh \ |  | ||||||
| diff --git a/tests/zfs-tests/tests/functional/cli_root/zfs_share/zfs_share_after_mount.ksh b/tests/zfs-tests/tests/functional/cli_root/zfs_share/zfs_share_after_mount.ksh
 |  | ||||||
| new file mode 100755 |  | ||||||
| index 000000000..0d4b66ea8
 |  | ||||||
| --- /dev/null
 |  | ||||||
| +++ b/tests/zfs-tests/tests/functional/cli_root/zfs_share/zfs_share_after_mount.ksh
 |  | ||||||
| @@ -0,0 +1,62 @@
 |  | ||||||
| +#!/bin/ksh -p
 |  | ||||||
| +#
 |  | ||||||
| +# CDDL HEADER START
 |  | ||||||
| +#
 |  | ||||||
| +# The contents of this file are subject to the terms of the
 |  | ||||||
| +# Common Development and Distribution License (the "License").
 |  | ||||||
| +# You may not use this file except in compliance with the License.
 |  | ||||||
| +#
 |  | ||||||
| +# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 |  | ||||||
| +# or https://opensource.org/licenses/CDDL-1.0.
 |  | ||||||
| +# See the License for the specific language governing permissions
 |  | ||||||
| +# and limitations under the License.
 |  | ||||||
| +#
 |  | ||||||
| +# When distributing Covered Code, include this CDDL HEADER in each
 |  | ||||||
| +# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 |  | ||||||
| +# If applicable, add the following below this CDDL HEADER, with the
 |  | ||||||
| +# fields enclosed by brackets "[]" replaced with your own identifying
 |  | ||||||
| +# information: Portions Copyright [yyyy] [name of copyright owner]
 |  | ||||||
| +#
 |  | ||||||
| +# CDDL HEADER END
 |  | ||||||
| +#
 |  | ||||||
| +
 |  | ||||||
| +#
 |  | ||||||
| +# Copyright (c) 2023 by Proxmox. All rights reserved.
 |  | ||||||
| +#
 |  | ||||||
| +
 |  | ||||||
| +. $STF_SUITE/include/libtest.shlib
 |  | ||||||
| +
 |  | ||||||
| +# DESCRIPTION:
 |  | ||||||
| +# Verify that nfs shares persist after zfs mount -a
 |  | ||||||
| +#
 |  | ||||||
| +# STRATEGY:
 |  | ||||||
| +# 1. Verify that the filesystem is not shared.
 |  | ||||||
| +# 2. Enable the 'sharenfs' property
 |  | ||||||
| +# 3. Verify filesystem is shared
 |  | ||||||
| +# 4. Invoke 'zfs mount -a'
 |  | ||||||
| +# 5. Verify filesystem is still shared
 |  | ||||||
| +
 |  | ||||||
| +verify_runnable "global"
 |  | ||||||
| +
 |  | ||||||
| +function cleanup
 |  | ||||||
| +{
 |  | ||||||
| +	log_must zfs set sharenfs=off $TESTPOOL/$TESTFS
 |  | ||||||
| +	is_shared $TESTPOOL/$TESTFS && \
 |  | ||||||
| +		log_must unshare_fs $TESTPOOL/$TESTFS
 |  | ||||||
| +	log_must zfs share -a
 |  | ||||||
| +}
 |  | ||||||
| +
 |  | ||||||
| +
 |  | ||||||
| +log_onexit cleanup
 |  | ||||||
| +
 |  | ||||||
| +cleanup
 |  | ||||||
| +
 |  | ||||||
| +log_must zfs set sharenfs="on" $TESTPOOL/$TESTFS
 |  | ||||||
| +log_must is_shared $TESTPOOL/$TESTFS
 |  | ||||||
| +log_must is_exported $TESTPOOL/$TESTFS
 |  | ||||||
| +
 |  | ||||||
| +log_must zfs mount -a
 |  | ||||||
| +log_must is_shared $TESTPOOL/$TESTFS
 |  | ||||||
| +log_must is_exported $TESTPOOL/$TESTFS
 |  | ||||||
| +
 |  | ||||||
| +log_pass "Verify that nfs shares persist after zfs mount -a"
 |  | ||||||
							
								
								
									
										1
									
								
								debian/patches/series
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								debian/patches/series
									
									
									
									
										vendored
									
									
								
							| @ -9,4 +9,3 @@ | |||||||
| 0009-arc-stat-summary-guard-access-to-l2arc-MFU-MRU-stats.patch | 0009-arc-stat-summary-guard-access-to-l2arc-MFU-MRU-stats.patch | ||||||
| 0010-Fix-nfs_truncate_shares-without-etc-exports.d.patch | 0010-Fix-nfs_truncate_shares-without-etc-exports.d.patch | ||||||
| 0011-zpool-status-tighten-bounds-for-noalloc-stat-availab.patch | 0011-zpool-status-tighten-bounds-for-noalloc-stat-availab.patch | ||||||
| 0012-fix-mount-do-not-truncate-shares-not-zfs-mount.patch |  | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								upstream
									
									
									
									
									
								
							
							
								
								
								
								
								
								
							
						
						
									
										2
									
								
								upstream
									
									
									
									
									
								
							| @ -1 +1 @@ | |||||||
| Subproject commit 494aaaed89cb9fe9f2da3b6c6f465a4bc9f6a7e1 | Subproject commit c883088df83ced3a2b8b38e6d89a5e63fb153ee4 | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Stoiko Ivanov
						Stoiko Ivanov