Compare commits
44 Commits
stable-7
...
6c9ff9b992
| Author | SHA1 | Date | |
|---|---|---|---|
| 6c9ff9b992 | |||
| b48cfd2b15 | |||
| a5e0251015 | |||
| 838cd1d173 | |||
| 5f4f0445f4 | |||
| 81d11761c3 | |||
| 3bda92bd20 | |||
| f67eb9538f | |||
| 00036e5a6e | |||
| 3db00caad9 | |||
| e295f30e6a | |||
| 96c807af63 | |||
| 88fd6e053b | |||
| 4f818e9880 | |||
| 310afb0d19 | |||
| 0f9a07b53e | |||
| aa99285dda | |||
| 7e3b7d81a1 | |||
| 28de0abfa9 | |||
| a20ffcd44f | |||
| 1382616c40 | |||
| 1621cb1079 | |||
| 508220ed2c | |||
| 6da885c3b1 | |||
| 2840fef531 | |||
| 1f8dab1515 | |||
| 2c95b92384 | |||
| 9e8946d4b9 | |||
| 8c6520d1fc | |||
| aa26132525 | |||
| 13c7e925aa | |||
| a80c5e3597 | |||
| 149fd91bb2 | |||
| 362d3432be | |||
| f5ed5be89a | |||
| 5891aaec34 | |||
| 63e591d8a9 | |||
| d855afe7be | |||
| 34d701d1ac | |||
| 40fe66e33e | |||
| 1b7710c13c | |||
| 2f5fca8a1a | |||
| 8ba2c83746 | |||
| dff6b68bf5 |
@@ -0,0 +1,7 @@
|
|||||||
|
/*.build
|
||||||
|
/*.buildinfo
|
||||||
|
/*.changes
|
||||||
|
/*.deb
|
||||||
|
/*.dsc
|
||||||
|
/*.tar*
|
||||||
|
/zfs-utils-*.*/
|
||||||
@@ -1,9 +1,11 @@
|
|||||||
include /usr/share/dpkg/default.mk
|
include /usr/share/dpkg/default.mk
|
||||||
# source form https://github.com/zfsonlinux/
|
# source form https://github.com/zfsonlinux/
|
||||||
|
|
||||||
ZFSDIR=zfs-linux_$(DEB_VERSION_UPSTREAM)
|
PACKAGE = zfs-linux
|
||||||
ZFSSRC=upstream
|
|
||||||
ORIG_SRC_TAR=$(ZFSDIR).orig.tar.gz
|
SRCDIR = upstream
|
||||||
|
BUILDDIR ?= $(PACKAGE)-$(DEB_VERSION_UPSTREAM)
|
||||||
|
ORIG_SRC_TAR = $(PACKAGE)_$(DEB_VERSION_UPSTREAM).orig.tar.gz
|
||||||
|
|
||||||
ZFS_DEB1= libnvpair3linux_$(DEB_VERSION)_amd64.deb
|
ZFS_DEB1= libnvpair3linux_$(DEB_VERSION)_amd64.deb
|
||||||
|
|
||||||
@@ -30,10 +32,14 @@ DEBS= $(ZFS_DEB1) $(ZFS_DEB2) $(ZFS_DBG_DEBS)
|
|||||||
ZFS_DSC = zfs-linux_$(DEB_VERSION).dsc
|
ZFS_DSC = zfs-linux_$(DEB_VERSION).dsc
|
||||||
|
|
||||||
all: deb
|
all: deb
|
||||||
.PHONY: deb
|
|
||||||
|
.PHONY: deb dsc
|
||||||
deb: $(DEBS)
|
deb: $(DEBS)
|
||||||
.PHONY: dsc
|
|
||||||
dsc: $(ZFS_DSC)
|
dsc:
|
||||||
|
rm -rf *.dsc $(BUILDDIR)
|
||||||
|
$(MAKE) $(ZFS_DSC)
|
||||||
|
lintian $(ZFS_DSC)
|
||||||
|
|
||||||
# called from pve-kernel's Makefile to get patched sources
|
# called from pve-kernel's Makefile to get patched sources
|
||||||
.PHONY: kernel
|
.PHONY: kernel
|
||||||
@@ -47,38 +53,41 @@ dinstall: $(DEBS)
|
|||||||
|
|
||||||
.PHONY: submodule
|
.PHONY: submodule
|
||||||
submodule:
|
submodule:
|
||||||
test -f "$(ZFSSRC)/README.md" || git submodule update --init
|
test -f "$(SRCDIR)/README.md" || git submodule update --init
|
||||||
$(ZFSSRC)/README.md: submodule
|
|
||||||
|
$(SRCDIR)/README.md: submodule
|
||||||
|
|
||||||
.PHONY: zfs
|
.PHONY: zfs
|
||||||
zfs: $(DEBS)
|
zfs: $(DEBS)
|
||||||
$(ZFS_DEB2) $(ZFS_DBG_DEBS): $(ZFS_DEB1)
|
$(ZFS_DEB2) $(ZFS_DBG_DEBS): $(ZFS_DEB1)
|
||||||
$(ZFS_DEB1): $(ZFSDIR)
|
$(ZFS_DEB1): $(BUILDDIR)
|
||||||
cd $(ZFSDIR); dpkg-buildpackage -b -uc -us
|
cd $(BUILDDIR); dpkg-buildpackage -b -uc -us
|
||||||
lintian $(DEBS)
|
lintian $(DEBS)
|
||||||
|
|
||||||
$(ORIG_SRC_TAR): $(ZFSDIR)
|
$(ORIG_SRC_TAR): $(BUILDDIR)
|
||||||
tar czf $(ORIG_SRC_TAR) --exclude="$(ZFSDIR)/debian" $(ZFSDIR)
|
tar czf $(ORIG_SRC_TAR) --exclude="$(BUILDDIR)/debian" $(BUILDDIR)
|
||||||
|
|
||||||
$(ZFS_DSC): $(ZFSDIR) $(ORIG_SRC_TAR)
|
$(ZFS_DSC): $(BUILDDIR) $(ORIG_SRC_TAR)
|
||||||
tar czf zfs-linux_$(ZFSVER).orig.tar.gz $(ZFSDIR)
|
cd $(BUILDDIR); dpkg-buildpackage -S -uc -us -d
|
||||||
cd $(ZFSDIR); dpkg-buildpackage -S -uc -us -d
|
|
||||||
lintian $@
|
|
||||||
|
|
||||||
$(ZFSDIR): $(ZFSSRC)/README.md $(ZFSSRC) debian
|
sbuild: $(ZFS_DSC)
|
||||||
rm -rf $(ZFSDIR) $(ZFSDIR).tmp
|
sbuild $(ZFS_DSC)
|
||||||
cp -a $(ZFSSRC) $(ZFSDIR).tmp
|
|
||||||
cp -a debian $(ZFSDIR).tmp/debian
|
|
||||||
mv $(ZFSDIR).tmp $(ZFSDIR)
|
|
||||||
|
|
||||||
|
$(BUILDDIR): $(SRCDIR)/README.md $(SRCDIR) debian
|
||||||
|
rm -rf $@ $@.tmp
|
||||||
|
cp -a $(SRCDIR) $@.tmp
|
||||||
|
cp -a debian $@.tmp/debian
|
||||||
|
mv $@.tmp $@
|
||||||
|
|
||||||
.PHONY: clean
|
.PHONY: clean
|
||||||
clean:
|
clean:
|
||||||
rm -rf *~ *.deb *.changes *.buildinfo *.build *.dsc *.orig.tar.* *.debian.tar.* $(ZFSDIR)
|
rm -rf $(PACKAGE)-[0-9]*/
|
||||||
|
rm -f *~ *.deb *.changes *.buildinfo *.build *.dsc *.orig.tar.* *.debian.tar.*
|
||||||
|
|
||||||
.PHONY: distclean
|
.PHONY: distclean
|
||||||
distclean: clean
|
distclean: clean
|
||||||
|
|
||||||
.PHONY: upload
|
.PHONY: upload
|
||||||
|
upload: UPLOAD_DIST ?= $(DEB_DISTRIBUTION)
|
||||||
upload: $(DEBS)
|
upload: $(DEBS)
|
||||||
tar -cf - $(DEBS) | ssh repoman@repo.proxmox.com -- upload --product pve,pmg,pbs --dist bullseye --arch amd64
|
tar -cf - $(DEBS) | ssh repoman@repo.proxmox.com -- upload --product pve,pmg,pbs --dist $(UPLOAD_DIST) --arch $(DEB_HOST_ARCH)
|
||||||
|
|||||||
Vendored
+84
@@ -1,3 +1,87 @@
|
|||||||
|
zfs-linux (2.2.3-pve1) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* update to new ZFS upstream 2.2.3 release
|
||||||
|
|
||||||
|
* fix #5288: correctly handle zvols with more than 15 partitions in udev
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Mon, 11 Mar 2024 13:42:50 +0100
|
||||||
|
|
||||||
|
zfs-linux (2.2.2-pve2) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* fix #5101: ensure datasets that have sharenfs enabled are not unexported
|
||||||
|
after a `zfs mount -a` call.
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Mon, 19 Feb 2024 16:56:37 +0100
|
||||||
|
|
||||||
|
zfs-linux (2.2.2-pve1) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* update to new ZFS upstream 2.2.2 release, as we have all important fixes
|
||||||
|
for recent discovered data integrity issues backported to previous
|
||||||
|
versions, there should be no visible change in that regard.
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Mon, 04 Dec 2023 16:50:25 +0100
|
||||||
|
|
||||||
|
zfs-linux (2.2.0-pve4) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* pick bug-fix staged for 2.2.2:
|
||||||
|
- fix (rare) corruption caused by dirty dnode being treated as clean
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Wed, 29 Nov 2023 09:21:26 +0100
|
||||||
|
|
||||||
|
zfs-linux (2.2.0-pve3) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* pick bug-fixes staged for 2.2.1:
|
||||||
|
- add a tunable to disable BRT support and disable it by default
|
||||||
|
- fix block cloning between unencrypted and encrypted datasets
|
||||||
|
- disable block cloning by default
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Fri, 17 Nov 2023 17:32:58 +0100
|
||||||
|
|
||||||
|
zfs-linux (2.2.0-pve2) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* avoid error from zfs-mount when /etc/exports.d does not exist (yet)
|
||||||
|
|
||||||
|
* ensure vdev_stat struct layout compat between 2.1 and 2.2, avoiding
|
||||||
|
false-positive detection of the non-allocating feature from 2.2 when the
|
||||||
|
kernel still used the 2.1 module.
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Sun, 12 Nov 2023 16:02:02 +0100
|
||||||
|
|
||||||
|
zfs-linux (2.2.0-pve1) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* update ZFS to 2.2.0
|
||||||
|
|
||||||
|
* zfsutils-linux:
|
||||||
|
- install new systemd units to trim a pool periodically
|
||||||
|
- ship new `zilstat` binary
|
||||||
|
- and new man pages for zfs lock, zfs unlock and vdev properties
|
||||||
|
- remove man pages for zfs jail and zfs unjail, those are for FreeBSD only
|
||||||
|
and the respective commands where never exposed for Linux
|
||||||
|
|
||||||
|
* fix #5014: re-enable blk-mq optimization
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Sun, 15 Oct 2023 12:09:24 +0200
|
||||||
|
|
||||||
|
zfs-linux (2.1.13-pve1) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* update ZFS to 2.1.13
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Thu, 28 Sep 2023 12:22:28 +0200
|
||||||
|
|
||||||
|
zfs-linux (2.1.12-pve1) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* update ZFS to 2.1.12
|
||||||
|
|
||||||
|
* zfs trim: avoid exit-failure if last pool isn't nvme-only
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Tue, 13 Jun 2023 15:25:16 +0200
|
||||||
|
|
||||||
|
zfs-linux (2.1.11-pve2) bookworm; urgency=medium
|
||||||
|
|
||||||
|
* re-build for Debian 12 Bookworm based releases
|
||||||
|
|
||||||
|
-- Proxmox Support Team <support@proxmox.com> Sat, 20 May 2023 19:32:04 +0200
|
||||||
|
|
||||||
zfs-linux (2.1.11-pve1) bullseye; urgency=medium
|
zfs-linux (2.1.11-pve1) bullseye; urgency=medium
|
||||||
|
|
||||||
* update ZFS to 2.1.11
|
* update ZFS to 2.1.11
|
||||||
|
|||||||
Vendored
+3
-16
@@ -151,6 +151,7 @@ Section: contrib/doc
|
|||||||
Architecture: all
|
Architecture: all
|
||||||
Depends:
|
Depends:
|
||||||
${sphinxdoc:Depends},
|
${sphinxdoc:Depends},
|
||||||
|
${sphinxdoc:Built-Using},
|
||||||
${misc:Depends}
|
${misc:Depends}
|
||||||
Recommends:
|
Recommends:
|
||||||
python3-pyzfs
|
python3-pyzfs
|
||||||
@@ -202,8 +203,8 @@ Description: OpenZFS root filesystem capabilities for Linux - dracut
|
|||||||
Package: zfsutils-linux
|
Package: zfsutils-linux
|
||||||
Section: contrib/admin
|
Section: contrib/admin
|
||||||
Architecture: linux-any
|
Architecture: linux-any
|
||||||
Depends: python3, ${misc:Depends}, ${python3:Depends}, ${shlibs:Depends}
|
Depends: python3, ${misc:Depends}, ${shlibs:Depends}
|
||||||
Recommends: lsb-base, zfs-zed
|
Recommends: zfs-zed
|
||||||
Suggests: nfs-kernel-server,
|
Suggests: nfs-kernel-server,
|
||||||
samba-common-bin (>= 3.0.23),
|
samba-common-bin (>= 3.0.23),
|
||||||
zfs-initramfs
|
zfs-initramfs
|
||||||
@@ -285,17 +286,3 @@ Description: Solaris Porting Layer user-space utilities for Linux (dummy)
|
|||||||
to Linux primitives.
|
to Linux primitives.
|
||||||
.
|
.
|
||||||
This is a transitional dummy package. It can safely be removed.
|
This is a transitional dummy package. It can safely be removed.
|
||||||
|
|
||||||
Package: zfs-dbg
|
|
||||||
Section: contrib/metapackages
|
|
||||||
Architecture: all
|
|
||||||
Suggests: libnvpair3linux-dbgsym,
|
|
||||||
libpam-zfs-dbgsym,
|
|
||||||
libuutil3linux-dbgsym,
|
|
||||||
libzfs4linux-dbgsym,
|
|
||||||
libzfsbootenv1linux-dbgsym,
|
|
||||||
libzpool5linux-dbgsym,
|
|
||||||
zfs-test-dbgsym,
|
|
||||||
zfsutils-linux-dbgsym,
|
|
||||||
zfs-zed-dbgsym,
|
|
||||||
Description: Transitional package. It can be safely removed.
|
|
||||||
|
|||||||
Vendored
+33
-64
@@ -37,25 +37,26 @@ Copyright: 2011, 2013, Nexenta Systems, Inc.
|
|||||||
2007, 2009, Sun Microsystems, Inc.
|
2007, 2009, Sun Microsystems, Inc.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: cmd/arc_summary/*
|
Files: cmd/arc_summary
|
||||||
Copyright:
|
Copyright:
|
||||||
2010, 2011, Jason J. Hellenthal <jhell@DataIX.net>
|
2010, 2011, Jason J. Hellenthal <jhell@DataIX.net>
|
||||||
2010, Martin Matuska <mm@FreeBSD.org>
|
2010, Martin Matuska <mm@FreeBSD.org>
|
||||||
2008, Ben Rockwood <benr@cuddletech.com>
|
2008, Ben Rockwood <benr@cuddletech.com>
|
||||||
|
2017, Scot W. Stevenson <scot.stevenson@gmail.com>
|
||||||
License: BSD-2-clause
|
License: BSD-2-clause
|
||||||
|
|
||||||
Files: cmd/arcstat/*
|
Files: cmd/arcstat.in
|
||||||
Source: http://github.com/mharsch/arcstat
|
Source: http://github.com/mharsch/arcstat
|
||||||
Copyright:
|
Copyright:
|
||||||
2007, Oracle and/or its affiliates.
|
2007, Oracle and/or its affiliates.
|
||||||
2010-2015, Mike Harsch
|
2010-2015, Mike Harsch
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: cmd/dbufstat/*
|
Files: cmd/dbufstat.in
|
||||||
Copyright: 2013, Lawrence Livermore National Security, LLC
|
Copyright: 2013, Lawrence Livermore National Security, LLC
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: cmd/mount_zfs/*
|
Files: cmd/mount_zfs.c
|
||||||
Copyright: 2011, Lawrence Livermore National Security, LLC
|
Copyright: 2011, Lawrence Livermore National Security, LLC
|
||||||
2005, 2010, Oracle and/or its affiliates.
|
2005, 2010, Oracle and/or its affiliates.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
@@ -64,7 +65,7 @@ Files: cmd/raidz_test/*
|
|||||||
Copyright: 2016 Gvozden Nešković.
|
Copyright: 2016 Gvozden Nešković.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: cmd/vdev_id/*
|
Files: udev/vdev_id
|
||||||
Copyright: 2011, 2013, Nexenta Systems, Inc.
|
Copyright: 2011, 2013, Nexenta Systems, Inc.
|
||||||
2007, 2009, Sun Microsystems, Inc.
|
2007, 2009, Sun Microsystems, Inc.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
@@ -106,7 +107,7 @@ Copyright:
|
|||||||
2018 Datto Inc.
|
2018 Datto Inc.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: cmd/zhack/*
|
Files: cmd/zhack.c
|
||||||
Copyright: 2013, Steven Hartland.
|
Copyright: 2013, Steven Hartland.
|
||||||
2011, 2012, 2014, Delphix.
|
2011, 2012, 2014, Delphix.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
@@ -132,14 +133,14 @@ Copyright:
|
|||||||
2017, Intel Corporation.
|
2017, Intel Corporation.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: cmd/zstreamdump/*
|
Files: cmd/zstream/*
|
||||||
Copyright:
|
Copyright:
|
||||||
2013, Delphix.
|
2013, 2015 Delphix.
|
||||||
2012, Martin Matuska <martin@matuska.org>
|
2012, Martin Matuska <martin@matuska.org>
|
||||||
2010, Sun Microsystems, Inc.
|
2010, Sun Microsystems, Inc.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: cmd/ztest/*
|
Files: cmd/ztest.c
|
||||||
Copyright:
|
Copyright:
|
||||||
2005, 2010, Oracle and/or its affiliates.
|
2005, 2010, Oracle and/or its affiliates.
|
||||||
2011, 2018 by Delphix.
|
2011, 2018 by Delphix.
|
||||||
@@ -150,7 +151,7 @@ Copyright:
|
|||||||
2017, Intel Corporation.
|
2017, Intel Corporation.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: cmd/zvol_id/*
|
Files: udev/zvol_id.c
|
||||||
Copyright: 2011, Fajar A. Nugraha.
|
Copyright: 2011, Fajar A. Nugraha.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
@@ -158,27 +159,6 @@ Files: config/*
|
|||||||
Copyright: 1996-2012, Free Software Foundation, Inc.
|
Copyright: 1996-2012, Free Software Foundation, Inc.
|
||||||
License: GPL-2+ with autoconf exception
|
License: GPL-2+ with autoconf exception
|
||||||
|
|
||||||
Files: config/ltoptions.m4
|
|
||||||
config/lt~obsolete.m4
|
|
||||||
config/ltversion.m4
|
|
||||||
config/libtool.m4
|
|
||||||
config/ltsugar.m4
|
|
||||||
Copyright: 1996-2012, Free Software Foundation, Inc.
|
|
||||||
License: PERMISSIVE
|
|
||||||
This file is free software; the Free Software Foundation gives
|
|
||||||
unlimited permission to copy and/or distribute it, with or without
|
|
||||||
modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
Files: config/install-sh
|
|
||||||
Copyright: 1994, X Consortium
|
|
||||||
License: Expat
|
|
||||||
|
|
||||||
Files: configure
|
|
||||||
Copyright: 1992-1996, 1998-2010, Free Software
|
|
||||||
License: PERMISSIVE2
|
|
||||||
This configure script is free software; the Free Software Foundation
|
|
||||||
gives unlimited permission to copy, distribute and modify it.
|
|
||||||
|
|
||||||
Files: contrib/bash_completion.d/*
|
Files: contrib/bash_completion.d/*
|
||||||
Copyright: 2010, 2013, Aneurin Price <aneurin.price@gmail.com>
|
Copyright: 2010, 2013, Aneurin Price <aneurin.price@gmail.com>
|
||||||
License: Expat
|
License: Expat
|
||||||
@@ -201,14 +181,8 @@ Copyright:
|
|||||||
2011-2013, Darik Horn <dajhorn@vanadac.com>
|
2011-2013, Darik Horn <dajhorn@vanadac.com>
|
||||||
2018-2019, Mo Zhou <cdluminate@gmail.com>
|
2018-2019, Mo Zhou <cdluminate@gmail.com>
|
||||||
2018-2020, Mo Zhou <lumin@debian.org>
|
2018-2020, Mo Zhou <lumin@debian.org>
|
||||||
2015-2021 Proxmox Server Solutions GmbH <support@proxmox.com>
|
|
||||||
License: GPL-2+
|
License: GPL-2+
|
||||||
|
|
||||||
Files: debian/po/*
|
|
||||||
Copyright:
|
|
||||||
2013, The Debian po file translators.
|
|
||||||
License: CDDL-1.0
|
|
||||||
|
|
||||||
Files: etc/init.d/zfs-*.in
|
Files: etc/init.d/zfs-*.in
|
||||||
Copyright:
|
Copyright:
|
||||||
2016, Carlo Landmeter <clandmeter@gmail.com>
|
2016, Carlo Landmeter <clandmeter@gmail.com>
|
||||||
@@ -399,12 +373,7 @@ Copyright: 2009, Oracle and/or its affiliates.
|
|||||||
2009, Michael Gebetsroither <michael.geb@gmx.at>
|
2009, Michael Gebetsroither <michael.geb@gmx.at>
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: man/man5/zfs-events.5
|
Files: man/man7/zpool-features.7
|
||||||
man/man5/zfs-module-parameters.5
|
|
||||||
Copyright: 2013, Turbo Fredriksson <turbo@bayour.com>
|
|
||||||
License: CDDL-1.0
|
|
||||||
|
|
||||||
Files: man/man5/zpool-features.5
|
|
||||||
Copyright:
|
Copyright:
|
||||||
2013, Delphix
|
2013, Delphix
|
||||||
2013, Saso Kiselkov
|
2013, Saso Kiselkov
|
||||||
@@ -427,16 +396,12 @@ Copyright: 2007, Sun Microsystems, Inc.
|
|||||||
2013, Delphix
|
2013, Delphix
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: man/man8/zstreamdump.8
|
|
||||||
Copyright: 2009, Sun Microsystems, Inc.
|
|
||||||
License: CDDL-1.0
|
|
||||||
|
|
||||||
Files: module/*
|
Files: module/*
|
||||||
Copyright: 2011-2014, Delphix.
|
Copyright: 2011-2014, Delphix.
|
||||||
2007, 2009, 2010, Sun Microsystems, Inc.
|
2007, 2009, 2010, Sun Microsystems, Inc.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/lua
|
Files: module/lua/*
|
||||||
Copyright: 1994-2015 Lua.org, PUC-Rio.
|
Copyright: 1994-2015 Lua.org, PUC-Rio.
|
||||||
License: Expat
|
License: Expat
|
||||||
|
|
||||||
@@ -483,7 +448,7 @@ Copyright: 2013, Saso Kiselkov.
|
|||||||
2005, 2010, Oracle and/or its affiliates.
|
2005, 2010, Oracle and/or its affiliates.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zcommon/zfs_uio.c
|
Files: module/os/linux/zfs/zfs_uio.c
|
||||||
Copyright: 2007, 2009, 2010, Sun Microsystems, Inc.
|
Copyright: 2007, 2009, 2010, Sun Microsystems, Inc.
|
||||||
1983-1989, AT&T
|
1983-1989, AT&T
|
||||||
1982, 1986, 1988, The Regents of the University of California
|
1982, 1986, 1988, The Regents of the University of California
|
||||||
@@ -583,7 +548,6 @@ Files: module/zfs/dmu_zfetch.c
|
|||||||
module/zfs/rrwlock.c
|
module/zfs/rrwlock.c
|
||||||
module/zfs/space_map.c
|
module/zfs/space_map.c
|
||||||
module/zfs/space_reftree.c
|
module/zfs/space_reftree.c
|
||||||
module/zfs/vdev_cache.c
|
|
||||||
module/zfs/vdev_mirror.c
|
module/zfs/vdev_mirror.c
|
||||||
module/zfs/vdev_missing.c
|
module/zfs/vdev_missing.c
|
||||||
module/zfs/vdev_queue.c
|
module/zfs/vdev_queue.c
|
||||||
@@ -651,14 +615,16 @@ Copyright: 2013, Steven Hartland.
|
|||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zfs/gzip.c
|
Files: module/zfs/gzip.c
|
||||||
module/zfs/sha256.c
|
|
||||||
module/zfs/spa_boot.c
|
|
||||||
module/zfs/unique.c
|
module/zfs/unique.c
|
||||||
module/zfs/zfs_byteswap.c
|
module/zfs/zfs_byteswap.c
|
||||||
module/zfs/zle.c
|
module/zfs/zle.c
|
||||||
Copyright: 2005-2010, Sun Microsystems, Inc.
|
Copyright: 2005-2010, Sun Microsystems, Inc.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
|
Files: module/icp/algs/sha2/*
|
||||||
|
Copyright: 2022, Tino Reichardt <milky-zfs@mcmilk.de>
|
||||||
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zfs/lz4.c
|
Files: module/zfs/lz4.c
|
||||||
Copyright: 2011-2013, Yann Collet
|
Copyright: 2011-2013, Yann Collet
|
||||||
License: BSD-2-clause
|
License: BSD-2-clause
|
||||||
@@ -697,13 +663,14 @@ Copyright: 2011, 2014, Nexenta Systems, Inc.
|
|||||||
2005, 2010, Oracle and/or its affiliates.
|
2005, 2010, Oracle and/or its affiliates.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zfs/vdev_disk.c
|
Files: module/os/linux/zfs/vdev_disk.c
|
||||||
Copyright: 2012, 2014, Delphix.
|
Copyright: 2012, 2014, Delphix.
|
||||||
2008-2010, Lawrence Livermore National Security, LLC
|
2008-2010, Lawrence Livermore National Security, LLC
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zfs/zfs_ctldir.c
|
Files: module/os/freebsd/zfs/zfs_ctldir.c
|
||||||
Copyright: 2013, Delphix.
|
module/os/linux/zfs/zfs_ctldir.c
|
||||||
|
Copyright: 2013, 2015 Delphix.
|
||||||
2011, Lawrence Livermore National Security, LLC
|
2011, Lawrence Livermore National Security, LLC
|
||||||
2005, 2010, Oracle and/or its affiliates.
|
2005, 2010, Oracle and/or its affiliates.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
@@ -726,7 +693,8 @@ Copyright: 2013, Delphix.
|
|||||||
2005, 2010, Oracle and/or its affiliates.
|
2005, 2010, Oracle and/or its affiliates.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zfs/zfs_vfsops.c
|
Files: module/os/freebsd/zfs/zfs_vfsops.c
|
||||||
|
module/os/linux/zfs/zfs_vfsops.c
|
||||||
module/zfs/zil.c
|
module/zfs/zil.c
|
||||||
Copyright: 2011-2014, Delphix.
|
Copyright: 2011-2014, Delphix.
|
||||||
2010, Robert Milkowski
|
2010, Robert Milkowski
|
||||||
@@ -741,8 +709,9 @@ Copyright: 2015, Chunwei Chen.
|
|||||||
2005, 2010, Oracle and/or its affiliates.
|
2005, 2010, Oracle and/or its affiliates.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zfs/zfs_znode.c
|
Files: module/os/freebsd/zfs/zfs_znode.c
|
||||||
Copyright: 2013, Delphix.
|
module/os/linux/zfs/zfs_znode.c
|
||||||
|
Copyright: 2013, 2015 Delphix.
|
||||||
2007, Jeremy Teo
|
2007, Jeremy Teo
|
||||||
2005, 2010, Oracle and/or its affiliates.
|
2005, 2010, Oracle and/or its affiliates.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
@@ -753,20 +722,20 @@ Copyright: 2013, Saso Kiselkov.
|
|||||||
2009, Sun Microsystems, Inc.
|
2009, Sun Microsystems, Inc.
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zfs/zpl_ctldir.c
|
Files: module/os/linux/zfs/zpl_ctldir.c
|
||||||
module/zfs/zpl_super.c
|
module/os/linux/zfs/zpl_super.c
|
||||||
module/zfs/zpl_xattr.c
|
module/os/linux/zfs/zpl_xattr.c
|
||||||
module/zfs/zvol.c
|
module/zfs/zvol.c
|
||||||
Copyright: 2008-2011, Lawrence Livermore National Security, LLC
|
Copyright: 2008-2011, Lawrence Livermore National Security, LLC
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zfs/zpl_export.c
|
Files: module/os/linux/zfs/zpl_export.c
|
||||||
Copyright: 2012, Cyril Plisko.
|
Copyright: 2012, Cyril Plisko.
|
||||||
2011, Gunnar Beutner
|
2011, Gunnar Beutner
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|
||||||
Files: module/zfs/zpl_file.c
|
Files: module/os/linux/zfs/zpl_file.c
|
||||||
module/zfs/zpl_inode.c
|
module/os/linux/zfs/zpl_inode.c
|
||||||
Copyright: 2015, Chunwei Chen.
|
Copyright: 2015, Chunwei Chen.
|
||||||
2011, Lawrence Livermore National Security, LLC
|
2011, Lawrence Livermore National Security, LLC
|
||||||
License: CDDL-1.0
|
License: CDDL-1.0
|
||||||
|
|||||||
+3
-3
@@ -13,13 +13,13 @@ 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/etc/systemd/system/zfs-zed.service.in b/etc/systemd/system/zfs-zed.service.in
|
diff --git a/etc/systemd/system/zfs-zed.service.in b/etc/systemd/system/zfs-zed.service.in
|
||||||
index be80025a4..20ce8e632 100644
|
index be2fc6734..7606604ec 100644
|
||||||
--- a/etc/systemd/system/zfs-zed.service.in
|
--- a/etc/systemd/system/zfs-zed.service.in
|
||||||
+++ b/etc/systemd/system/zfs-zed.service.in
|
+++ b/etc/systemd/system/zfs-zed.service.in
|
||||||
@@ -4,7 +4,7 @@ Documentation=man:zed(8)
|
@@ -5,7 +5,7 @@ ConditionPathIsDirectory=/sys/module/zfs
|
||||||
ConditionPathIsDirectory=/sys/module/zfs
|
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
|
EnvironmentFile=-@initconfdir@/zfs
|
||||||
-ExecStart=@sbindir@/zed -F
|
-ExecStart=@sbindir@/zed -F
|
||||||
+ExecStart=/usr/sbin/zed -F
|
+ExecStart=/usr/sbin/zed -F
|
||||||
Restart=always
|
Restart=always
|
||||||
|
|||||||
@@ -14,13 +14,13 @@ 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/etc/systemd/system/zfs-import-scan.service.in b/etc/systemd/system/zfs-import-scan.service.in
|
diff --git a/etc/systemd/system/zfs-import-scan.service.in b/etc/systemd/system/zfs-import-scan.service.in
|
||||||
index 598ef501b..e4f3a70c1 100644
|
index c5dd45d87..1c792edf0 100644
|
||||||
--- a/etc/systemd/system/zfs-import-scan.service.in
|
--- a/etc/systemd/system/zfs-import-scan.service.in
|
||||||
+++ b/etc/systemd/system/zfs-import-scan.service.in
|
+++ b/etc/systemd/system/zfs-import-scan.service.in
|
||||||
@@ -13,7 +13,7 @@ ConditionPathIsDirectory=/sys/module/zfs
|
@@ -14,7 +14,7 @@ ConditionPathIsDirectory=/sys/module/zfs
|
||||||
[Service]
|
|
||||||
Type=oneshot
|
Type=oneshot
|
||||||
RemainAfterExit=yes
|
RemainAfterExit=yes
|
||||||
|
EnvironmentFile=-@initconfdir@/zfs
|
||||||
-ExecStart=@sbindir@/zpool import -aN -o cachefile=none $ZPOOL_IMPORT_OPTS
|
-ExecStart=@sbindir@/zpool import -aN -o cachefile=none $ZPOOL_IMPORT_OPTS
|
||||||
+ExecStart=@sbindir@/zpool import -aN -d /dev/disk/by-id -o cachefile=none $ZPOOL_IMPORT_OPTS
|
+ExecStart=@sbindir@/zpool import -aN -d /dev/disk/by-id -o cachefile=none $ZPOOL_IMPORT_OPTS
|
||||||
|
|
||||||
|
|||||||
+2
-2
@@ -13,10 +13,10 @@ 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 227b26c26..240d0dbfa 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
|
||||||
@@ -42,7 +42,7 @@ ZED_EMAIL_ADDR="root"
|
@@ -41,7 +41,7 @@ ZED_EMAIL_ADDR="root"
|
||||||
##
|
##
|
||||||
# Minimum number of seconds between notifications for a similar event.
|
# Minimum number of seconds between notifications for a similar event.
|
||||||
#
|
#
|
||||||
|
|||||||
+25
-10
@@ -3,29 +3,44 @@ From: Antonio Russo <antonio.e.russo@gmail.com>
|
|||||||
Date: Fri, 20 Mar 2020 17:28:43 +0100
|
Date: Fri, 20 Mar 2020 17:28:43 +0100
|
||||||
Subject: [PATCH] dont symlink zed scripts
|
Subject: [PATCH] dont symlink zed scripts
|
||||||
|
|
||||||
(cherry picked and adapted from 5cee380324d74e640d5dd7a360faba3994c8007f [0])
|
Of the zedlet scripts shipped by upstream, a subset are enabled by
|
||||||
|
default, by creating symlinks in /etc/zfs/zed.d. These symlinks are
|
||||||
|
shipped in the zfs-zed package. dpkg, however, does not support
|
||||||
|
conffile handling of symlinks, and therefore any changes (removals) to
|
||||||
|
the symlinks are not preserved on package upgrade.
|
||||||
|
|
||||||
[0] https://salsa.debian.org/zfsonlinux-team/zfs.git
|
To address this policy violation, we:
|
||||||
|
|
||||||
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
1. During package build, create a list of enabled-by-default zedlets,
|
||||||
|
instead of creating symlinks.
|
||||||
|
2. On package removal, identify all enabled-by-default zedlets whose
|
||||||
|
symlinks do not exist (i.e., were removed by the user). This is done
|
||||||
|
by creating "whiteout" links to /dev/null in their place).
|
||||||
|
3. On package installation, create links to enabled-by-default zedlets
|
||||||
|
UNLESS there is already a file there (i.e., abort if there is a
|
||||||
|
whiteout link).
|
||||||
|
4. We also clean up broken symlinks to removed zedlets at package
|
||||||
|
postinst.
|
||||||
|
|
||||||
Description: track default symlinks, instead of symlinking
|
Description: track default symlinks, instead of symlinking
|
||||||
Forwarded: no need
|
Forwarded: no need
|
||||||
|
(cherry picked from https://salsa.debian.org/zfsonlinux-team/zfs/-/commit/5cee380324d7)
|
||||||
|
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
||||||
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
||||||
---
|
---
|
||||||
cmd/zed/zed.d/Makefile.am | 2 +-
|
cmd/zed/zed.d/Makefile.am | 2 +-
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/cmd/zed/zed.d/Makefile.am b/cmd/zed/zed.d/Makefile.am
|
diff --git a/cmd/zed/zed.d/Makefile.am b/cmd/zed/zed.d/Makefile.am
|
||||||
index 2c8173b3e..ad39292e4 100644
|
index 812558cf6..f802cf140 100644
|
||||||
--- a/cmd/zed/zed.d/Makefile.am
|
--- a/cmd/zed/zed.d/Makefile.am
|
||||||
+++ b/cmd/zed/zed.d/Makefile.am
|
+++ b/cmd/zed/zed.d/Makefile.am
|
||||||
@@ -49,7 +49,7 @@ install-data-hook:
|
@@ -48,7 +48,7 @@ zed-install-data-hook:
|
||||||
for f in $(zedconfdefaults); do \
|
set -x; for f in $(zedconfdefaults); do \
|
||||||
test -f "$(DESTDIR)$(zedconfdir)/$${f}" -o \
|
[ -f "$(DESTDIR)$(zedconfdir)/$${f}" ] ||\
|
||||||
-L "$(DESTDIR)$(zedconfdir)/$${f}" || \
|
[ -L "$(DESTDIR)$(zedconfdir)/$${f}" ] || \
|
||||||
- ln -s "$(zedexecdir)/$${f}" "$(DESTDIR)$(zedconfdir)"; \
|
- $(LN_S) "$(zedexecdir)/$${f}" "$(DESTDIR)$(zedconfdir)"; \
|
||||||
+ echo "$${f}" >> "$(DESTDIR)$(zedexecdir)/DEFAULT-ENABLED" ; \
|
+ echo "$${f}" >> "$(DESTDIR)$(zedexecdir)/DEFAULT-ENABLED" ; \
|
||||||
done
|
done
|
||||||
chmod 0600 "$(DESTDIR)$(zedconfdir)/zed.rc"
|
|
||||||
|
|
||||||
|
SHELLCHECKSCRIPTS += $(dist_zedconf_DATA) $(dist_zedexec_SCRIPTS) $(nodist_zedexec_SCRIPTS)
|
||||||
|
|||||||
@@ -13,16 +13,28 @@ can contain characters which will be escaped by systemd.
|
|||||||
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
||||||
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
||||||
---
|
---
|
||||||
etc/systemd/system/50-zfs.preset.in | 1 +
|
etc/Makefile.am | 1 +
|
||||||
etc/systemd/system/Makefile.am | 1 +
|
etc/systemd/system/50-zfs.preset | 1 +
|
||||||
etc/systemd/system/zfs-import@.service.in | 16 ++++++++++++++++
|
etc/systemd/system/zfs-import@.service.in | 16 ++++++++++++++++
|
||||||
3 files changed, 18 insertions(+)
|
3 files changed, 18 insertions(+)
|
||||||
create mode 100644 etc/systemd/system/zfs-import@.service.in
|
create mode 100644 etc/systemd/system/zfs-import@.service.in
|
||||||
|
|
||||||
diff --git a/etc/systemd/system/50-zfs.preset.in b/etc/systemd/system/50-zfs.preset.in
|
diff --git a/etc/Makefile.am b/etc/Makefile.am
|
||||||
|
index 7187762d3..de131dc87 100644
|
||||||
|
--- a/etc/Makefile.am
|
||||||
|
+++ b/etc/Makefile.am
|
||||||
|
@@ -54,6 +54,7 @@ dist_systemdpreset_DATA = \
|
||||||
|
systemdunit_DATA = \
|
||||||
|
%D%/systemd/system/zfs-import-cache.service \
|
||||||
|
%D%/systemd/system/zfs-import-scan.service \
|
||||||
|
+ %D%/systemd/system/zfs-import@.service \
|
||||||
|
%D%/systemd/system/zfs-import.target \
|
||||||
|
%D%/systemd/system/zfs-mount.service \
|
||||||
|
%D%/systemd/system/zfs-scrub-monthly@.timer \
|
||||||
|
diff --git a/etc/systemd/system/50-zfs.preset b/etc/systemd/system/50-zfs.preset
|
||||||
index e4056a92c..030611419 100644
|
index e4056a92c..030611419 100644
|
||||||
--- a/etc/systemd/system/50-zfs.preset.in
|
--- a/etc/systemd/system/50-zfs.preset
|
||||||
+++ b/etc/systemd/system/50-zfs.preset.in
|
+++ b/etc/systemd/system/50-zfs.preset
|
||||||
@@ -1,6 +1,7 @@
|
@@ -1,6 +1,7 @@
|
||||||
# ZFS is enabled by default
|
# ZFS is enabled by default
|
||||||
enable zfs-import-cache.service
|
enable zfs-import-cache.service
|
||||||
@@ -31,18 +43,6 @@ index e4056a92c..030611419 100644
|
|||||||
enable zfs-import.target
|
enable zfs-import.target
|
||||||
enable zfs-mount.service
|
enable zfs-mount.service
|
||||||
enable zfs-share.service
|
enable zfs-share.service
|
||||||
diff --git a/etc/systemd/system/Makefile.am b/etc/systemd/system/Makefile.am
|
|
||||||
index 35f833de5..af3ae597c 100644
|
|
||||||
--- a/etc/systemd/system/Makefile.am
|
|
||||||
+++ b/etc/systemd/system/Makefile.am
|
|
||||||
@@ -7,6 +7,7 @@ systemdunit_DATA = \
|
|
||||||
zfs-zed.service \
|
|
||||||
zfs-import-cache.service \
|
|
||||||
zfs-import-scan.service \
|
|
||||||
+ zfs-import@.service \
|
|
||||||
zfs-mount.service \
|
|
||||||
zfs-share.service \
|
|
||||||
zfs-volume-wait.service \
|
|
||||||
diff --git a/etc/systemd/system/zfs-import@.service.in b/etc/systemd/system/zfs-import@.service.in
|
diff --git a/etc/systemd/system/zfs-import@.service.in b/etc/systemd/system/zfs-import@.service.in
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..9b4ee9371
|
index 000000000..9b4ee9371
|
||||||
|
|||||||
@@ -15,36 +15,36 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
|||||||
rename man/{man1/arcstat.1 => man8/arcstat.8} (99%)
|
rename man/{man1/arcstat.1 => man8/arcstat.8} (99%)
|
||||||
|
|
||||||
diff --git a/man/Makefile.am b/man/Makefile.am
|
diff --git a/man/Makefile.am b/man/Makefile.am
|
||||||
index 64650c2b9..95a66a62f 100644
|
index 45156571e..3713e9371 100644
|
||||||
--- a/man/Makefile.am
|
--- a/man/Makefile.am
|
||||||
+++ b/man/Makefile.am
|
+++ b/man/Makefile.am
|
||||||
@@ -8,7 +8,6 @@ dist_man_MANS = \
|
@@ -2,7 +2,6 @@ dist_noinst_man_MANS = \
|
||||||
man1/ztest.1 \
|
%D%/man1/cstyle.1
|
||||||
man1/raidz_test.1 \
|
|
||||||
man1/zvol_wait.1 \
|
dist_man_MANS = \
|
||||||
- man1/arcstat.1 \
|
- %D%/man1/arcstat.1 \
|
||||||
\
|
%D%/man1/raidz_test.1 \
|
||||||
man5/vdev_id.conf.5 \
|
%D%/man1/test-runner.1 \
|
||||||
\
|
%D%/man1/zhack.1 \
|
||||||
@@ -22,6 +21,7 @@ dist_man_MANS = \
|
@@ -22,6 +21,7 @@ dist_man_MANS = \
|
||||||
man7/zpoolconcepts.7 \
|
%D%/man7/zpoolconcepts.7 \
|
||||||
man7/zpoolprops.7 \
|
%D%/man7/zpoolprops.7 \
|
||||||
\
|
\
|
||||||
+ man8/arcstat.8 \
|
+ %D%/man8/arcstat.8 \
|
||||||
man8/fsck.zfs.8 \
|
%D%/man8/fsck.zfs.8 \
|
||||||
man8/mount.zfs.8 \
|
%D%/man8/mount.zfs.8 \
|
||||||
man8/vdev_id.8 \
|
%D%/man8/vdev_id.8 \
|
||||||
diff --git a/man/man1/arcstat.1 b/man/man8/arcstat.8
|
diff --git a/man/man1/arcstat.1 b/man/man8/arcstat.8
|
||||||
similarity index 99%
|
similarity index 99%
|
||||||
rename from man/man1/arcstat.1
|
rename from man/man1/arcstat.1
|
||||||
rename to man/man8/arcstat.8
|
rename to man/man8/arcstat.8
|
||||||
index a69cd8937..dfe9c971b 100644
|
index 82358fa68..a8fb55498 100644
|
||||||
--- a/man/man1/arcstat.1
|
--- a/man/man1/arcstat.1
|
||||||
+++ b/man/man8/arcstat.8
|
+++ b/man/man8/arcstat.8
|
||||||
@@ -13,7 +13,7 @@
|
@@ -13,7 +13,7 @@
|
||||||
.\" Copyright (c) 2020 by AJ Jordan. All rights reserved.
|
.\" Copyright (c) 2020 by AJ Jordan. All rights reserved.
|
||||||
.\"
|
.\"
|
||||||
.Dd May 26, 2021
|
.Dd December 23, 2022
|
||||||
-.Dt ARCSTAT 1
|
-.Dt ARCSTAT 1
|
||||||
+.Dt ARCSTAT 8
|
+.Dt ARCSTAT 8
|
||||||
.Os
|
.Os
|
||||||
|
|||||||
+14
-14
@@ -22,15 +22,15 @@ l2_bufc_data_asize l2_bufc_metadata_asize to .get accessor
|
|||||||
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
||||||
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
||||||
---
|
---
|
||||||
cmd/arc_summary/arc_summary3 | 28 ++++++++++++++--------------
|
cmd/arc_summary | 28 ++++++++++++++--------------
|
||||||
cmd/arcstat/arcstat.in | 14 +++++++-------
|
cmd/arcstat.in | 14 +++++++-------
|
||||||
2 files changed, 21 insertions(+), 21 deletions(-)
|
2 files changed, 21 insertions(+), 21 deletions(-)
|
||||||
|
|
||||||
diff --git a/cmd/arc_summary/arc_summary3 b/cmd/arc_summary/arc_summary3
|
diff --git a/cmd/arc_summary b/cmd/arc_summary
|
||||||
index 9d0c2d30d..fd2581ae2 100755
|
index 9c69ec4f8..edf94ea2a 100755
|
||||||
--- a/cmd/arc_summary/arc_summary3
|
--- a/cmd/arc_summary
|
||||||
+++ b/cmd/arc_summary/arc_summary3
|
+++ b/cmd/arc_summary
|
||||||
@@ -609,13 +609,13 @@ def section_arc(kstats_dict):
|
@@ -655,13 +655,13 @@ def section_arc(kstats_dict):
|
||||||
prt_i1('L2 cached evictions:', f_bytes(arc_stats['evict_l2_cached']))
|
prt_i1('L2 cached evictions:', f_bytes(arc_stats['evict_l2_cached']))
|
||||||
prt_i1('L2 eligible evictions:', f_bytes(arc_stats['evict_l2_eligible']))
|
prt_i1('L2 eligible evictions:', f_bytes(arc_stats['evict_l2_eligible']))
|
||||||
prt_i2('L2 eligible MFU evictions:',
|
prt_i2('L2 eligible MFU evictions:',
|
||||||
@@ -48,7 +48,7 @@ index 9d0c2d30d..fd2581ae2 100755
|
|||||||
prt_i1('L2 ineligible evictions:',
|
prt_i1('L2 ineligible evictions:',
|
||||||
f_bytes(arc_stats['evict_l2_ineligible']))
|
f_bytes(arc_stats['evict_l2_ineligible']))
|
||||||
print()
|
print()
|
||||||
@@ -757,20 +757,20 @@ def section_l2arc(kstats_dict):
|
@@ -851,20 +851,20 @@ def section_l2arc(kstats_dict):
|
||||||
f_perc(arc_stats['l2_hdr_size'], arc_stats['l2_size']),
|
f_perc(arc_stats['l2_hdr_size'], arc_stats['l2_size']),
|
||||||
f_bytes(arc_stats['l2_hdr_size']))
|
f_bytes(arc_stats['l2_hdr_size']))
|
||||||
prt_i2('MFU allocated size:',
|
prt_i2('MFU allocated size:',
|
||||||
@@ -79,11 +79,11 @@ index 9d0c2d30d..fd2581ae2 100755
|
|||||||
|
|
||||||
print()
|
print()
|
||||||
prt_1('L2ARC breakdown:', f_hits(l2_access_total))
|
prt_1('L2ARC breakdown:', f_hits(l2_access_total))
|
||||||
diff --git a/cmd/arcstat/arcstat.in b/cmd/arcstat/arcstat.in
|
diff --git a/cmd/arcstat.in b/cmd/arcstat.in
|
||||||
index d2b2e28d1..8004940b3 100755
|
index 8df1c62f7..833348d0e 100755
|
||||||
--- a/cmd/arcstat/arcstat.in
|
--- a/cmd/arcstat.in
|
||||||
+++ b/cmd/arcstat/arcstat.in
|
+++ b/cmd/arcstat.in
|
||||||
@@ -482,8 +482,8 @@ def calculate():
|
@@ -565,8 +565,8 @@ def calculate():
|
||||||
v["el2skip"] = d["evict_l2_skip"] // sint
|
v["el2skip"] = d["evict_l2_skip"] // sint
|
||||||
v["el2cach"] = d["evict_l2_cached"] // sint
|
v["el2cach"] = d["evict_l2_cached"] // sint
|
||||||
v["el2el"] = d["evict_l2_eligible"] // sint
|
v["el2el"] = d["evict_l2_eligible"] // sint
|
||||||
@@ -94,7 +94,7 @@ index d2b2e28d1..8004940b3 100755
|
|||||||
v["el2inel"] = d["evict_l2_ineligible"] // sint
|
v["el2inel"] = d["evict_l2_ineligible"] // sint
|
||||||
v["mtxmis"] = d["mutex_miss"] // sint
|
v["mtxmis"] = d["mutex_miss"] // sint
|
||||||
|
|
||||||
@@ -498,11 +498,11 @@ def calculate():
|
@@ -581,11 +581,11 @@ def calculate():
|
||||||
v["l2size"] = cur["l2_size"]
|
v["l2size"] = cur["l2_size"]
|
||||||
v["l2bytes"] = d["l2_read_bytes"] // sint
|
v["l2bytes"] = d["l2_read_bytes"] // sint
|
||||||
|
|
||||||
@@ -1,134 +0,0 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Valmiky Arquissandas <kayvlim@gmail.com>
|
|
||||||
Date: Fri, 8 Oct 2021 16:32:27 +0100
|
|
||||||
Subject: [PATCH] arcstat: Fix integer division with python3
|
|
||||||
|
|
||||||
The arcstat script requests compatibility with python2 and python3, but
|
|
||||||
PEP 238 modified the / operator and results in erroneous output when
|
|
||||||
run under python3.
|
|
||||||
|
|
||||||
This commit replaces instances of / with //, yielding the expected
|
|
||||||
result in both versions of Python.
|
|
||||||
|
|
||||||
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
|
|
||||||
Reviewed-by: John Kennedy <john.kennedy@delphix.com>
|
|
||||||
Reviewed-by: Ryan Moeller <ryan@ixsystems.com>
|
|
||||||
Signed-off-by: Valmiky Arquissandas <foss@kayvlim.com>
|
|
||||||
Closes #12603
|
|
||||||
(cherry picked from commit 2d02bba23d83ae8fede8d281edc255f01ccd28e9)
|
|
||||||
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
|
||||||
---
|
|
||||||
cmd/arcstat/arcstat.in | 66 +++++++++++++++++++++---------------------
|
|
||||||
1 file changed, 33 insertions(+), 33 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/cmd/arcstat/arcstat.in b/cmd/arcstat/arcstat.in
|
|
||||||
index 0128fd817..d2b2e28d1 100755
|
|
||||||
--- a/cmd/arcstat/arcstat.in
|
|
||||||
+++ b/cmd/arcstat/arcstat.in
|
|
||||||
@@ -441,73 +441,73 @@ def calculate():
|
|
||||||
|
|
||||||
v = dict()
|
|
||||||
v["time"] = time.strftime("%H:%M:%S", time.localtime())
|
|
||||||
- v["hits"] = d["hits"] / sint
|
|
||||||
- v["miss"] = d["misses"] / sint
|
|
||||||
+ v["hits"] = d["hits"] // sint
|
|
||||||
+ v["miss"] = d["misses"] // sint
|
|
||||||
v["read"] = v["hits"] + v["miss"]
|
|
||||||
- v["hit%"] = 100 * v["hits"] / v["read"] if v["read"] > 0 else 0
|
|
||||||
+ v["hit%"] = 100 * v["hits"] // v["read"] if v["read"] > 0 else 0
|
|
||||||
v["miss%"] = 100 - v["hit%"] if v["read"] > 0 else 0
|
|
||||||
|
|
||||||
- v["dhit"] = (d["demand_data_hits"] + d["demand_metadata_hits"]) / sint
|
|
||||||
- v["dmis"] = (d["demand_data_misses"] + d["demand_metadata_misses"]) / sint
|
|
||||||
+ v["dhit"] = (d["demand_data_hits"] + d["demand_metadata_hits"]) // sint
|
|
||||||
+ v["dmis"] = (d["demand_data_misses"] + d["demand_metadata_misses"]) // sint
|
|
||||||
|
|
||||||
v["dread"] = v["dhit"] + v["dmis"]
|
|
||||||
- v["dh%"] = 100 * v["dhit"] / v["dread"] if v["dread"] > 0 else 0
|
|
||||||
+ v["dh%"] = 100 * v["dhit"] // v["dread"] if v["dread"] > 0 else 0
|
|
||||||
v["dm%"] = 100 - v["dh%"] if v["dread"] > 0 else 0
|
|
||||||
|
|
||||||
- v["phit"] = (d["prefetch_data_hits"] + d["prefetch_metadata_hits"]) / sint
|
|
||||||
+ v["phit"] = (d["prefetch_data_hits"] + d["prefetch_metadata_hits"]) // sint
|
|
||||||
v["pmis"] = (d["prefetch_data_misses"] +
|
|
||||||
- d["prefetch_metadata_misses"]) / sint
|
|
||||||
+ d["prefetch_metadata_misses"]) // sint
|
|
||||||
|
|
||||||
v["pread"] = v["phit"] + v["pmis"]
|
|
||||||
- v["ph%"] = 100 * v["phit"] / v["pread"] if v["pread"] > 0 else 0
|
|
||||||
+ v["ph%"] = 100 * v["phit"] // v["pread"] if v["pread"] > 0 else 0
|
|
||||||
v["pm%"] = 100 - v["ph%"] if v["pread"] > 0 else 0
|
|
||||||
|
|
||||||
v["mhit"] = (d["prefetch_metadata_hits"] +
|
|
||||||
- d["demand_metadata_hits"]) / sint
|
|
||||||
+ d["demand_metadata_hits"]) // sint
|
|
||||||
v["mmis"] = (d["prefetch_metadata_misses"] +
|
|
||||||
- d["demand_metadata_misses"]) / sint
|
|
||||||
+ d["demand_metadata_misses"]) // sint
|
|
||||||
|
|
||||||
v["mread"] = v["mhit"] + v["mmis"]
|
|
||||||
- v["mh%"] = 100 * v["mhit"] / v["mread"] if v["mread"] > 0 else 0
|
|
||||||
+ v["mh%"] = 100 * v["mhit"] // v["mread"] if v["mread"] > 0 else 0
|
|
||||||
v["mm%"] = 100 - v["mh%"] if v["mread"] > 0 else 0
|
|
||||||
|
|
||||||
v["arcsz"] = cur["size"]
|
|
||||||
v["size"] = cur["size"]
|
|
||||||
v["c"] = cur["c"]
|
|
||||||
- v["mfu"] = d["mfu_hits"] / sint
|
|
||||||
- v["mru"] = d["mru_hits"] / sint
|
|
||||||
- v["mrug"] = d["mru_ghost_hits"] / sint
|
|
||||||
- v["mfug"] = d["mfu_ghost_hits"] / sint
|
|
||||||
- v["eskip"] = d["evict_skip"] / sint
|
|
||||||
- v["el2skip"] = d["evict_l2_skip"] / sint
|
|
||||||
- v["el2cach"] = d["evict_l2_cached"] / sint
|
|
||||||
- v["el2el"] = d["evict_l2_eligible"] / sint
|
|
||||||
- v["el2mfu"] = d["evict_l2_eligible_mfu"] / sint
|
|
||||||
- v["el2mru"] = d["evict_l2_eligible_mru"] / sint
|
|
||||||
- v["el2inel"] = d["evict_l2_ineligible"] / sint
|
|
||||||
- v["mtxmis"] = d["mutex_miss"] / sint
|
|
||||||
+ v["mfu"] = d["mfu_hits"] // sint
|
|
||||||
+ v["mru"] = d["mru_hits"] // sint
|
|
||||||
+ v["mrug"] = d["mru_ghost_hits"] // sint
|
|
||||||
+ v["mfug"] = d["mfu_ghost_hits"] // sint
|
|
||||||
+ v["eskip"] = d["evict_skip"] // sint
|
|
||||||
+ v["el2skip"] = d["evict_l2_skip"] // sint
|
|
||||||
+ v["el2cach"] = d["evict_l2_cached"] // sint
|
|
||||||
+ v["el2el"] = d["evict_l2_eligible"] // sint
|
|
||||||
+ v["el2mfu"] = d["evict_l2_eligible_mfu"] // sint
|
|
||||||
+ v["el2mru"] = d["evict_l2_eligible_mru"] // sint
|
|
||||||
+ v["el2inel"] = d["evict_l2_ineligible"] // sint
|
|
||||||
+ v["mtxmis"] = d["mutex_miss"] // sint
|
|
||||||
|
|
||||||
if l2exist:
|
|
||||||
- v["l2hits"] = d["l2_hits"] / sint
|
|
||||||
- v["l2miss"] = d["l2_misses"] / sint
|
|
||||||
+ v["l2hits"] = d["l2_hits"] // sint
|
|
||||||
+ v["l2miss"] = d["l2_misses"] // sint
|
|
||||||
v["l2read"] = v["l2hits"] + v["l2miss"]
|
|
||||||
- v["l2hit%"] = 100 * v["l2hits"] / v["l2read"] if v["l2read"] > 0 else 0
|
|
||||||
+ v["l2hit%"] = 100 * v["l2hits"] // v["l2read"] if v["l2read"] > 0 else 0
|
|
||||||
|
|
||||||
v["l2miss%"] = 100 - v["l2hit%"] if v["l2read"] > 0 else 0
|
|
||||||
v["l2asize"] = cur["l2_asize"]
|
|
||||||
v["l2size"] = cur["l2_size"]
|
|
||||||
- v["l2bytes"] = d["l2_read_bytes"] / sint
|
|
||||||
+ v["l2bytes"] = d["l2_read_bytes"] // sint
|
|
||||||
|
|
||||||
v["l2pref"] = cur["l2_prefetch_asize"]
|
|
||||||
v["l2mfu"] = cur["l2_mfu_asize"]
|
|
||||||
v["l2mru"] = cur["l2_mru_asize"]
|
|
||||||
v["l2data"] = cur["l2_bufc_data_asize"]
|
|
||||||
v["l2meta"] = cur["l2_bufc_metadata_asize"]
|
|
||||||
- v["l2pref%"] = 100 * v["l2pref"] / v["l2asize"]
|
|
||||||
- v["l2mfu%"] = 100 * v["l2mfu"] / v["l2asize"]
|
|
||||||
- v["l2mru%"] = 100 * v["l2mru"] / v["l2asize"]
|
|
||||||
- v["l2data%"] = 100 * v["l2data"] / v["l2asize"]
|
|
||||||
- v["l2meta%"] = 100 * v["l2meta"] / v["l2asize"]
|
|
||||||
+ v["l2pref%"] = 100 * v["l2pref"] // v["l2asize"]
|
|
||||||
+ v["l2mfu%"] = 100 * v["l2mfu"] // v["l2asize"]
|
|
||||||
+ v["l2mru%"] = 100 * v["l2mru"] // v["l2asize"]
|
|
||||||
+ v["l2data%"] = 100 * v["l2data"] // v["l2asize"]
|
|
||||||
+ v["l2meta%"] = 100 * v["l2meta"] // v["l2asize"]
|
|
||||||
|
|
||||||
v["grow"] = 0 if cur["arc_no_grow"] else 1
|
|
||||||
v["need"] = cur["arc_need_free"]
|
|
||||||
@@ -0,0 +1,76 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: siv0 <github@nomore.at>
|
||||||
|
Date: Tue, 31 Oct 2023 21:57:54 +0100
|
||||||
|
Subject: [PATCH] Fix nfs_truncate_shares without /etc/exports.d
|
||||||
|
|
||||||
|
Calling nfs_reset_shares on Linux prints a warning:
|
||||||
|
`failed to lock /etc/exports.d/zfs.exports.lock: No such file or
|
||||||
|
directory`
|
||||||
|
when /etc/exports.d does not exist. The directory gets created, when a
|
||||||
|
filesystem is actually exported through nfs_toggle_share and
|
||||||
|
nfs_init_share. The truncation of /etc/exports.d/zfs.exports happens
|
||||||
|
unconditionally when calling `zfs mount -a` (via zfs_do_mount and
|
||||||
|
share_mount in `cmd/zfs/zfs_main.c`).
|
||||||
|
|
||||||
|
Fixing the issue only in the Linux part, since the exports file on
|
||||||
|
freebsd is in `/etc/zfs/`, which seems present on 2 FreeBSD systems I
|
||||||
|
have access to (through `/etc/zfs/compatibility.d/`), while a Debian
|
||||||
|
box does not have the directory even if `/usr/sbin/exportfs` is
|
||||||
|
present through the `nfs-kernel-server` package.
|
||||||
|
|
||||||
|
The code for exports_available is copied from nfs_available above.
|
||||||
|
|
||||||
|
Fixes: ede037cda73675f42b1452187e8dd3438fafc220
|
||||||
|
("Make zfs-share service resilient to stale exports")
|
||||||
|
|
||||||
|
Reviewed-by: Brian Atkinson <batkinson@lanl.gov>
|
||||||
|
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
|
||||||
|
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
||||||
|
Closes #15369
|
||||||
|
Closes #15468
|
||||||
|
(cherry picked from commit 41e55b476bcfc90f1ad81c02c5375367fdace9e9)
|
||||||
|
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
||||||
|
---
|
||||||
|
lib/libshare/os/linux/nfs.c | 18 ++++++++++++++++++
|
||||||
|
1 file changed, 18 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/lib/libshare/os/linux/nfs.c b/lib/libshare/os/linux/nfs.c
|
||||||
|
index 004946b0c..3dce81840 100644
|
||||||
|
--- a/lib/libshare/os/linux/nfs.c
|
||||||
|
+++ b/lib/libshare/os/linux/nfs.c
|
||||||
|
@@ -47,6 +47,7 @@
|
||||||
|
|
||||||
|
|
||||||
|
static boolean_t nfs_available(void);
|
||||||
|
+static boolean_t exports_available(void);
|
||||||
|
|
||||||
|
typedef int (*nfs_shareopt_callback_t)(const char *opt, const char *value,
|
||||||
|
void *cookie);
|
||||||
|
@@ -539,6 +540,8 @@ nfs_commit_shares(void)
|
||||||
|
static void
|
||||||
|
nfs_truncate_shares(void)
|
||||||
|
{
|
||||||
|
+ if (!exports_available())
|
||||||
|
+ return;
|
||||||
|
nfs_reset_shares(ZFS_EXPORTS_LOCK, ZFS_EXPORTS_FILE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -566,3 +569,18 @@ nfs_available(void)
|
||||||
|
|
||||||
|
return (avail == 1);
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+static boolean_t
|
||||||
|
+exports_available(void)
|
||||||
|
+{
|
||||||
|
+ static int avail;
|
||||||
|
+
|
||||||
|
+ if (!avail) {
|
||||||
|
+ if (access(ZFS_EXPORTS_DIR, F_OK) != 0)
|
||||||
|
+ avail = -1;
|
||||||
|
+ else
|
||||||
|
+ avail = 1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return (avail == 1);
|
||||||
|
+}
|
||||||
+66
@@ -0,0 +1,66 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
||||||
|
Date: Sun, 12 Nov 2023 15:52:25 +0100
|
||||||
|
Subject: [PATCH] zpool status: tighten bounds for noalloc stat availabillity
|
||||||
|
|
||||||
|
When running zfs 2.2.0 userspace utilities with a kernel that still
|
||||||
|
has 2.1.13 modules zpool status adds `(non-allocating)` next to the
|
||||||
|
disk name of a single-disk pool.
|
||||||
|
|
||||||
|
The reason for this seems to be that the patch adding the `vs_pspace` field was
|
||||||
|
backported, but the one adding `vs_noalloc` was not.
|
||||||
|
|
||||||
|
Itself that is not a problem, but in 2.2 `noalloc` was added before `psspace`,
|
||||||
|
so the struct layout between 2.1.13 and 2.2.0 do NOT match anymore...
|
||||||
|
|
||||||
|
I.e., the struct looks like the following at the end for ZFS 2.1.x:
|
||||||
|
|
||||||
|
```
|
||||||
|
typedef struct vdev_stat {
|
||||||
|
hrtime_t vs_timestamp; /* time since vdev load */
|
||||||
|
// snip
|
||||||
|
uint64_t vs_logical_ashift; /* vdev_logical_ashift */
|
||||||
|
uint64_t vs_physical_ashift; /* vdev_physical_ashift */
|
||||||
|
uint64_t vs_pspace; /* physical capacity */
|
||||||
|
} vdev_stat_t;
|
||||||
|
```
|
||||||
|
|
||||||
|
And like the following on ZFS 2.2.x:
|
||||||
|
```
|
||||||
|
typedef struct vdev_stat {
|
||||||
|
hrtime_t vs_timestamp; /* time since vdev load */
|
||||||
|
// snip
|
||||||
|
uint64_t vs_logical_ashift; /* vdev_logical_ashift */
|
||||||
|
uint64_t vs_physical_ashift; /* vdev_physical_ashift */
|
||||||
|
uint64_t vs_noalloc; /* allocations halted? */
|
||||||
|
uint64_t vs_pspace; /* physical capacity */
|
||||||
|
} vdev_stat_t;
|
||||||
|
```
|
||||||
|
|
||||||
|
Resulting in 2.2.x user-space tooling interpreting the `vs_pspace` field from
|
||||||
|
the 2.1.x kernel module as `vs_noalloc` field.
|
||||||
|
|
||||||
|
For now, work-around that discrepancy by coupling the availability of
|
||||||
|
the vs_noalloc field with the one of the vs_pspace one, as when both
|
||||||
|
are returned from the module we can be sure that our struct layout
|
||||||
|
matches again.
|
||||||
|
|
||||||
|
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
||||||
|
---
|
||||||
|
cmd/zpool/zpool_main.c | 3 ++-
|
||||||
|
1 file changed, 2 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/cmd/zpool/zpool_main.c b/cmd/zpool/zpool_main.c
|
||||||
|
index 69bf9649a..fd42ce7c1 100644
|
||||||
|
--- a/cmd/zpool/zpool_main.c
|
||||||
|
+++ b/cmd/zpool/zpool_main.c
|
||||||
|
@@ -2616,7 +2616,8 @@ print_status_config(zpool_handle_t *zhp, status_cbdata_t *cb, const char *name,
|
||||||
|
|
||||||
|
if (vs->vs_scan_removing != 0) {
|
||||||
|
(void) printf(gettext(" (removing)"));
|
||||||
|
- } else if (VDEV_STAT_VALID(vs_noalloc, vsc) && vs->vs_noalloc != 0) {
|
||||||
|
+ } else if (VDEV_STAT_VALID(vs_pspace, vsc)
|
||||||
|
+ && VDEV_STAT_VALID(vs_noalloc, vsc) && vs->vs_noalloc != 0) {
|
||||||
|
(void) printf(gettext(" (non-allocating)"));
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +1,52 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Fabian=20Gr=C3=BCnbichler?= <f.gruenbichler@proxmox.com>
|
||||||
|
Date: Wed, 6 Mar 2024 10:39:06 +0100
|
||||||
|
Subject: [PATCH] udev: correctly handle partition #16 and later
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
If a zvol has more than 15 partitions, the minor device number exhausts
|
||||||
|
the slot count reserved for partitions next to the zvol itself. As a
|
||||||
|
result, the minor number cannot be used to determine the partition
|
||||||
|
number for the higher partition, and doing so results in wrong named
|
||||||
|
symlinks being generated by udev.
|
||||||
|
|
||||||
|
Since the partition number is encoded in the block device name anyway,
|
||||||
|
let's just extract it from there instead.
|
||||||
|
|
||||||
|
Fixes: #15904
|
||||||
|
|
||||||
|
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
|
||||||
|
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
||||||
|
---
|
||||||
|
udev/zvol_id.c | 9 +++++----
|
||||||
|
1 file changed, 5 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/udev/zvol_id.c b/udev/zvol_id.c
|
||||||
|
index 5960b9787..609349594 100644
|
||||||
|
--- a/udev/zvol_id.c
|
||||||
|
+++ b/udev/zvol_id.c
|
||||||
|
@@ -51,7 +51,7 @@ const char *__asan_default_options(void) {
|
||||||
|
int
|
||||||
|
main(int argc, const char *const *argv)
|
||||||
|
{
|
||||||
|
- if (argc != 2) {
|
||||||
|
+ if (argc != 2 || strncmp(argv[1], "/dev/zd", 7) != 0) {
|
||||||
|
fprintf(stderr, "usage: %s /dev/zdX\n", argv[0]);
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
@@ -72,9 +72,10 @@ main(int argc, const char *const *argv)
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
- unsigned int dev_part = minor(sb.st_rdev) % ZVOL_MINORS;
|
||||||
|
- if (dev_part != 0)
|
||||||
|
- sprintf(zvol_name + strlen(zvol_name), "-part%u", dev_part);
|
||||||
|
+ const char *dev_part = strrchr(dev_name, 'p');
|
||||||
|
+ if (dev_part != NULL) {
|
||||||
|
+ sprintf(zvol_name + strlen(zvol_name), "-part%s", dev_part + 1);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
for (size_t i = 0; i < strlen(zvol_name); ++i)
|
||||||
|
if (isblank(zvol_name[i]))
|
||||||
Vendored
+4
-2
@@ -6,5 +6,7 @@
|
|||||||
0006-dont-symlink-zed-scripts.patch
|
0006-dont-symlink-zed-scripts.patch
|
||||||
0007-Add-systemd-unit-for-importing-specific-pools.patch
|
0007-Add-systemd-unit-for-importing-specific-pools.patch
|
||||||
0008-Patch-move-manpage-arcstat-1-to-arcstat-8.patch
|
0008-Patch-move-manpage-arcstat-1-to-arcstat-8.patch
|
||||||
0009-arcstat-Fix-integer-division-with-python3.patch
|
0009-arc-stat-summary-guard-access-to-l2arc-MFU-MRU-stats.patch
|
||||||
0010-arc-stat-summary-guard-access-to-l2arc-MFU-MRU-stats.patch
|
0010-Fix-nfs_truncate_shares-without-etc-exports.d.patch
|
||||||
|
0011-zpool-status-tighten-bounds-for-noalloc-stat-availab.patch
|
||||||
|
0012-udev-correctly-handle-partition-16-and-later.patch
|
||||||
|
|||||||
Vendored
+2
-10
@@ -10,7 +10,7 @@ SPHINX_BUILD = $(shell dpkg -L python3-sphinx | grep -m 1 "/sphinx-build$$")
|
|||||||
export DEB_BUILD_MAINT_OPTIONS = hardening=+all
|
export DEB_BUILD_MAINT_OPTIONS = hardening=+all
|
||||||
|
|
||||||
%:
|
%:
|
||||||
dh $@ --with autoreconf,python3,sphinxdoc --parallel
|
dh $@ --with autoreconf,python3,sphinxdoc
|
||||||
|
|
||||||
adapt_meta_file:
|
adapt_meta_file:
|
||||||
@# Embed the downstream version in the module.
|
@# Embed the downstream version in the module.
|
||||||
@@ -60,10 +60,6 @@ override_dh_auto_install:
|
|||||||
@# Install the utilities.
|
@# Install the utilities.
|
||||||
$(MAKE) install DESTDIR='$(CURDIR)/debian/tmp'
|
$(MAKE) install DESTDIR='$(CURDIR)/debian/tmp'
|
||||||
|
|
||||||
# Use upstream's bash completion
|
|
||||||
install -D -t '$(CURDIR)/debian/tmp/usr/share/bash-completion/completions/' \
|
|
||||||
'$(CURDIR)/contrib/bash_completion.d/zfs'
|
|
||||||
|
|
||||||
# Move from bin_dir to /usr/sbin
|
# Move from bin_dir to /usr/sbin
|
||||||
# Remove suffix (.py) as per policy 10.4 - Scripts
|
# Remove suffix (.py) as per policy 10.4 - Scripts
|
||||||
# https://www.debian.org/doc/debian-policy/ch-files.html#s-scripts
|
# https://www.debian.org/doc/debian-policy/ch-files.html#s-scripts
|
||||||
@@ -83,7 +79,6 @@ override_dh_auto_install:
|
|||||||
|
|
||||||
chmod a-x '$(CURDIR)/debian/tmp/etc/zfs/zfs-functions'
|
chmod a-x '$(CURDIR)/debian/tmp/etc/zfs/zfs-functions'
|
||||||
chmod a-x '$(CURDIR)/debian/tmp/etc/default/zfs'
|
chmod a-x '$(CURDIR)/debian/tmp/etc/default/zfs'
|
||||||
chmod a-x '$(CURDIR)/debian/tmp/usr/share/bash-completion/completions/zfs'
|
|
||||||
|
|
||||||
override_dh_python3:
|
override_dh_python3:
|
||||||
dh_python3 -p python3-pyzfs
|
dh_python3 -p python3-pyzfs
|
||||||
@@ -91,9 +86,6 @@ override_dh_python3:
|
|||||||
override_dh_makeshlibs:
|
override_dh_makeshlibs:
|
||||||
dh_makeshlibs -a -V
|
dh_makeshlibs -a -V
|
||||||
|
|
||||||
override_dh_strip:
|
|
||||||
dh_strip --dbgsym-migration='zfs-dbg (<< 2.0.4~)'
|
|
||||||
|
|
||||||
override_dh_auto_clean:
|
override_dh_auto_clean:
|
||||||
find . -name .gitignore -delete
|
find . -name .gitignore -delete
|
||||||
rm -rf zfs-$(DEB_VERSION_UPSTREAM)
|
rm -rf zfs-$(DEB_VERSION_UPSTREAM)
|
||||||
@@ -101,7 +93,7 @@ override_dh_auto_clean:
|
|||||||
@if test -e META.orig; then mv META.orig META; fi
|
@if test -e META.orig; then mv META.orig META; fi
|
||||||
|
|
||||||
override_dh_install:
|
override_dh_install:
|
||||||
find debian/tmp/lib -name *.la -delete
|
find debian/tmp/lib -name '*.la' -delete
|
||||||
dh_install
|
dh_install
|
||||||
|
|
||||||
override_dh_missing:
|
override_dh_missing:
|
||||||
|
|||||||
+1
-1
@@ -60,7 +60,7 @@ do
|
|||||||
case "${ret}" in
|
case "${ret}" in
|
||||||
disable);;
|
disable);;
|
||||||
enable) trim_if_not_already_trimming "${pool}" ;;
|
enable) trim_if_not_already_trimming "${pool}" ;;
|
||||||
-|auto) pool_is_nvme_only "${pool}" && trim_if_not_already_trimming "${pool}" ;;
|
-|auto) if pool_is_nvme_only "${pool}"; then trim_if_not_already_trimming "${pool}"; fi ;;
|
||||||
*) cat > /dev/stderr <<EOF
|
*) cat > /dev/stderr <<EOF
|
||||||
$0: [WARNING] illegal value "${ret}" for property "${PROPERTY_NAME}" of ZFS dataset "${pool}".
|
$0: [WARNING] illegal value "${ret}" for property "${PROPERTY_NAME}" of ZFS dataset "${pool}".
|
||||||
$0: Acceptable choices for this property are: auto, enable, disable. The default is auto.
|
$0: Acceptable choices for this property are: auto, enable, disable. The default is auto.
|
||||||
|
|||||||
Vendored
+4
-7
@@ -3,11 +3,8 @@ command-in-sbin-has-manpage-in-incorrect-section
|
|||||||
arch-dep-package-has-big-usr-share
|
arch-dep-package-has-big-usr-share
|
||||||
manpage-without-executable
|
manpage-without-executable
|
||||||
national-encoding *usr/share/zfs/zfs-tests/tests/functional/channel_program/lua_core/tst.lib_table.lua*
|
national-encoding *usr/share/zfs/zfs-tests/tests/functional/channel_program/lua_core/tst.lib_table.lua*
|
||||||
executable-not-elf-or-script *usr/share/zfs/zfs-tests/tests/functional/cli_root/zfs_jail/jail.conf*
|
executable-not-elf-or-script *usr/share/zfs/zfs-tests/tests/functional/cli_root/*
|
||||||
package-contains-documentation-outside-usr-share-doc *usr/share/zfs/zfs-tests/*
|
package-contains-documentation-outside-usr-share-doc *usr/share/zfs/zfs-tests/*
|
||||||
script-not-executable *usr/share/zfs/common.sh*
|
script-not-executable [usr/share/zfs/common.sh]
|
||||||
script-not-executable *usr/share/zfs/zfs-tests/include/default.cfg*
|
script-not-executable [usr/share/zfs/zfs-tests/include/default.cfg]
|
||||||
script-not-executable *usr/share/zfs/zfs-tests/tests/functional/cli_root/zfs_wait/zfs_wait.kshlib*
|
script-not-executable [usr/share/zfs/zfs-tests/tests/functional/*]
|
||||||
script-not-executable *usr/share/zfs/zfs-tests/tests/functional/cli_root/zpool_wait/zpool_wait.kshlib*
|
|
||||||
script-not-executable *usr/share/zfs/zfs-tests/tests/functional/l2arc/l2arc.cfg*
|
|
||||||
script-not-executable *usr/share/zfs/zfs-tests/tests/functional/redacted_send/redacted.kshlib*
|
|
||||||
|
|||||||
Vendored
+9
-2
@@ -14,6 +14,9 @@ lib/systemd/system/zfs-scrub-monthly@.timer
|
|||||||
lib/systemd/system/zfs-scrub-weekly@.timer
|
lib/systemd/system/zfs-scrub-weekly@.timer
|
||||||
lib/systemd/system/zfs-scrub@.service
|
lib/systemd/system/zfs-scrub@.service
|
||||||
lib/systemd/system/zfs-share.service
|
lib/systemd/system/zfs-share.service
|
||||||
|
lib/systemd/system/zfs-trim-monthly@.timer
|
||||||
|
lib/systemd/system/zfs-trim-weekly@.timer
|
||||||
|
lib/systemd/system/zfs-trim@.service
|
||||||
lib/systemd/system/zfs-volume-wait.service
|
lib/systemd/system/zfs-volume-wait.service
|
||||||
lib/systemd/system/zfs-volumes.target
|
lib/systemd/system/zfs-volumes.target
|
||||||
lib/systemd/system/zfs.target
|
lib/systemd/system/zfs.target
|
||||||
@@ -30,7 +33,9 @@ sbin/zpool
|
|||||||
sbin/zstream
|
sbin/zstream
|
||||||
sbin/zstreamdump
|
sbin/zstreamdump
|
||||||
usr/bin/zvol_wait
|
usr/bin/zvol_wait
|
||||||
|
usr/bin/zilstat
|
||||||
usr/lib/modules-load.d/ lib/
|
usr/lib/modules-load.d/ lib/
|
||||||
|
usr/lib/zfs-linux/zfs_prepare_disk
|
||||||
usr/lib/zfs-linux/zpool.d/
|
usr/lib/zfs-linux/zpool.d/
|
||||||
usr/lib/zfs-linux/zpool_influxdb
|
usr/lib/zfs-linux/zpool_influxdb
|
||||||
usr/sbin/arc_summary
|
usr/sbin/arc_summary
|
||||||
@@ -43,6 +48,7 @@ usr/share/man/man1/zvol_wait.1
|
|||||||
usr/share/man/man4/zfs.4
|
usr/share/man/man4/zfs.4
|
||||||
usr/share/man/man4/spl.4
|
usr/share/man/man4/spl.4
|
||||||
usr/share/man/man5/
|
usr/share/man/man5/
|
||||||
|
usr/share/man/man7/vdevprops.7
|
||||||
usr/share/man/man7/zfsconcepts.7
|
usr/share/man/man7/zfsconcepts.7
|
||||||
usr/share/man/man7/zfsprops.7
|
usr/share/man/man7/zfsprops.7
|
||||||
usr/share/man/man7/zpoolconcepts.7
|
usr/share/man/man7/zpoolconcepts.7
|
||||||
@@ -63,11 +69,11 @@ usr/share/man/man8/zfs-get.8
|
|||||||
usr/share/man/man8/zfs-groupspace.8
|
usr/share/man/man8/zfs-groupspace.8
|
||||||
usr/share/man/man8/zfs-hold.8
|
usr/share/man/man8/zfs-hold.8
|
||||||
usr/share/man/man8/zfs-inherit.8
|
usr/share/man/man8/zfs-inherit.8
|
||||||
usr/share/man/man8/zfs-jail.8
|
|
||||||
usr/share/man/man8/zfs-list.8
|
usr/share/man/man8/zfs-list.8
|
||||||
usr/share/man/man8/zfs-load-key.8
|
usr/share/man/man8/zfs-load-key.8
|
||||||
usr/share/man/man8/zfs-mount-generator.8
|
usr/share/man/man8/zfs-mount-generator.8
|
||||||
usr/share/man/man8/zfs-mount.8
|
usr/share/man/man8/zfs-mount.8
|
||||||
|
usr/share/man/man8/zfs_prepare_disk.8
|
||||||
usr/share/man/man8/zfs-program.8
|
usr/share/man/man8/zfs-program.8
|
||||||
usr/share/man/man8/zfs-project.8
|
usr/share/man/man8/zfs-project.8
|
||||||
usr/share/man/man8/zfs-projectspace.8
|
usr/share/man/man8/zfs-projectspace.8
|
||||||
@@ -83,9 +89,9 @@ usr/share/man/man8/zfs-set.8
|
|||||||
usr/share/man/man8/zfs-share.8
|
usr/share/man/man8/zfs-share.8
|
||||||
usr/share/man/man8/zfs-snapshot.8
|
usr/share/man/man8/zfs-snapshot.8
|
||||||
usr/share/man/man8/zfs-unallow.8
|
usr/share/man/man8/zfs-unallow.8
|
||||||
usr/share/man/man8/zfs-unjail.8
|
|
||||||
usr/share/man/man8/zfs-unload-key.8
|
usr/share/man/man8/zfs-unload-key.8
|
||||||
usr/share/man/man8/zfs-unmount.8
|
usr/share/man/man8/zfs-unmount.8
|
||||||
|
usr/share/man/man8/zfs-unzone.8
|
||||||
usr/share/man/man8/zfs-upgrade.8
|
usr/share/man/man8/zfs-upgrade.8
|
||||||
usr/share/man/man8/zfs-userspace.8
|
usr/share/man/man8/zfs-userspace.8
|
||||||
usr/share/man/man8/zfs-wait.8
|
usr/share/man/man8/zfs-wait.8
|
||||||
@@ -124,6 +130,7 @@ usr/share/man/man8/zpool-sync.8
|
|||||||
usr/share/man/man8/zpool-trim.8
|
usr/share/man/man8/zpool-trim.8
|
||||||
usr/share/man/man8/zpool-upgrade.8
|
usr/share/man/man8/zpool-upgrade.8
|
||||||
usr/share/man/man8/zpool-wait.8
|
usr/share/man/man8/zpool-wait.8
|
||||||
|
usr/share/man/man8/zfs-zone.8
|
||||||
usr/share/man/man8/zpool.8
|
usr/share/man/man8/zpool.8
|
||||||
usr/share/man/man8/zstream.8
|
usr/share/man/man8/zstream.8
|
||||||
usr/share/man/man8/zstreamdump.8
|
usr/share/man/man8/zstreamdump.8
|
||||||
|
|||||||
+1
-1
Submodule upstream updated: e25f9131d6...c883088df8
Reference in New Issue
Block a user