]> git.proxmox.com Git - zfsonlinux.git/commitdiff
rebase ZFS on top of debian/0.7.6-1
authorFabian Grünbichler <f.gruenbichler@proxmox.com>
Tue, 3 Apr 2018 12:08:19 +0000 (14:08 +0200)
committerFabian Grünbichler <f.gruenbichler@proxmox.com>
Tue, 3 Apr 2018 12:10:51 +0000 (14:10 +0200)
38 files changed:
zfs-debian
zfs-patches/0001-remove-DKMS-modules-and-dracut-build.patch
zfs-patches/0004-Fix-ARC-hit-rate.patch [deleted file]
zfs-patches/0004-always-load-ZFS-module-on-boot.patch [new file with mode: 0644]
zfs-patches/0005-always-load-ZFS-module-on-boot.patch [deleted file]
zfs-patches/0006-Use-sbin-openrc-run-for-openrc-init-scripts.patch [deleted file]
zfs-patches/0007-vdev_mirror-load-balancing-fixes.patch [deleted file]
zfs-patches/0008-Fix-zfs_ioc_pool_sync-should-not-use-fnvlist.patch [deleted file]
zfs-patches/0009-dmu_objset-release-bonus-buffer-in-failure-path.patch [deleted file]
zfs-patches/0010-Fix-bug-in-distclean-which-removes-needed-files.patch [deleted file]
zfs-patches/0011-Rewrite-of-function-fBytes-in-arc_summary.py.patch [deleted file]
zfs-patches/0012-Minor-code-cleanup-in-arc_summary.py.patch [deleted file]
zfs-patches/0013-Rewrite-fHits-in-arc_summary.py-with-SI-units.patch [deleted file]
zfs-patches/0014-Add-documentation-strings-to-arc_summary.py.patch [deleted file]
zfs-patches/0015-Sort-output-of-tunables-in-arc_summary.py.patch [deleted file]
zfs-patches/0016-Fix-arc_summary.py-d-crash-with-Python3.patch [deleted file]
zfs-patches/0017-Minor-code-cleanups-in-arc_python.py.patch [deleted file]
zfs-patches/0018-Fix-data-on-evict_skips-in-arc_summary.py.patch [deleted file]
zfs-patches/0019-Update-for-cppcheck-v1.80.patch [deleted file]
zfs-patches/0020-OpenZFS-8794-cstyle-generates-warnings-with-recent-p.patch [deleted file]
zfs-patches/0021-Handle-invalid-options-in-arc_summary.patch [deleted file]
zfs-patches/0022-Handle-broken-pipes-in-arc_summary.patch [deleted file]
zfs-patches/0023-Call-commit-callbacks-from-the-tail-of-the-list.patch [deleted file]
zfs-patches/0024-Fix-zpool-add-handling-of-nested-interior-VDEVs.patch [deleted file]
zfs-patches/0025-zhack-fix-getopt-return-type.patch [deleted file]
zfs-patches/0026-Revert-raidz_map-and-_col-structure-types.patch [deleted file]
zfs-patches/0027-Use-zap_count-instead-of-cached-z_size-for-unlink.patch [deleted file]
zfs-patches/0028-Fix-incompatibility-with-Reiser4-patched-kernels.patch [deleted file]
zfs-patches/0029-Remove-l2arc_nocompress-from-zfs-module-parameters-5.patch [deleted file]
zfs-patches/0030-Fix-shellcheck-v0.4.6-warnings.patch [deleted file]
zfs-patches/0031-Fix-Debian-packaging-on-ARMv7-ARM64.patch [deleted file]
zfs-patches/0032-OpenZFS-8835-Speculative-prefetch-in-ZFS-not-working.patch [deleted file]
zfs-patches/0033-Cleanup-zloop-working-directory-after-each-pass.patch [deleted file]
zfs-patches/0034-Extend-zloop.sh-for-automated-testing.patch [deleted file]
zfs-patches/0035-Fix-zfs-receive-o-when-used-with-e-d.patch [deleted file]
zfs-patches/0036-Tag-zfs-0.7.6.patch [deleted file]
zfs-patches/0037-Revert-cherry-pick-fix-distclean-which-removes-neede.patch [deleted file]
zfs-patches/series

index 5601d8209e1588bed0aaecd98e914cc5b649b6bf..751356d3540d352bb6d27a20d584a020db1b4e1d 160000 (submodule)
@@ -1 +1 @@
-Subproject commit 5601d8209e1588bed0aaecd98e914cc5b649b6bf
+Subproject commit 751356d3540d352bb6d27a20d584a020db1b4e1d
index db413ac0dad0ef4a5dc6f0f7ab0bd9168d5ab10c..fad365eed325fc523278cd70787954bbe79b1c87 100644 (file)
@@ -8,33 +8,35 @@ Content-Transfer-Encoding: 8bit
 
 Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
 ---
- debian/control.in    |  37 +++---------------
+ debian/control.in    |  41 ++------------------
  debian/control       |   1 -
  debian/not-installed |   1 +
  debian/rules         | 105 +--------------------------------------------------
- 4 files changed, 8 insertions(+), 136 deletions(-)
+ 4 files changed, 6 insertions(+), 142 deletions(-)
 
 diff --git a/debian/control.in b/debian/control.in
-index b3ef99870..8e69b6e37 100644
+index aef8cac2e..3cc15a05b 100644
 --- a/debian/control.in
 +++ b/debian/control.in
-@@ -8,7 +8,6 @@ Uploaders: Aron Xu <aron@debian.org>,
- Build-Depends: dh-autoreconf,
-                autotools-dev,
+@@ -9,7 +9,6 @@ Build-Depends: autotools-dev,
                 debhelper (>= 10.2),
+                dh-autoreconf,
+                dh-python,
 -               dkms (>> 2.1.1.2-5),
+                libattr1-dev,
+                libblkid-dev,
                 libselinux1-dev,
-                libtool,
-                lsb-release,
-@@ -84,25 +83,11 @@ Description: OpenZFS pool library for Linux
+@@ -86,27 +85,10 @@ Description: OpenZFS pool library for Linux
   .
   This zpool library provides support for managing zpools.
  
 -Package: zfs-dkms
 -Architecture: all
--Pre-Depends: spl-dkms (>= ${source:Upstream-Version}), spl-dkms (<<${source:Upstream-Version}.)
+-Pre-Depends: spl-dkms (<<${source:Upstream-Version}.),
+-             spl-dkms (>= ${source:Upstream-Version})
 -Depends: dkms (>> 2.1.1.2-5), lsb-release, ${misc:Depends}
--Recommends: zfsutils-linux (>= ${binary:Version}), zfs-zed
+-Recommends: zfs-zed, zfsutils-linux (>= ${binary:Version}),
+-              @LINUX_COMPAT@
 -Provides: zfs-modules
 -Description: OpenZFS filesystem kernel modules for Linux
 - The Z file system is a pooled filesystem designed for maximum data
@@ -46,20 +48,22 @@ index b3ef99870..8e69b6e37 100644
 -
  Package: zfs-initramfs
  Architecture: all
- Depends: initramfs-tools,
-  busybox-initramfs | busybox-static | busybox,
-- zfs-modules | zfs-dkms, zfsutils-linux (>= ${binary:Version}),
-+ zfsutils-linux (>= ${binary:Version}),
-  ${misc:Depends}
+ Depends: busybox-initramfs | busybox-static | busybox,
+          initramfs-tools,
+-         zfs-modules | zfs-dkms,
+          zfsutils-linux (>= ${binary:Version}),
+          ${misc:Depends}
  Description: OpenZFS root filesystem capabilities for Linux - initramfs
-  The Z file system is a pooled filesystem designed for maximum data
-@@ -112,24 +97,12 @@ Description: OpenZFS root filesystem capabilities for Linux - initramfs
+@@ -117,29 +99,14 @@ Description: OpenZFS root filesystem capabilities for Linux - initramfs
   This package adds OpenZFS to the system initramfs with a hook
   for the initramfs-tools infrastructure.
  
 -Package: zfs-dracut
 -Architecture: all
--Depends: dracut, zfs-modules | zfs-dkms, zfsutils-linux (>= ${binary:Version}), ${misc:Depends}
+-Depends: dracut,
+-         zfs-modules | zfs-dkms,
+-         zfsutils-linux (>= ${binary:Version}),
+-         ${misc:Depends}
 -Description: OpenZFS root filesystem capabilities for Linux - dracut
 - The Z file system is a pooled filesystem designed for maximum data
 - integrity, supporting data snapshots, multiple copies, and data
@@ -71,45 +75,47 @@ index b3ef99870..8e69b6e37 100644
  Package: zfsutils-linux
  Section: contrib/admin
  Architecture: linux-any
- Depends: ${misc:Depends}, ${shlibs:Depends}, ${python3:Depends}, python3
+ Depends: python3, ${misc:Depends}, ${python3:Depends}, ${shlibs:Depends}
 -Recommends: lsb-base, zfs-modules | zfs-dkms, zfs-zed
--Breaks: zfs-dkms (>> ${binary:Version}), zfs-dkms (<< ${binary:Version})
--Suggests: nfs-kernel-server, samba-common-bin (>= 3.0.23), zfs-initramfs | zfs-dracut
+-Breaks: zfs-dkms (<< ${binary:Version}), zfs-dkms (>> ${binary:Version})
 +Recommends: lsb-base, zfs-zed
-+Suggests: nfs-kernel-server, samba-common-bin (>= 3.0.23), zfs-initramfs
+ Suggests: nfs-kernel-server,
+           samba-common-bin (>= 3.0.23),
+-          zfs-initramfs | zfs-dracut
++          zfs-initramfs
  Conflicts: zfs, zfs-fuse, zutils
  Provides: zfsutils
  Description: command-line tools to manage OpenZFS filesystems
-@@ -143,7 +116,7 @@ Description: command-line tools to manage OpenZFS filesystems
+@@ -153,8 +120,7 @@ Description: command-line tools to manage OpenZFS filesystems
  Package: zfs-zed
  Section: contrib/admin
  Architecture: linux-any
--Depends: ${misc:Depends}, ${shlibs:Depends}, zfs-modules | zfs-dkms, zfsutils-linux (>= ${binary:Version})
-+Depends: ${misc:Depends}, ${shlibs:Depends}, zfsutils-linux (>= ${binary:Version})
+-Depends: zfs-modules | zfs-dkms,
+-         zfsutils-linux (>= ${binary:Version}),
++Depends: zfsutils-linux (>= ${binary:Version}),
+          ${misc:Depends},
+          ${shlibs:Depends}
  Description: OpenZFS Event Daemon
-  The Z file system is a pooled filesystem designed for maximum data
-  integrity, supporting data snapshots, multiple copies, and data
-@@ -154,7 +127,7 @@ Description: OpenZFS Event Daemon
- Package: zfs-test
- Section: contrib/admin
- Architecture: linux-any
--Depends: ${misc:Depends}, ${shlibs:Depends}, zfs-modules | zfs-dkms, zfsutils-linux (>=${binary:Version}), parted, lsscsi, mdadm, bc, ksh, fio, acl, sudo, sysstat, python
-+Depends: ${misc:Depends}, ${shlibs:Depends}, zfsutils-linux (>=${binary:Version}), parted, lsscsi, mdadm, bc, ksh, fio, acl, sudo, sysstat, python
- Breaks: zfsutils-linux (<= 0.6.5.11-1)
- Replaces: zfsutils-linux (<= 0.6.5.11-1)
- Description: OpenZFS test infrastructure an support scripts
+@@ -177,7 +143,6 @@ Depends: acl,
+          python,
+          sudo,
+          sysstat,
+-         zfs-modules | zfs-dkms,
+          zfsutils-linux (>=${binary:Version}),
+          ${misc:Depends},
+          ${shlibs:Depends}
 diff --git a/debian/control b/debian/control
-index b3ef99870..816403e44 100644
+index 3cf6fb649..51cfe6a64 100644
 --- a/debian/control
 +++ b/debian/control
-@@ -8,7 +8,6 @@ Uploaders: Aron Xu <aron@debian.org>,
- Build-Depends: dh-autoreconf,
-                autotools-dev,
+@@ -9,7 +9,6 @@ Build-Depends: autotools-dev,
                 debhelper (>= 10.2),
+                dh-autoreconf,
+                dh-python,
 -               dkms (>> 2.1.1.2-5),
+                libattr1-dev,
+                libblkid-dev,
                 libselinux1-dev,
-                libtool,
-                lsb-release,
 diff --git a/debian/not-installed b/debian/not-installed
 index f54fe7310..16b1cef6c 100644
 --- a/debian/not-installed
@@ -120,7 +126,7 @@ index f54fe7310..16b1cef6c 100644
  etc/zfs/vdev_id.conf.sas_switch.example
 +usr/lib/dracut
 diff --git a/debian/rules b/debian/rules
-index f445b58c5..d71926b33 100755
+index cc47a74a1..a5c37c81d 100755
 --- a/debian/rules
 +++ b/debian/rules
 @@ -5,9 +5,6 @@ include /usr/share/dpkg/default.mk
@@ -156,7 +162,7 @@ index f445b58c5..d71926b33 100755
 +      dh $@ --with autoreconf,python3,systemd --parallel
  
  override_dh_auto_configure:
-       @cp debian/control.in debian/control
+       sed "s/@LINUX_COMPAT@/linux-libc-dev \(< $(shell debian/get_next.sh)\)/" debian/control.in > debian/control
 @@ -73,36 +65,6 @@ override_dh_auto_install:
        $(INSTALL) -d '$(CURDIR)/debian/tmp/usr/sbin/'
        mv '$(CURDIR)/debian/tmp/sbin/zed' '$(CURDIR)/debian/tmp/usr/sbin/zed'
diff --git a/zfs-patches/0004-Fix-ARC-hit-rate.patch b/zfs-patches/0004-Fix-ARC-hit-rate.patch
deleted file mode 100644 (file)
index 271a65d..0000000
+++ /dev/null
@@ -1,151 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Brian Behlendorf <behlendorf1@llnl.gov>
-Date: Mon, 8 Jan 2018 09:52:36 -0800
-Subject: [PATCH] Fix ARC hit rate
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-When the compressed ARC feature was added in commit d3c2ae1
-the method of reference counting in the ARC was modified.  As
-part of this accounting change the arc_buf_add_ref() function
-was removed entirely.
-
-This would have be fine but the arc_buf_add_ref() function
-served a second undocumented purpose of updating the ARC access
-information when taking a hold on a dbuf.  Without this logic
-in place a cached dbuf would not migrate its associated
-arc_buf_hdr_t to the MFU list.  This would negatively impact
-the ARC hit rate, particularly on systems with a small ARC.
-
-This change reinstates the missing call to arc_access() from
-dbuf_hold() by implementing a new arc_buf_access() function.
-
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Reviewed-by: Tony Hutter <hutter2@llnl.gov>
-Reviewed-by: Tim Chase <tim@chase2k.com>
-Reviewed by: George Wilson <george.wilson@delphix.com>
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Closes #6171
-Closes #6852
-Closes #6989
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- include/sys/arc.h |  1 +
- module/zfs/arc.c  | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++--
- module/zfs/dbuf.c |  4 +++-
- 3 files changed, 56 insertions(+), 3 deletions(-)
-
-diff --git a/include/sys/arc.h b/include/sys/arc.h
-index 66f37cf71..1ea4937bd 100644
---- a/include/sys/arc.h
-+++ b/include/sys/arc.h
-@@ -221,6 +221,7 @@ void arc_buf_destroy(arc_buf_t *buf, void *tag);
- void arc_buf_info(arc_buf_t *buf, arc_buf_info_t *abi, int state_index);
- uint64_t arc_buf_size(arc_buf_t *buf);
- uint64_t arc_buf_lsize(arc_buf_t *buf);
-+void arc_buf_access(arc_buf_t *buf);
- void arc_release(arc_buf_t *buf, void *tag);
- int arc_released(arc_buf_t *buf);
- void arc_buf_sigsegv(int sig, siginfo_t *si, void *unused);
-diff --git a/module/zfs/arc.c b/module/zfs/arc.c
-index 2b0a78d4b..264e67735 100644
---- a/module/zfs/arc.c
-+++ b/module/zfs/arc.c
-@@ -429,9 +429,14 @@ typedef struct arc_stats {
-        * by multiple buffers.
-        */
-       kstat_named_t arcstat_mutex_miss;
-+      /*
-+       * Number of buffers skipped when updating the access state due to the
-+       * header having already been released after acquiring the hash lock.
-+       */
-+      kstat_named_t arcstat_access_skip;
-       /*
-        * Number of buffers skipped because they have I/O in progress, are
--       * indrect prefetch buffers that have not lived long enough, or are
-+       * indirect prefetch buffers that have not lived long enough, or are
-        * not from the spa we're trying to evict from.
-        */
-       kstat_named_t arcstat_evict_skip;
-@@ -667,6 +672,7 @@ static arc_stats_t arc_stats = {
-       { "mfu_ghost_hits",             KSTAT_DATA_UINT64 },
-       { "deleted",                    KSTAT_DATA_UINT64 },
-       { "mutex_miss",                 KSTAT_DATA_UINT64 },
-+      { "access_skip",                KSTAT_DATA_UINT64 },
-       { "evict_skip",                 KSTAT_DATA_UINT64 },
-       { "evict_not_enough",           KSTAT_DATA_UINT64 },
-       { "evict_l2_cached",            KSTAT_DATA_UINT64 },
-@@ -4926,7 +4932,51 @@ arc_access(arc_buf_hdr_t *hdr, kmutex_t *hash_lock)
-       }
- }
--/* a generic arc_done_func_t which you can use */
-+/*
-+ * This routine is called by dbuf_hold() to update the arc_access() state
-+ * which otherwise would be skipped for entries in the dbuf cache.
-+ */
-+void
-+arc_buf_access(arc_buf_t *buf)
-+{
-+      mutex_enter(&buf->b_evict_lock);
-+      arc_buf_hdr_t *hdr = buf->b_hdr;
-+
-+      /*
-+       * Avoid taking the hash_lock when possible as an optimization.
-+       * The header must be checked again under the hash_lock in order
-+       * to handle the case where it is concurrently being released.
-+       */
-+      if (hdr->b_l1hdr.b_state == arc_anon || HDR_EMPTY(hdr)) {
-+              mutex_exit(&buf->b_evict_lock);
-+              return;
-+      }
-+
-+      kmutex_t *hash_lock = HDR_LOCK(hdr);
-+      mutex_enter(hash_lock);
-+
-+      if (hdr->b_l1hdr.b_state == arc_anon || HDR_EMPTY(hdr)) {
-+              mutex_exit(hash_lock);
-+              mutex_exit(&buf->b_evict_lock);
-+              ARCSTAT_BUMP(arcstat_access_skip);
-+              return;
-+      }
-+
-+      mutex_exit(&buf->b_evict_lock);
-+
-+      ASSERT(hdr->b_l1hdr.b_state == arc_mru ||
-+          hdr->b_l1hdr.b_state == arc_mfu);
-+
-+      DTRACE_PROBE1(arc__hit, arc_buf_hdr_t *, hdr);
-+      arc_access(hdr, hash_lock);
-+      mutex_exit(hash_lock);
-+
-+      ARCSTAT_BUMP(arcstat_hits);
-+      ARCSTAT_CONDSTAT(!HDR_PREFETCH(hdr), demand, prefetch,
-+          !HDR_ISTYPE_METADATA(hdr), data, metadata, hits);
-+}
-+
-+/* a generic arc_read_done_func_t which you can use */
- /* ARGSUSED */
- void
- arc_bcopy_func(zio_t *zio, arc_buf_t *buf, void *arg)
-diff --git a/module/zfs/dbuf.c b/module/zfs/dbuf.c
-index 60f52d294..4ee121f5a 100644
---- a/module/zfs/dbuf.c
-+++ b/module/zfs/dbuf.c
-@@ -2719,8 +2719,10 @@ __dbuf_hold_impl(struct dbuf_hold_impl_data *dh)
-               return (SET_ERROR(ENOENT));
-       }
--      if (dh->dh_db->db_buf != NULL)
-+      if (dh->dh_db->db_buf != NULL) {
-+              arc_buf_access(dh->dh_db->db_buf);
-               ASSERT3P(dh->dh_db->db.db_data, ==, dh->dh_db->db_buf->b_data);
-+      }
-       ASSERT(dh->dh_db->db_buf == NULL || arc_referenced(dh->dh_db->db_buf));
--- 
-2.14.2
-
diff --git a/zfs-patches/0004-always-load-ZFS-module-on-boot.patch b/zfs-patches/0004-always-load-ZFS-module-on-boot.patch
new file mode 100644 (file)
index 0000000..8ed5779
--- /dev/null
@@ -0,0 +1,30 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Fabian=20Gr=C3=BCnbichler?= <f.gruenbichler@proxmox.com>
+Date: Fri, 19 Jan 2018 12:13:46 +0100
+Subject: [PATCH] always load ZFS module on boot
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+since zfs-import-scan.service is disabled by default, and
+zfs-import-cache.service only gets started if a cache file exists, this
+is needed for zfs-mount, zfs-share and zfs-zed services in case ZFS is
+not actually used.
+
+Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
+---
+ etc/modules-load.d/zfs.conf.in | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/etc/modules-load.d/zfs.conf.in b/etc/modules-load.d/zfs.conf.in
+index 8b41baa30..59b058c9a 100644
+--- a/etc/modules-load.d/zfs.conf.in
++++ b/etc/modules-load.d/zfs.conf.in
+@@ -1,3 +1,3 @@
+ # Always load kernel modules at boot.  The default behavior is to load the
+ # kernel modules in the zfs-import-*.service or when blkid(8) detects a pool.
+-#zfs
++zfs
+-- 
+2.14.2
+
diff --git a/zfs-patches/0005-always-load-ZFS-module-on-boot.patch b/zfs-patches/0005-always-load-ZFS-module-on-boot.patch
deleted file mode 100644 (file)
index 8ed5779..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: =?UTF-8?q?Fabian=20Gr=C3=BCnbichler?= <f.gruenbichler@proxmox.com>
-Date: Fri, 19 Jan 2018 12:13:46 +0100
-Subject: [PATCH] always load ZFS module on boot
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-since zfs-import-scan.service is disabled by default, and
-zfs-import-cache.service only gets started if a cache file exists, this
-is needed for zfs-mount, zfs-share and zfs-zed services in case ZFS is
-not actually used.
-
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- etc/modules-load.d/zfs.conf.in | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-diff --git a/etc/modules-load.d/zfs.conf.in b/etc/modules-load.d/zfs.conf.in
-index 8b41baa30..59b058c9a 100644
---- a/etc/modules-load.d/zfs.conf.in
-+++ b/etc/modules-load.d/zfs.conf.in
-@@ -1,3 +1,3 @@
- # Always load kernel modules at boot.  The default behavior is to load the
- # kernel modules in the zfs-import-*.service or when blkid(8) detects a pool.
--#zfs
-+zfs
--- 
-2.14.2
-
diff --git a/zfs-patches/0006-Use-sbin-openrc-run-for-openrc-init-scripts.patch b/zfs-patches/0006-Use-sbin-openrc-run-for-openrc-init-scripts.patch
deleted file mode 100644 (file)
index 4f37a7a..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: BtbN <btbn@btbn.de>
-Date: Thu, 17 Aug 2017 00:51:51 +0200
-Subject: [PATCH] Use /sbin/openrc-run for openrc init scripts
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Using /sbin/runscript is deprecated and throws a QA warning
-when still used in init scripts.
-
-Reviewed-by: bunder2015 <omfgbunder@gmail.com>
-Signed-off-by: BtbN <btbn@btbn.de>
-Closes #6519
-(cherry picked from commit 6116bbd7446f06d913415bdecb208a78b31db0af)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- etc/init.d/Makefile.am | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-diff --git a/etc/init.d/Makefile.am b/etc/init.d/Makefile.am
-index 247db0aba..93432386a 100644
---- a/etc/init.d/Makefile.am
-+++ b/etc/init.d/Makefile.am
-@@ -22,7 +22,7 @@ $(init_SCRIPTS) $(initconf_SCRIPTS) $(initcommon_SCRIPTS):%:%.in
-               NFS_SRV=nfs; \
-         fi; \
-         if [ -e /sbin/openrc-run ]; then \
--              SHELL=/sbin/runscript; \
-+              SHELL=/sbin/openrc-run; \
-         else \
-               SHELL=/bin/sh; \
-         fi; \
--- 
-2.14.2
-
diff --git a/zfs-patches/0007-vdev_mirror-load-balancing-fixes.patch b/zfs-patches/0007-vdev_mirror-load-balancing-fixes.patch
deleted file mode 100644 (file)
index 57dd6c4..0000000
+++ /dev/null
@@ -1,209 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Gvozden Neskovic <neskovic@gmail.com>
-Date: Fri, 4 Aug 2017 11:29:56 +0200
-Subject: [PATCH] vdev_mirror: load balancing fixes
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-vdev_queue:
-- Track the last position of each vdev, including the io size,
-  in order to detect linear access of the following zio.
-- Remove duplicate `vq_lastoffset`
-
-vdev_mirror:
-- Correctly calculate the zio offset (signedness issue)
-- Deprecate `vdev_queue_register_lastoffset()`
-- Add `VDEV_LABEL_START_SIZE` to zio offset of leaf vdevs
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Signed-off-by: Gvozden Neskovic <neskovic@gmail.com>
-Closes #6461
-(cherry picked from commit 06acbbc429bfe7197e5fc3a49acfeef5c37b64c8)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- include/sys/vdev.h       |  3 +--
- include/sys/vdev_impl.h  |  1 -
- module/zfs/vdev_mirror.c | 36 ++++++++++++++++--------------------
- module/zfs/vdev_queue.c  | 21 +++++++--------------
- 4 files changed, 24 insertions(+), 37 deletions(-)
-
-diff --git a/include/sys/vdev.h b/include/sys/vdev.h
-index 7157ef43f..473d2691c 100644
---- a/include/sys/vdev.h
-+++ b/include/sys/vdev.h
-@@ -125,8 +125,7 @@ extern zio_t *vdev_queue_io(zio_t *zio);
- extern void vdev_queue_io_done(zio_t *zio);
- extern int vdev_queue_length(vdev_t *vd);
--extern uint64_t vdev_queue_lastoffset(vdev_t *vd);
--extern void vdev_queue_register_lastoffset(vdev_t *vd, zio_t *zio);
-+extern uint64_t vdev_queue_last_offset(vdev_t *vd);
- extern void vdev_config_dirty(vdev_t *vd);
- extern void vdev_config_clean(vdev_t *vd);
-diff --git a/include/sys/vdev_impl.h b/include/sys/vdev_impl.h
-index 7c5e54b08..4c2e3cd2e 100644
---- a/include/sys/vdev_impl.h
-+++ b/include/sys/vdev_impl.h
-@@ -127,7 +127,6 @@ struct vdev_queue {
-       hrtime_t        vq_io_delta_ts;
-       zio_t           vq_io_search; /* used as local for stack reduction */
-       kmutex_t        vq_lock;
--      uint64_t        vq_lastoffset;
- };
- /*
-diff --git a/module/zfs/vdev_mirror.c b/module/zfs/vdev_mirror.c
-index 0439e4b46..d230b4db4 100644
---- a/module/zfs/vdev_mirror.c
-+++ b/module/zfs/vdev_mirror.c
-@@ -116,7 +116,8 @@ static const zio_vsd_ops_t vdev_mirror_vsd_ops = {
- static int
- vdev_mirror_load(mirror_map_t *mm, vdev_t *vd, uint64_t zio_offset)
- {
--      uint64_t lastoffset;
-+      uint64_t last_offset;
-+      int64_t offset_diff;
-       int load;
-       /* All DVAs have equal weight at the root. */
-@@ -129,13 +130,17 @@ vdev_mirror_load(mirror_map_t *mm, vdev_t *vd, uint64_t zio_offset)
-        * worse overall when resilvering with compared to without.
-        */
-+      /* Fix zio_offset for leaf vdevs */
-+      if (vd->vdev_ops->vdev_op_leaf)
-+              zio_offset += VDEV_LABEL_START_SIZE;
-+
-       /* Standard load based on pending queue length. */
-       load = vdev_queue_length(vd);
--      lastoffset = vdev_queue_lastoffset(vd);
-+      last_offset = vdev_queue_last_offset(vd);
-       if (vd->vdev_nonrot) {
-               /* Non-rotating media. */
--              if (lastoffset == zio_offset)
-+              if (last_offset == zio_offset)
-                       return (load + zfs_vdev_mirror_non_rotating_inc);
-               /*
-@@ -148,16 +153,16 @@ vdev_mirror_load(mirror_map_t *mm, vdev_t *vd, uint64_t zio_offset)
-       }
-       /* Rotating media I/O's which directly follow the last I/O. */
--      if (lastoffset == zio_offset)
-+      if (last_offset == zio_offset)
-               return (load + zfs_vdev_mirror_rotating_inc);
-       /*
-        * Apply half the seek increment to I/O's within seek offset
--       * of the last I/O queued to this vdev as they should incur less
-+       * of the last I/O issued to this vdev as they should incur less
-        * of a seek increment.
-        */
--      if (ABS(lastoffset - zio_offset) <
--          zfs_vdev_mirror_rotating_seek_offset)
-+      offset_diff = (int64_t)(last_offset - zio_offset);
-+      if (ABS(offset_diff) < zfs_vdev_mirror_rotating_seek_offset)
-               return (load + (zfs_vdev_mirror_rotating_seek_inc / 2));
-       /* Apply the full seek increment to all other I/O's. */
-@@ -382,29 +387,20 @@ vdev_mirror_child_select(zio_t *zio)
-               mm->mm_preferred_cnt++;
-       }
--      if (mm->mm_preferred_cnt == 1) {
--              vdev_queue_register_lastoffset(
--                  mm->mm_child[mm->mm_preferred[0]].mc_vd, zio);
-+      if (mm->mm_preferred_cnt == 1)
-               return (mm->mm_preferred[0]);
--      }
--      if (mm->mm_preferred_cnt > 1) {
--              int c = vdev_mirror_preferred_child_randomize(zio);
--              vdev_queue_register_lastoffset(mm->mm_child[c].mc_vd, zio);
--              return (c);
--      }
-+      if (mm->mm_preferred_cnt > 1)
-+              return (vdev_mirror_preferred_child_randomize(zio));
-       /*
-        * Every device is either missing or has this txg in its DTL.
-        * Look for any child we haven't already tried before giving up.
-        */
-       for (c = 0; c < mm->mm_children; c++) {
--              if (!mm->mm_child[c].mc_tried) {
--                      vdev_queue_register_lastoffset(mm->mm_child[c].mc_vd,
--                          zio);
-+              if (!mm->mm_child[c].mc_tried)
-                       return (c);
--              }
-       }
-       /*
-diff --git a/module/zfs/vdev_queue.c b/module/zfs/vdev_queue.c
-index 6b3e87291..40cba340a 100644
---- a/module/zfs/vdev_queue.c
-+++ b/module/zfs/vdev_queue.c
-@@ -393,7 +393,7 @@ vdev_queue_init(vdev_t *vd)
-                   sizeof (zio_t), offsetof(struct zio, io_queue_node));
-       }
--      vq->vq_lastoffset = 0;
-+      vq->vq_last_offset = 0;
- }
- void
-@@ -699,9 +699,8 @@ again:
-        */
-       tree = vdev_queue_class_tree(vq, p);
-       vq->vq_io_search.io_timestamp = 0;
--      vq->vq_io_search.io_offset = vq->vq_last_offset + 1;
--      VERIFY3P(avl_find(tree, &vq->vq_io_search,
--          &idx), ==, NULL);
-+      vq->vq_io_search.io_offset = vq->vq_last_offset - 1;
-+      VERIFY3P(avl_find(tree, &vq->vq_io_search, &idx), ==, NULL);
-       zio = avl_nearest(tree, idx, AVL_AFTER);
-       if (zio == NULL)
-               zio = avl_first(tree);
-@@ -728,7 +727,7 @@ again:
-       }
-       vdev_queue_pending_add(vq, zio);
--      vq->vq_last_offset = zio->io_offset;
-+      vq->vq_last_offset = zio->io_offset + zio->io_size;
-       return (zio);
- }
-@@ -806,7 +805,7 @@ vdev_queue_io_done(zio_t *zio)
- }
- /*
-- * As these three methods are only used for load calculations we're not
-+ * As these two methods are only used for load calculations we're not
-  * concerned if we get an incorrect value on 32bit platforms due to lack of
-  * vq_lock mutex use here, instead we prefer to keep it lock free for
-  * performance.
-@@ -818,15 +817,9 @@ vdev_queue_length(vdev_t *vd)
- }
- uint64_t
--vdev_queue_lastoffset(vdev_t *vd)
-+vdev_queue_last_offset(vdev_t *vd)
- {
--      return (vd->vdev_queue.vq_lastoffset);
--}
--
--void
--vdev_queue_register_lastoffset(vdev_t *vd, zio_t *zio)
--{
--      vd->vdev_queue.vq_lastoffset = zio->io_offset + zio->io_size;
-+      return (vd->vdev_queue.vq_last_offset);
- }
- #if defined(_KERNEL) && defined(HAVE_SPL)
--- 
-2.14.2
-
diff --git a/zfs-patches/0008-Fix-zfs_ioc_pool_sync-should-not-use-fnvlist.patch b/zfs-patches/0008-Fix-zfs_ioc_pool_sync-should-not-use-fnvlist.patch
deleted file mode 100644 (file)
index 0bd8036..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Chunwei Chen <tuxoko@gmail.com>
-Date: Mon, 21 Aug 2017 13:11:11 -0700
-Subject: [PATCH] Fix zfs_ioc_pool_sync should not use fnvlist
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Use fnvlist on user input would allow user to easily panic zfs.
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Reviewed-by: Alek Pinchuk <apinchuk@datto.com>
-Signed-off-by: Chunwei Chen <david.chen@osnexus.com>
-Closes #6529
-(cherry picked from commit 7192ec7942f233e267bf631b433eb2414dc5f332)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- module/zfs/zfs_ioctl.c | 12 +++++++++---
- 1 file changed, 9 insertions(+), 3 deletions(-)
-
-diff --git a/module/zfs/zfs_ioctl.c b/module/zfs/zfs_ioctl.c
-index d195eded7..f4f509a7e 100644
---- a/module/zfs/zfs_ioctl.c
-+++ b/module/zfs/zfs_ioctl.c
-@@ -5901,20 +5901,26 @@ static int
- zfs_ioc_pool_sync(const char *pool, nvlist_t *innvl, nvlist_t *onvl)
- {
-       int err;
--      boolean_t force;
-+      boolean_t force = B_FALSE;
-       spa_t *spa;
-       if ((err = spa_open(pool, &spa, FTAG)) != 0)
-               return (err);
--      force = fnvlist_lookup_boolean_value(innvl, "force");
-+      if (innvl) {
-+              if (nvlist_lookup_boolean_value(innvl, "force", &force) != 0) {
-+                      err = SET_ERROR(EINVAL);
-+                      goto out;
-+              }
-+      }
-+
-       if (force) {
-               spa_config_enter(spa, SCL_CONFIG, FTAG, RW_WRITER);
-               vdev_config_dirty(spa->spa_root_vdev);
-               spa_config_exit(spa, SCL_CONFIG, FTAG);
-       }
-       txg_wait_synced(spa_get_dsl(spa), 0);
--
-+out:
-       spa_close(spa, FTAG);
-       return (err);
--- 
-2.14.2
-
diff --git a/zfs-patches/0009-dmu_objset-release-bonus-buffer-in-failure-path.patch b/zfs-patches/0009-dmu_objset-release-bonus-buffer-in-failure-path.patch
deleted file mode 100644 (file)
index dabada3..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Gvozden Neskovic <neskovic@gmail.com>
-Date: Wed, 30 Aug 2017 21:09:18 +0200
-Subject: [PATCH] dmu_objset: release bonus buffer in failure path
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Reported by kmemleak during testing of a new patch:
-
-```
-unreferenced object 0xffff9f1c12e38800 (size 1024):
-  comm "z_upgrade", pid 17842, jiffies 4296870904 (age 8746.268s)
-  backtrace:
-    kmemleak_alloc+0x7a/0x100
-    __kmalloc_node+0x26c/0x510
-    range_tree_create+0x39/0xa0 [zfs]
-    dmu_zfetch_init+0x73/0xe0 [zfs]
-    dnode_create+0x12c/0x3b0 [zfs]
-    dnode_hold_impl+0x1096/0x1130 [zfs]
-    dnode_hold+0x23/0x30 [zfs]
-    dmu_bonus_hold_impl+0x6b/0x370 [zfs]
-    dmu_bonus_hold+0x1e/0x30 [zfs]
-    dmu_objset_space_upgrade+0x114/0x310 [zfs]
-    dmu_objset_userobjspace_upgrade_cb+0xd8/0x150 [zfs]
-    dmu_objset_upgrade_task_cb+0x136/0x1e0 [zfs]
-    kthread+0x119/0x150
-```
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Gvozden Neskovic <neskovic@gmail.com>
-Closes #6575
-(cherry picked from commit a94447ddf3e8632e1e0476a3b1c985f41a0ae899)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- module/zfs/dmu_objset.c | 1 +
- 1 file changed, 1 insertion(+)
-
-diff --git a/module/zfs/dmu_objset.c b/module/zfs/dmu_objset.c
-index 9a7a6968d..3425d542f 100644
---- a/module/zfs/dmu_objset.c
-+++ b/module/zfs/dmu_objset.c
-@@ -1853,6 +1853,7 @@ dmu_objset_space_upgrade(objset_t *os)
-               dmu_tx_hold_bonus(tx, obj);
-               objerr = dmu_tx_assign(tx, TXG_WAIT);
-               if (objerr != 0) {
-+                      dmu_buf_rele(db, FTAG);
-                       dmu_tx_abort(tx);
-                       continue;
-               }
--- 
-2.14.2
-
diff --git a/zfs-patches/0010-Fix-bug-in-distclean-which-removes-needed-files.patch b/zfs-patches/0010-Fix-bug-in-distclean-which-removes-needed-files.patch
deleted file mode 100644 (file)
index 77ff67c..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: David Quigley <dpquigl@users.noreply.github.com>
-Date: Wed, 13 Sep 2017 12:45:04 -0600
-Subject: [PATCH] Fix bug in distclean which removes needed files
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Running distclean removes the following files because of an error
-in Makefile.am
-
-deleted:    tests/zfs-tests/include/commands.cfg
-deleted:    tests/zfs-tests/include/libtest.shlib
-deleted:    tests/zfs-tests/include/math.shlib
-deleted:    tests/zfs-tests/include/properties.shlib
-deleted:    tests/zfs-tests/include/zpool_script.shlib
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: David Quigley <david.quigley@intel.com>
-Closes #6636
-(cherry picked from commit 53e5890cff8b7c21d34e1142ae717ae79af54da6)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- tests/zfs-tests/include/Makefile.am | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-diff --git a/tests/zfs-tests/include/Makefile.am b/tests/zfs-tests/include/Makefile.am
-index 579e1356e..24633ccc3 100644
---- a/tests/zfs-tests/include/Makefile.am
-+++ b/tests/zfs-tests/include/Makefile.am
-@@ -10,4 +10,4 @@ dist_pkgdata_SCRIPTS = \
- EXTRA_DIST=default.cfg.in
- distclean-local::
--      -$(RM) $(dist_pkgdata_SCRIPTS)
-+      -$(RM) default.cfg
--- 
-2.14.2
-
diff --git a/zfs-patches/0011-Rewrite-of-function-fBytes-in-arc_summary.py.patch b/zfs-patches/0011-Rewrite-of-function-fBytes-in-arc_summary.py.patch
deleted file mode 100644 (file)
index c0fb96f..0000000
+++ /dev/null
@@ -1,98 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: "Scot W. Stevenson" <scot.stevenson@gmail.com>
-Date: Wed, 25 Oct 2017 08:29:02 +0200
-Subject: [PATCH] Rewrite of function fBytes() in arc_summary.py
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Replace if-elif-else construction with shorter loop;
-remove unused parameter "Decimal"; centralize format
-string; add function documentation string; conform to
-PEP8.
-
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Signed-off-by: Scot W. Stevenson <scot.stevenson@gmail.com>
-Closes #6784
-(cherry picked from commit 5dc25de668ce8c4e43ebd8c589202392297699b9)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/arc_summary/arc_summary.py | 60 ++++++++++++++++++++++--------------------
- 1 file changed, 31 insertions(+), 29 deletions(-)
-
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index 93918a08f..e19278cef 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -88,36 +88,38 @@ def div2():
-     sys.stdout.write("\n")
--def fBytes(Bytes=0, Decimal=2):
--    kbytes = (2 ** 10)
--    mbytes = (2 ** 20)
--    gbytes = (2 ** 30)
--    tbytes = (2 ** 40)
--    pbytes = (2 ** 50)
--    ebytes = (2 ** 60)
--    zbytes = (2 ** 70)
--    ybytes = (2 ** 80)
--
--    if Bytes >= ybytes:
--        return str("%0." + str(Decimal) + "f") % (Bytes / ybytes) + "\tYiB"
--    elif Bytes >= zbytes:
--        return str("%0." + str(Decimal) + "f") % (Bytes / zbytes) + "\tZiB"
--    elif Bytes >= ebytes:
--        return str("%0." + str(Decimal) + "f") % (Bytes / ebytes) + "\tEiB"
--    elif Bytes >= pbytes:
--        return str("%0." + str(Decimal) + "f") % (Bytes / pbytes) + "\tPiB"
--    elif Bytes >= tbytes:
--        return str("%0." + str(Decimal) + "f") % (Bytes / tbytes) + "\tTiB"
--    elif Bytes >= gbytes:
--        return str("%0." + str(Decimal) + "f") % (Bytes / gbytes) + "\tGiB"
--    elif Bytes >= mbytes:
--        return str("%0." + str(Decimal) + "f") % (Bytes / mbytes) + "\tMiB"
--    elif Bytes >= kbytes:
--        return str("%0." + str(Decimal) + "f") % (Bytes / kbytes) + "\tKiB"
--    elif Bytes == 0:
--        return str("%d" % 0) + "\tBytes"
-+def fBytes(b=0):
-+    """Return human-readable representation of a byte value in
-+    powers of 2 (eg "KiB" for "kibibytes", etc) to two decimal
-+    points. Values smaller than one KiB are returned without
-+    decimal points.
-+    """
-+
-+    prefixes = [
-+        [2**80, "YiB"],   # yobibytes (yotta)
-+        [2**70, "ZiB"],   # zebibytes (zetta)
-+        [2**60, "EiB"],   # exbibytes (exa)
-+        [2**50, "PiB"],   # pebibytes (peta)
-+        [2**40, "TiB"],   # tebibytes (tera)
-+        [2**30, "GiB"],   # gibibytes (giga)
-+        [2**20, "MiB"],   # mebibytes (mega)
-+        [2**10, "KiB"]]   # kibibytes (kilo)
-+
-+    if b >= 2**10:
-+
-+        for limit, unit in prefixes:
-+
-+            if b >= limit:
-+                value = b / limit
-+                break
-+
-+        result = "%0.2f\t%s" % (value, unit)
-+
-     else:
--        return str("%d" % Bytes) + "\tBytes"
-+
-+        result = "%d\tBytes" % b
-+
-+    return result
- def fHits(Hits=0, Decimal=2):
--- 
-2.14.2
-
diff --git a/zfs-patches/0012-Minor-code-cleanup-in-arc_summary.py.patch b/zfs-patches/0012-Minor-code-cleanup-in-arc_summary.py.patch
deleted file mode 100644 (file)
index 1ad2b55..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: "Scot W. Stevenson" <scot.stevenson@gmail.com>
-Date: Fri, 3 Nov 2017 23:43:53 +0100
-Subject: [PATCH] Minor code cleanup in arc_summary.py
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Simplify and inline single-use function div1(); inline twice-used
-function div2(); add function comment to zfs_header(); replace
-variable "unused" in get_Kstat() with "_" following convention.
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Scot W. Stevenson <scot.stevenson@gmail.com>
-Closes #6802
-(cherry picked from commit 03f638a8efe4f8e5901fc0e07fad5604e2550f22)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/arc_summary/arc_summary.py | 25 ++++++++-----------------
- 1 file changed, 8 insertions(+), 17 deletions(-)
-
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index e19278cef..6b818edc7 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -63,7 +63,7 @@ def get_Kstat():
-         del kstats[0:2]
-         for kstat in kstats:
-             kstat = kstat.strip()
--            name, unused, value = kstat.split()
-+            name, _, value = kstat.split()
-             Kstat[namespace + name] = D(value)
-     Kstat = {}
-@@ -77,17 +77,6 @@ def get_Kstat():
-     return Kstat
--def div1():
--    sys.stdout.write("\n")
--    for i in range(18):
--        sys.stdout.write("%s" % "----")
--    sys.stdout.write("\n")
--
--
--def div2():
--    sys.stdout.write("\n")
--
--
- def fBytes(b=0):
-     """Return human-readable representation of a byte value in
-     powers of 2 (eg "KiB" for "kibibytes", etc) to two decimal
-@@ -908,11 +897,13 @@ unSub = [
- def zfs_header():
--    daydate = time.strftime("%a %b %d %H:%M:%S %Y")
-+    """Print title string with date
-+    """
-+    daydate = time.strftime('%a %b %d %H:%M:%S %Y')
--    div1()
--    sys.stdout.write("ZFS Subsystem Report\t\t\t\t%s" % daydate)
--    div2()
-+    sys.stdout.write('\n'+'-'*72+'\n')
-+    sys.stdout.write('ZFS Subsystem Report\t\t\t\t%s' % daydate)
-+    sys.stdout.write('\n')
- def usage():
-@@ -975,7 +966,7 @@ def main():
-     zfs_header()
-     for page in pages:
-         page(Kstat)
--        div2()
-+        sys.stdout.write("\n")
- if __name__ == '__main__':
--- 
-2.14.2
-
diff --git a/zfs-patches/0013-Rewrite-fHits-in-arc_summary.py-with-SI-units.patch b/zfs-patches/0013-Rewrite-fHits-in-arc_summary.py-with-SI-units.patch
deleted file mode 100644 (file)
index 3064b16..0000000
+++ /dev/null
@@ -1,101 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: "Scot W. Stevenson" <scot.stevenson@gmail.com>
-Date: Sat, 4 Nov 2017 21:33:28 +0100
-Subject: [PATCH] Rewrite fHits() in arc_summary.py with SI units
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Complete rewrite of fHits(). Move units from non-standard English
-abbreviations to SI units, thereby avoiding confusion because of
-"long scale" and "short scale" numbers. Remove unused parameter
-"Decimal". Add function string. Aim to confirm to PEP8.
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Scot W. Stevenson <scot.stevenson@gmail.com>
-Closes #6815
-(cherry picked from commit 88e4e0d5dd1800add5191633d65797ce1c2eb4cf)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/arc_summary/arc_summary.py | 62 ++++++++++++++++++++++--------------------
- 1 file changed, 33 insertions(+), 29 deletions(-)
-
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index 6b818edc7..cbb7d20bc 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -111,36 +111,40 @@ def fBytes(b=0):
-     return result
--def fHits(Hits=0, Decimal=2):
--    khits = (10 ** 3)
--    mhits = (10 ** 6)
--    bhits = (10 ** 9)
--    thits = (10 ** 12)
--    qhits = (10 ** 15)
--    Qhits = (10 ** 18)
--    shits = (10 ** 21)
--    Shits = (10 ** 24)
--
--    if Hits >= Shits:
--        return str("%0." + str(Decimal) + "f") % (Hits / Shits) + "S"
--    elif Hits >= shits:
--        return str("%0." + str(Decimal) + "f") % (Hits / shits) + "s"
--    elif Hits >= Qhits:
--        return str("%0." + str(Decimal) + "f") % (Hits / Qhits) + "Q"
--    elif Hits >= qhits:
--        return str("%0." + str(Decimal) + "f") % (Hits / qhits) + "q"
--    elif Hits >= thits:
--        return str("%0." + str(Decimal) + "f") % (Hits / thits) + "t"
--    elif Hits >= bhits:
--        return str("%0." + str(Decimal) + "f") % (Hits / bhits) + "b"
--    elif Hits >= mhits:
--        return str("%0." + str(Decimal) + "f") % (Hits / mhits) + "m"
--    elif Hits >= khits:
--        return str("%0." + str(Decimal) + "f") % (Hits / khits) + "k"
--    elif Hits == 0:
--        return str("%d" % 0)
-+def fHits(hits=0):
-+    """Create a human-readable representation of the number of hits.
-+    The single-letter symbols used are SI to avoid the confusion caused
-+    by the different "short scale" and "long scale" representations in
-+    English, which use the same words for different values. See
-+    https://en.wikipedia.org/wiki/Names_of_large_numbers and
-+    https://physics.nist.gov/cuu/Units/prefixes.html
-+    """
-+
-+    numbers = [
-+            [10**24, 'Y'],  # yotta (septillion)
-+            [10**21, 'Z'],  # zetta (sextillion)
-+            [10**18, 'E'],  # exa   (quintrillion)
-+            [10**15, 'P'],  # peta  (quadrillion)
-+            [10**12, 'T'],  # tera  (trillion)
-+            [10**9, 'G'],   # giga  (billion)
-+            [10**6, 'M'],   # mega  (million)
-+            [10**3, 'k']]   # kilo  (thousand)
-+
-+    if hits >= 1000:
-+
-+        for limit, symbol in numbers:
-+
-+            if hits >= limit:
-+                value = hits/limit
-+                break
-+
-+        result = "%0.2f%s" % (value, symbol)
-+
-     else:
--        return str("%d" % Hits)
-+
-+        result = "%d" % hits
-+
-+    return result
- def fPerc(lVal=0, rVal=0, Decimal=2):
--- 
-2.14.2
-
diff --git a/zfs-patches/0014-Add-documentation-strings-to-arc_summary.py.patch b/zfs-patches/0014-Add-documentation-strings-to-arc_summary.py.patch
deleted file mode 100644 (file)
index 119ea60..0000000
+++ /dev/null
@@ -1,213 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: "Scot W. Stevenson" <scot.stevenson@gmail.com>
-Date: Sun, 5 Nov 2017 22:11:37 +0100
-Subject: [PATCH] Add documentation strings to arc_summary.py
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Include docstrings (PEP8, PEP257) for module and all functions.
-Separately, remove outdated section in comment at start of
-module. Separately, remove unused global constant "usetunable".
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Scot W. Stevenson <scot.stevenson@gmail.com>
-Closes #6818
-(cherry picked from commit 03955e348803a942048db8b32827f7ff6715c02e)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/arc_summary/arc_summary.py | 56 +++++++++++++++++++++++++++++++-----------
- 1 file changed, 42 insertions(+), 14 deletions(-)
-
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index cbb7d20bc..f4968fb6a 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -31,34 +31,37 @@
- #
- # If you are having troubles when using this script from cron(8) please try
- # adjusting your PATH before reporting problems.
--#
--# /usr/bin & /sbin
--#
--# Binaries used are:
--#
--# dc(1), kldstat(8), sed(1), sysctl(8) & vmstat(8)
--#
--# Binaries that I am working on phasing out are:
--#
--# dc(1) & sed(1)
-+"""Print statistics on the ZFS Adjustable Replacement Cache (ARC)
-+
-+Provides basic information on the ARC, its efficiency, the L2ARC (if present),
-+the Data Management Unit (DMU), Virtual Devices (VDEVs), and tunables. See the
-+in-source documentation and code at
-+https://github.com/zfsonlinux/zfs/blob/master/module/zfs/arc.c for details.
-+"""
- import sys
- import time
- import getopt
- import re
-+
- from os import listdir
- from subprocess import Popen, PIPE
- from decimal import Decimal as D
--
--usetunable = True
- show_tunable_descriptions = False
- alternate_tunable_layout = False
- kstat_pobj = re.compile("^([^:]+):\s+(.+)\s*$", flags=re.M)
- def get_Kstat():
-+    """Collect information on the ZFS subsystem from the /proc virtual
-+    file system. The name "kstat" is a holdover from the Solaris utility
-+    of the same name.
-+    """
-+
-     def load_proc_kstats(fn, namespace):
-+        """Collect information on a specific subsystem of the ARC"""
-+
-         kstats = [line.strip() for line in open(fn)]
-         del kstats[0:2]
-         for kstat in kstats:
-@@ -148,6 +151,8 @@ def fHits(hits=0):
- def fPerc(lVal=0, rVal=0, Decimal=2):
-+    """Calculate percentage value and return in human-readable format"""
-+
-     if rVal > 0:
-         return str("%0." + str(Decimal) + "f") % (100 * (lVal / rVal)) + "%"
-     else:
-@@ -155,6 +160,7 @@ def fPerc(lVal=0, rVal=0, Decimal=2):
- def get_arc_summary(Kstat):
-+    """Collect general data on the ARC"""
-     output = {}
-     memory_throttle_count = Kstat[
-@@ -256,6 +262,8 @@ def get_arc_summary(Kstat):
- def _arc_summary(Kstat):
-+    """Print information on the ARC"""
-+
-     # ARC Sizing
-     arc = get_arc_summary(Kstat)
-@@ -330,6 +338,8 @@ def _arc_summary(Kstat):
- def get_arc_efficiency(Kstat):
-+    """Collect information on the efficiency of the ARC"""
-+
-     output = {}
-     arc_hits = Kstat["kstat.zfs.misc.arcstats.hits"]
-@@ -453,6 +463,8 @@ def get_arc_efficiency(Kstat):
- def _arc_efficiency(Kstat):
-+    """Print information on the efficiency of the ARC"""
-+
-     arc = get_arc_efficiency(Kstat)
-     sys.stdout.write("ARC Total accesses:\t\t\t\t\t%s\n" %
-@@ -563,6 +575,8 @@ def _arc_efficiency(Kstat):
- def get_l2arc_summary(Kstat):
-+    """Collection information on the L2ARC"""
-+
-     output = {}
-     l2_abort_lowmem = Kstat["kstat.zfs.misc.arcstats.l2_abort_lowmem"]
-@@ -657,6 +671,7 @@ def get_l2arc_summary(Kstat):
- def _l2arc_summary(Kstat):
-+    """Print information on the L2ARC"""
-     arc = get_l2arc_summary(Kstat)
-@@ -741,6 +756,8 @@ def _l2arc_summary(Kstat):
- def get_dmu_summary(Kstat):
-+    """Collect information on the DMU"""
-+
-     output = {}
-     zfetch_hits = Kstat["kstat.zfs.misc.zfetchstats.hits"]
-@@ -766,6 +783,7 @@ def get_dmu_summary(Kstat):
- def _dmu_summary(Kstat):
-+    """Print information on the DMU"""
-     arc = get_dmu_summary(Kstat)
-@@ -787,6 +805,8 @@ def _dmu_summary(Kstat):
- def get_vdev_summary(Kstat):
-+    """Collect information on the VDEVs"""
-+
-     output = {}
-     vdev_cache_delegations = \
-@@ -817,6 +837,8 @@ def get_vdev_summary(Kstat):
- def _vdev_summary(Kstat):
-+    """Print information on the VDEVs"""
-+
-     arc = get_vdev_summary(Kstat)
-     if arc['vdev_cache_total'] > 0:
-@@ -836,6 +858,8 @@ def _vdev_summary(Kstat):
- def _tunable_summary(Kstat):
-+    """Print information on tunables"""
-+
-     global show_tunable_descriptions
-     global alternate_tunable_layout
-@@ -901,8 +925,8 @@ unSub = [
- def zfs_header():
--    """Print title string with date
--    """
-+    """Print title string with date"""
-+
-     daydate = time.strftime('%a %b %d %H:%M:%S %Y')
-     sys.stdout.write('\n'+'-'*72+'\n')
-@@ -911,6 +935,8 @@ def zfs_header():
- def usage():
-+    """Print usage information"""
-+
-     sys.stdout.write("Usage: arc_summary.py [-h] [-a] [-d] [-p PAGE]\n\n")
-     sys.stdout.write("\t -h, --help           : "
-                      "Print this help message and exit\n")
-@@ -931,6 +957,8 @@ def usage():
- def main():
-+    """Main function"""
-+
-     global show_tunable_descriptions
-     global alternate_tunable_layout
--- 
-2.14.2
-
diff --git a/zfs-patches/0015-Sort-output-of-tunables-in-arc_summary.py.patch b/zfs-patches/0015-Sort-output-of-tunables-in-arc_summary.py.patch
deleted file mode 100644 (file)
index c9c3481..0000000
+++ /dev/null
@@ -1,51 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: "Scot W. Stevenson" <scot.stevenson@gmail.com>
-Date: Tue, 7 Nov 2017 23:50:15 +0100
-Subject: [PATCH] Sort output of tunables in arc_summary.py
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Sort list of tunables printed by _tunable_summary()
-alphabetically
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Scot W. Stevenson <scot.stevenson@gmail.com>
-Closes #6828
-(cherry picked from commit 904c03672beeadf4c74b919f55b5f78be882b7f8)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/arc_summary/arc_summary.py | 12 ++++++++----
- 1 file changed, 8 insertions(+), 4 deletions(-)
-
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index f4968fb6a..4c513d63d 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -900,14 +900,18 @@ def _tunable_summary(Kstat):
-             sys.stderr.write("Tunable descriptions will be disabled.\n")
-     sys.stdout.write("ZFS Tunable:\n")
-+    names.sort()
-+
-+    if alternate_tunable_layout:
-+        format = "\t%s=%s\n"
-+    else:
-+        format = "\t%-50s%s\n"
-+
-     for name in names:
-+
-         if not name:
-             continue
--        format = "\t%-50s%s\n"
--        if alternate_tunable_layout:
--            format = "\t%s=%s\n"
--
-         if show_tunable_descriptions and name in descriptions:
-             sys.stdout.write("\t# %s\n" % descriptions[name])
--- 
-2.14.2
-
diff --git a/zfs-patches/0016-Fix-arc_summary.py-d-crash-with-Python3.patch b/zfs-patches/0016-Fix-arc_summary.py-d-crash-with-Python3.patch
deleted file mode 100644 (file)
index fdab618..0000000
+++ /dev/null
@@ -1,93 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: "Scot W. Stevenson" <scot.stevenson@gmail.com>
-Date: Sun, 12 Nov 2017 05:27:43 +0100
-Subject: [PATCH] Fix arc_summary.py -d crash with Python3
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Prevents arc_summary.py crashing when called with parameter -d or
-long form --description with Python3.
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Scot W. Stevenson <scot.stevenson@gmail.com>
-Closes #6849
-Closes #6850
-(cherry picked from commit 7de8fb33a206fabb06261c0a5b79656d66efb32f)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/arc_summary/arc_summary.py | 24 ++++++++++++++++--------
- 1 file changed, 16 insertions(+), 8 deletions(-)
-
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index 4c513d63d..ec0468ecc 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -39,12 +39,12 @@ in-source documentation and code at
- https://github.com/zfsonlinux/zfs/blob/master/module/zfs/arc.c for details.
- """
--import sys
--import time
- import getopt
-+import os
- import re
-+import sys
-+import time
--from os import listdir
- from subprocess import Popen, PIPE
- from decimal import Decimal as D
-@@ -858,12 +858,12 @@ def _vdev_summary(Kstat):
- def _tunable_summary(Kstat):
--    """Print information on tunables"""
-+    """Print information on tunables, including descriptions if requested"""
-     global show_tunable_descriptions
-     global alternate_tunable_layout
--    names = listdir("/sys/module/zfs/parameters/")
-+    names = os.listdir("/sys/module/zfs/parameters/")
-     values = {}
-     for name in names:
-@@ -874,13 +874,21 @@ def _tunable_summary(Kstat):
-     descriptions = {}
-     if show_tunable_descriptions:
-+
-+        command = ["/sbin/modinfo", "zfs", "-0"]
-+
-         try:
--            command = ["/sbin/modinfo", "zfs", "-0"]
-             p = Popen(command, stdin=PIPE, stdout=PIPE,
-                       stderr=PIPE, shell=False, close_fds=True)
-             p.wait()
--            description_list = p.communicate()[0].strip().split('\0')
-+            # By default, Python 2 returns a string as the first element of the
-+            # tuple from p.communicate(), while Python 3 returns bytes which
-+            # must be decoded first. The better way to do this would be with
-+            # subprocess.run() or at least .check_output(), but this fails on
-+            # CentOS 6 because of its old version of Python 2
-+            desc = bytes.decode(p.communicate()[0])
-+            description_list = desc.strip().split('\0')
-             if p.returncode == 0:
-                 for tunable in description_list:
-@@ -899,7 +907,7 @@ def _tunable_summary(Kstat):
-                              (sys.argv[0], command[0], e.strerror))
-             sys.stderr.write("Tunable descriptions will be disabled.\n")
--    sys.stdout.write("ZFS Tunable:\n")
-+    sys.stdout.write("ZFS Tunables:\n")
-     names.sort()
-     if alternate_tunable_layout:
--- 
-2.14.2
-
diff --git a/zfs-patches/0017-Minor-code-cleanups-in-arc_python.py.patch b/zfs-patches/0017-Minor-code-cleanups-in-arc_python.py.patch
deleted file mode 100644 (file)
index e85f7e7..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: "Scot W. Stevenson" <scot.stevenson@gmail.com>
-Date: Wed, 15 Nov 2017 19:28:11 +0100
-Subject: [PATCH] Minor code cleanups in arc_python.py
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Remove unused library re and associated variable kstat_pobj. Add note
-to documentation at start of program about required support for old
-versions of Python. Change variable "format" (which is a built-in
-function) to "fmt".
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Signed-off-by: Scot W. Stevenson <scot.stevenson@gmail.com>
-Closes #6869
-(cherry picked from commit d486dee89e54560536a759f3c5fb1eb8b07efc3f)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/arc_summary/arc_summary.py | 12 +++++++-----
- 1 file changed, 7 insertions(+), 5 deletions(-)
-
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index ec0468ecc..c9a2c5d03 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -31,6 +31,10 @@
- #
- # If you are having troubles when using this script from cron(8) please try
- # adjusting your PATH before reporting problems.
-+#
-+# Note some of this code uses older code (eg getopt instead of argparse,
-+# subprocess.Popen() instead of subprocess.run()) because we need to support
-+# some very old versions of Python.
- """Print statistics on the ZFS Adjustable Replacement Cache (ARC)
- Provides basic information on the ARC, its efficiency, the L2ARC (if present),
-@@ -41,7 +45,6 @@ https://github.com/zfsonlinux/zfs/blob/master/module/zfs/arc.c for details.
- import getopt
- import os
--import re
- import sys
- import time
-@@ -50,7 +53,6 @@ from decimal import Decimal as D
- show_tunable_descriptions = False
- alternate_tunable_layout = False
--kstat_pobj = re.compile("^([^:]+):\s+(.+)\s*$", flags=re.M)
- def get_Kstat():
-@@ -911,9 +913,9 @@ def _tunable_summary(Kstat):
-     names.sort()
-     if alternate_tunable_layout:
--        format = "\t%s=%s\n"
-+        fmt = "\t%s=%s\n"
-     else:
--        format = "\t%-50s%s\n"
-+        fmt = "\t%-50s%s\n"
-     for name in names:
-@@ -923,7 +925,7 @@ def _tunable_summary(Kstat):
-         if show_tunable_descriptions and name in descriptions:
-             sys.stdout.write("\t# %s\n" % descriptions[name])
--        sys.stdout.write(format % (name, values[name]))
-+        sys.stdout.write(fmt % (name, values[name]))
- unSub = [
--- 
-2.14.2
-
diff --git a/zfs-patches/0018-Fix-data-on-evict_skips-in-arc_summary.py.patch b/zfs-patches/0018-Fix-data-on-evict_skips-in-arc_summary.py.patch
deleted file mode 100644 (file)
index 1538bb5..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: "Scot W. Stevenson" <scot.stevenson@gmail.com>
-Date: Sat, 18 Nov 2017 23:07:04 +0100
-Subject: [PATCH] Fix data on evict_skips in arc_summary.py
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Display correct data from kstat arcstats for evict_skips,
-which is currently repeating the data from mutex_misses.
-Fixes #6882
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Scot W. Stevenson <scot.stevenson@gmail.com>
-Closes #6882
-Closes #6883
-(cherry picked from commit 7a8bef39838cdb9f996bf400add5a8583fe10e87)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/arc_summary/arc_summary.py | 5 +++--
- 1 file changed, 3 insertions(+), 2 deletions(-)
-
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index c9a2c5d03..5da81347c 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -179,12 +179,13 @@ def get_arc_summary(Kstat):
-     # ARC Misc.
-     deleted = Kstat["kstat.zfs.misc.arcstats.deleted"]
-     mutex_miss = Kstat["kstat.zfs.misc.arcstats.mutex_miss"]
-+    evict_skip = Kstat["kstat.zfs.misc.arcstats.evict_skip"]
-     # ARC Misc.
-     output["arc_misc"] = {}
-     output["arc_misc"]["deleted"] = fHits(deleted)
-     output["arc_misc"]['mutex_miss'] = fHits(mutex_miss)
--    output["arc_misc"]['evict_skips'] = fHits(mutex_miss)
-+    output["arc_misc"]['evict_skips'] = fHits(evict_skip)
-     # ARC Sizing
-     arc_size = Kstat["kstat.zfs.misc.arcstats.size"]
-@@ -281,7 +282,7 @@ def _arc_summary(Kstat):
-     sys.stdout.write("\tMutex Misses:\t\t\t\t%s\n" %
-                      arc['arc_misc']['mutex_miss'])
-     sys.stdout.write("\tEvict Skips:\t\t\t\t%s\n" %
--                     arc['arc_misc']['mutex_miss'])
-+                     arc['arc_misc']['evict_skips'])
-     sys.stdout.write("\n")
-     # ARC Sizing
--- 
-2.14.2
-
diff --git a/zfs-patches/0019-Update-for-cppcheck-v1.80.patch b/zfs-patches/0019-Update-for-cppcheck-v1.80.patch
deleted file mode 100644 (file)
index ad332dd..0000000
+++ /dev/null
@@ -1,280 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Brian Behlendorf <behlendorf1@llnl.gov>
-Date: Sat, 18 Nov 2017 14:08:00 -0800
-Subject: [PATCH] Update for cppcheck v1.80
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Resolve new warnings and errors from cppcheck v1.80.
-
-* [lib/libshare/libshare.c:543]: (warning)
-  Possible null pointer dereference: protocol
-* [lib/libzfs/libzfs_dataset.c:2323]: (warning)
-  Possible null pointer dereference: srctype
-* [lib/libzfs/libzfs_import.c:318]: (error)
-  Uninitialized variable: link
-* [module/zfs/abd.c:353]: (error) Uninitialized variable: sg
-* [module/zfs/abd.c:353]: (error) Uninitialized variable: i
-* [module/zfs/abd.c:385]: (error) Uninitialized variable: sg
-* [module/zfs/abd.c:385]: (error) Uninitialized variable: i
-* [module/zfs/abd.c:553]: (error) Uninitialized variable: i
-* [module/zfs/abd.c:553]: (error) Uninitialized variable: sg
-* [module/zfs/abd.c:763]: (error) Uninitialized variable: i
-* [module/zfs/abd.c:763]: (error) Uninitialized variable: sg
-* [module/zfs/abd.c:305]: (error) Uninitialized variable: tmp_page
-* [module/zfs/zpl_xattr.c:342]: (warning)
-   Possible null pointer dereference: value
-* [module/zfs/zvol.c:208]: (error) Uninitialized variable: p
-
-Convert the following suppression to inline.
-
-* [module/zfs/zfs_vnops.c:840]: (error)
-  Possible null pointer dereference: aiov
-
-Exclude HAVE_UIO_ZEROCOPY and HAVE_DNLC from analysis since
-these macro's will never be defined until this functionality
-is implemented.
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Closes #6879
-(cherry picked from commit aebc5df418cb52cc2ec9fa6c9c147ca3b048bc49)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- Makefile.am                 |  6 +++---
- lib/libshare/libshare.c     | 37 ++++---------------------------------
- lib/libzfs/libzfs_dataset.c |  4 +++-
- lib/libzfs/libzfs_import.c  |  2 +-
- module/zfs/abd.c            | 18 +++++++++---------
- module/zfs/zfs_vnops.c      |  1 +
- module/zfs/zpl_xattr.c      |  2 +-
- module/zfs/zvol.c           |  2 +-
- 8 files changed, 23 insertions(+), 49 deletions(-)
-
-diff --git a/Makefile.am b/Makefile.am
-index e46ac2dbe..508d3f40e 100644
---- a/Makefile.am
-+++ b/Makefile.am
-@@ -65,10 +65,10 @@ lint: cppcheck paxcheck
- cppcheck:
-       @if type cppcheck > /dev/null 2>&1; then \
--              cppcheck --quiet --force --error-exitcode=2 \
-+              cppcheck --quiet --force --error-exitcode=2 --inline-suppr \
-                       --suppressions-list=.github/suppressions.txt \
--                      -UHAVE_SSE2 -UHAVE_AVX512F \
--                      ${top_srcdir}; \
-+                      -UHAVE_SSE2 -UHAVE_AVX512F -UHAVE_UIO_ZEROCOPY \
-+                      -UHAVE_DNLC ${top_srcdir}; \
-       fi
- paxcheck:
-diff --git a/lib/libshare/libshare.c b/lib/libshare/libshare.c
-index aa565ca82..022df016f 100644
---- a/lib/libshare/libshare.c
-+++ b/lib/libshare/libshare.c
-@@ -493,20 +493,10 @@ int
- sa_enable_share(sa_share_t share, char *protocol)
- {
-       sa_share_impl_t impl_share = (sa_share_impl_t)share;
--      int rc, ret;
--      boolean_t found_protocol;
-+      int rc, ret = SA_OK;
-+      boolean_t found_protocol = B_FALSE;
-       sa_fstype_t *fstype;
--#ifdef DEBUG
--      fprintf(stderr, "sa_enable_share: share->sharepath=%s, protocol=%s\n",
--          impl_share->sharepath, protocol);
--#endif
--
--      assert(impl_share->handle != NULL);
--
--      ret = SA_OK;
--      found_protocol = B_FALSE;
--
-       fstype = fstypes;
-       while (fstype != NULL) {
-               if (protocol == NULL || strcmp(fstype->name, protocol) == 0) {
-@@ -534,18 +524,10 @@ int
- sa_disable_share(sa_share_t share, char *protocol)
- {
-       sa_share_impl_t impl_share = (sa_share_impl_t)share;
--      int rc, ret;
--      boolean_t found_protocol;
-+      int rc, ret = SA_OK;
-+      boolean_t found_protocol = B_FALSE;
-       sa_fstype_t *fstype;
--#ifdef DEBUG
--      fprintf(stderr, "sa_disable_share: share->sharepath=%s, protocol=%s\n",
--          impl_share->sharepath, protocol);
--#endif
--
--      ret = SA_OK;
--      found_protocol = B_FALSE;
--
-       fstype = fstypes;
-       while (fstype != NULL) {
-               if (protocol == NULL || strcmp(fstype->name, protocol) == 0) {
-@@ -696,11 +678,6 @@ sa_parse_legacy_options(sa_group_t group, char *options, char *proto)
- {
-       sa_fstype_t *fstype;
--#ifdef DEBUG
--      fprintf(stderr, "sa_parse_legacy_options: options=%s, proto=%s\n",
--          options, proto);
--#endif
--
-       fstype = fstypes;
-       while (fstype != NULL) {
-               if (strcmp(fstype->name, proto) != 0) {
-@@ -787,12 +764,6 @@ sa_zfs_process_share(sa_handle_t handle, sa_group_t group, sa_share_t share,
-       sa_handle_impl_t impl_handle = (sa_handle_impl_t)handle;
-       sa_share_impl_t impl_share = (sa_share_impl_t)share;
--#ifdef DEBUG
--      fprintf(stderr, "sa_zfs_process_share: mountpoint=%s, proto=%s, "
--          "shareopts=%s, sourcestr=%s, dataset=%s\n", mountpoint, proto,
--          shareopts, sourcestr, dataset);
--#endif
--
-       return (process_share(impl_handle, impl_share, mountpoint, NULL,
-           proto, shareopts, NULL, dataset, B_FALSE));
- }
-diff --git a/lib/libzfs/libzfs_dataset.c b/lib/libzfs/libzfs_dataset.c
-index d6e85024d..b65dbc826 100644
---- a/lib/libzfs/libzfs_dataset.c
-+++ b/lib/libzfs/libzfs_dataset.c
-@@ -2244,8 +2244,10 @@ static void
- get_source(zfs_handle_t *zhp, zprop_source_t *srctype, char *source,
-     char *statbuf, size_t statlen)
- {
--      if (statbuf == NULL || *srctype == ZPROP_SRC_TEMPORARY)
-+      if (statbuf == NULL ||
-+          srctype == NULL || *srctype == ZPROP_SRC_TEMPORARY) {
-               return;
-+      }
-       if (source == NULL) {
-               *srctype = ZPROP_SRC_NONE;
-diff --git a/lib/libzfs/libzfs_import.c b/lib/libzfs/libzfs_import.c
-index 8b5222475..39c067293 100644
---- a/lib/libzfs/libzfs_import.c
-+++ b/lib/libzfs/libzfs_import.c
-@@ -309,7 +309,7 @@ zpool_label_disk_wait(char *path, int timeout_ms)
-               dev = udev_device_new_from_subsystem_sysname(udev,
-                   "block", sysname);
-               if ((dev != NULL) && udev_device_is_ready(dev)) {
--                      struct udev_list_entry *links, *link;
-+                      struct udev_list_entry *links, *link = NULL;
-                       ret = 0;
-                       links = udev_device_get_devlinks_list_entry(dev);
-diff --git a/module/zfs/abd.c b/module/zfs/abd.c
-index 765ac7fb7..138b041c8 100644
---- a/module/zfs/abd.c
-+++ b/module/zfs/abd.c
-@@ -250,7 +250,7 @@ abd_alloc_pages(abd_t *abd, size_t size)
-       struct list_head pages;
-       struct sg_table table;
-       struct scatterlist *sg;
--      struct page *page, *tmp_page;
-+      struct page *page, *tmp_page = NULL;
-       gfp_t gfp = __GFP_NOWARN | GFP_NOIO;
-       gfp_t gfp_comp = (gfp | __GFP_NORETRY | __GFP_COMP) & ~__GFP_RECLAIM;
-       int max_order = MIN(zfs_abd_scatter_max_order, MAX_ORDER - 1);
-@@ -334,12 +334,12 @@ abd_alloc_pages(abd_t *abd, size_t size)
- static void
- abd_alloc_pages(abd_t *abd, size_t size)
- {
--      struct scatterlist *sg;
-+      struct scatterlist *sg = NULL;
-       struct sg_table table;
-       struct page *page;
-       gfp_t gfp = __GFP_NOWARN | GFP_NOIO;
-       int nr_pages = abd_chunkcnt_for_bytes(size);
--      int i;
-+      int i = 0;
-       while (sg_alloc_table(&table, nr_pages, gfp)) {
-               ABDSTAT_BUMP(abdstat_scatter_sg_table_retry);
-@@ -370,11 +370,11 @@ abd_alloc_pages(abd_t *abd, size_t size)
- static void
- abd_free_pages(abd_t *abd)
- {
--      struct scatterlist *sg;
-+      struct scatterlist *sg = NULL;
-       struct sg_table table;
-       struct page *page;
-       int nr_pages = ABD_SCATTER(abd).abd_nents;
--      int order, i;
-+      int order, i = 0;
-       if (abd->abd_flags & ABD_FLAG_MULTI_ZONE)
-               ABDSTAT_BUMPDOWN(abdstat_scatter_page_multi_zone);
-@@ -543,8 +543,8 @@ abd_verify(abd_t *abd)
-               ASSERT3P(abd->abd_u.abd_linear.abd_buf, !=, NULL);
-       } else {
-               size_t n;
--              int i;
--              struct scatterlist *sg;
-+              int i = 0;
-+              struct scatterlist *sg = NULL;
-               ASSERT3U(ABD_SCATTER(abd).abd_nents, >, 0);
-               ASSERT3U(ABD_SCATTER(abd).abd_offset, <,
-@@ -749,8 +749,8 @@ abd_get_offset_impl(abd_t *sabd, size_t off, size_t size)
-               abd->abd_u.abd_linear.abd_buf =
-                   (char *)sabd->abd_u.abd_linear.abd_buf + off;
-       } else {
--              int i;
--              struct scatterlist *sg;
-+              int i = 0;
-+              struct scatterlist *sg = NULL;
-               size_t new_offset = sabd->abd_u.abd_scatter.abd_offset + off;
-               abd = abd_alloc_struct();
-diff --git a/module/zfs/zfs_vnops.c b/module/zfs/zfs_vnops.c
-index 6a1dab5c9..6f6ce79db 100644
---- a/module/zfs/zfs_vnops.c
-+++ b/module/zfs/zfs_vnops.c
-@@ -836,6 +836,7 @@ zfs_write(struct inode *ip, uio_t *uio, int ioflag, cred_t *cr)
-                           aiov->iov_base != abuf->b_data)) {
-                               ASSERT(xuio);
-                               dmu_write(zfsvfs->z_os, zp->z_id, woff,
-+                                  /* cppcheck-suppress nullPointer */
-                                   aiov->iov_len, aiov->iov_base, tx);
-                               dmu_return_arcbuf(abuf);
-                               xuio_stat_wbuf_copied();
-diff --git a/module/zfs/zpl_xattr.c b/module/zfs/zpl_xattr.c
-index 0c626b122..ebb6e7be2 100644
---- a/module/zfs/zpl_xattr.c
-+++ b/module/zfs/zpl_xattr.c
-@@ -333,7 +333,7 @@ zpl_xattr_get_sa(struct inode *ip, const char *name, void *value, size_t size)
-       if (error)
-               return (error);
--      if (!size)
-+      if (size == 0 || value == NULL)
-               return (nv_size);
-       if (size < nv_size)
-diff --git a/module/zfs/zvol.c b/module/zfs/zvol.c
-index 5293f95fb..aac494209 100644
---- a/module/zfs/zvol.c
-+++ b/module/zfs/zvol.c
-@@ -202,7 +202,7 @@ static zvol_state_t *
- zvol_find_by_name_hash(const char *name, uint64_t hash, int mode)
- {
-       zvol_state_t *zv;
--      struct hlist_node *p;
-+      struct hlist_node *p = NULL;
-       mutex_enter(&zvol_state_lock);
-       hlist_for_each(p, ZVOL_HT_HEAD(hash)) {
--- 
-2.14.2
-
diff --git a/zfs-patches/0020-OpenZFS-8794-cstyle-generates-warnings-with-recent-p.patch b/zfs-patches/0020-OpenZFS-8794-cstyle-generates-warnings-with-recent-p.patch
deleted file mode 100644 (file)
index cc04e9a..0000000
+++ /dev/null
@@ -1,157 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Dominik Hassler <hadfl@omniosce.org>
-Date: Thu, 9 Nov 2017 15:22:07 +0100
-Subject: [PATCH] OpenZFS 8794 - cstyle generates warnings with recent perl
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Authored by: Dominik Hassler <hadfl@omniosce.org>
-Reviewed by: Andy Fiddaman <andy@omniosce.org>
-Reviewed by: Igor Kozhukhov <igor@dilos.org>
-Reviewed by: Toomas Soome <tsoome@me.com>
-Reviewed by: Brian Behlendorf <behlendorf1@llnl.gov>
-Approved by: Dan McDonald <danmcd@joyent.com>
-Ported-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-
-OpenZFS-issue: https://www.illumos.org/issues/8794
-OpenZFS-commit: https://github.com/openzfs/openzfs/commit/578f67364c
-Closes #6973
-
-(cherry picked from commit d27a40d28f96cfd9f7b32337306f64935ee749bc)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- scripts/cstyle.pl | 36 ++++++++++++++++++------------------
- 1 file changed, 18 insertions(+), 18 deletions(-)
-
-diff --git a/scripts/cstyle.pl b/scripts/cstyle.pl
-index 73c708c0b..00b33dddf 100755
---- a/scripts/cstyle.pl
-+++ b/scripts/cstyle.pl
-@@ -383,7 +383,7 @@ line: while (<$filehandle>) {
-       # is this the beginning or ending of a function?
-       # (not if "struct foo\n{\n")
--      if (/^{$/ && $prev =~ /\)\s*(const\s*)?(\/\*.*\*\/\s*)?\\?$/) {
-+      if (/^\{$/ && $prev =~ /\)\s*(const\s*)?(\/\*.*\*\/\s*)?\\?$/) {
-               $in_function = 1;
-               $in_declaration = 1;
-               $in_function_header = 0;
-@@ -391,7 +391,7 @@ line: while (<$filehandle>) {
-               $prev = $line;
-               next line;
-       }
--      if (/^}\s*(\/\*.*\*\/\s*)*$/) {
-+      if (/^\}\s*(\/\*.*\*\/\s*)*$/) {
-               if ($prev =~ /^\s*return\s*;/) {
-                       err_prev("unneeded return at end of function");
-               }
-@@ -401,7 +401,7 @@ line: while (<$filehandle>) {
-               next line;
-       }
-       if ($in_function_header && ! /^    (\w|\.)/ ) {
--              if (/^{}$/ # empty functions
-+              if (/^\{\}$/ # empty functions
-               || /;/ #run function with multiline arguments
-               || /#/ #preprocessor commands
-               || /^[^\s\\]*\(.*\)$/ #functions without ; at the end
-@@ -431,7 +431,7 @@ line: while (<$filehandle>) {
-                       $function_header_full_indent = 1;
-               }
-       }
--      if ($in_function_header && /^{$/) {
-+      if ($in_function_header && /^\{$/) {
-               $in_function_header = 0;
-               $function_header_full_indent = 0;
-               $in_function = 1;
-@@ -440,7 +440,7 @@ line: while (<$filehandle>) {
-               $in_function_header = 0;
-               $function_header_full_indent = 0;
-       }
--      if ($in_function_header && /{$/ ) {
-+      if ($in_function_header && /\{$/ ) {
-               if ($picky) {
-                       err("opening brace on same line as function header");
-               }
-@@ -670,14 +670,14 @@ line: while (<$filehandle>) {
-       if (/\S\{/ && !/\{\{/) {
-               err("missing space before left brace");
-       }
--      if ($in_function && /^\s+{/ &&
-+      if ($in_function && /^\s+\{/ &&
-           ($prev =~ /\)\s*$/ || $prev =~ /\bstruct\s+\w+$/)) {
-               err("left brace starting a line");
-       }
--      if (/}(else|while)/) {
-+      if (/\}(else|while)/) {
-               err("missing space after right brace");
-       }
--      if (/}\s\s+(else|while)/) {
-+      if (/\}\s\s+(else|while)/) {
-               err("extra space after right brace");
-       }
-       if (/\b_VOID\b|\bVOID\b|\bSTATIC\b/) {
-@@ -730,18 +730,18 @@ line: while (<$filehandle>) {
-       if ($heuristic) {
-               # cannot check this everywhere due to "struct {\n...\n} foo;"
-               if ($in_function && !$in_declaration &&
--                  /}./ && !/}\s+=/ && !/{.*}[;,]$/ && !/}(\s|\ 1)*$/ &&
--                  !/} (else|while)/ && !/}}/) {
-+                  /\}./ && !/\}\s+=/ && !/\{.*\}[;,]$/ && !/\}(\s|\ 1)*$/ &&
-+                  !/\} (else|while)/ && !/\}\}/) {
-                       err("possible bad text following right brace");
-               }
-               # cannot check this because sub-blocks in
-               # the middle of code are ok
--              if ($in_function && /^\s+{/) {
-+              if ($in_function && /^\s+\{/) {
-                       err("possible left brace starting a line");
-               }
-       }
-       if (/^\s*else\W/) {
--              if ($prev =~ /^\s*}$/) {
-+              if ($prev =~ /^\s*\}$/) {
-                       err_prefix($prev,
-                           "else and right brace should be on same line");
-               }
-@@ -827,8 +827,8 @@ process_indent($)
-       # skip over enumerations, array definitions, initializers, etc.
-       if ($cont_off <= 0 && !/^\s*$special/ &&
--          (/(?:(?:\b(?:enum|struct|union)\s*[^\{]*)|(?:\s+=\s*)){/ ||
--          (/^\s*{/ && $prev =~ /=\s*(?:\/\*.*\*\/\s*)*$/))) {
-+          (/(?:(?:\b(?:enum|struct|union)\s*[^\{]*)|(?:\s+=\s*))\{/ ||
-+          (/^\s*\{/ && $prev =~ /=\s*(?:\/\*.*\*\/\s*)*$/))) {
-               $cont_in = 0;
-               $cont_off = tr/{/{/ - tr/}/}/;
-               return;
-@@ -851,14 +851,14 @@ process_indent($)
-               return          if (/^\s*\}?$/);
-               return          if (/^\s*\}?\s*else\s*\{?$/);
-               return          if (/^\s*do\s*\{?$/);
--              return          if (/{$/);
--              return          if (/}[,;]?$/);
-+              return          if (/\{$/);
-+              return          if (/\}[,;]?$/);
-               # Allow macros on their own lines
-               return          if (/^\s*[A-Z_][A-Z_0-9]*$/);
-               # cases we don't deal with, generally non-kosher
--              if (/{/) {
-+              if (/\{/) {
-                       err("stuff after {");
-                       return;
-               }
-@@ -927,7 +927,7 @@ process_indent($)
-                       #
-                       next            if (@cont_paren != 0);
-                       if ($cont_special) {
--                              if ($rest =~ /^\s*{?$/) {
-+                              if ($rest =~ /^\s*\{?$/) {
-                                       $cont_in = 0;
-                                       last;
-                               }
--- 
-2.14.2
-
diff --git a/zfs-patches/0021-Handle-invalid-options-in-arc_summary.patch b/zfs-patches/0021-Handle-invalid-options-in-arc_summary.patch
deleted file mode 100644 (file)
index e353de6..0000000
+++ /dev/null
@@ -1,137 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: LOLi <loli10K@users.noreply.github.com>
-Date: Tue, 19 Dec 2017 22:02:40 +0100
-Subject: [PATCH] Handle invalid options in arc_summary
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-If an invalid option is provided to arc_summary.py we handle any error
-thrown from the getopt Python module and print the usage help message.
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Signed-off-by: loli10K <ezomori.nozomu@gmail.com>
-Closes #6983
-(cherry picked from commit 9a6c57845a431f55fd617c38e180b26215f0ca6f)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- .../tests/functional/cli_user/misc/Makefile.am     |  1 +
- cmd/arc_summary/arc_summary.py                     | 16 ++++++---
- tests/runfiles/linux.run                           |  2 +-
- .../cli_user/misc/arc_summary_002_neg.ksh          | 38 ++++++++++++++++++++++
- 4 files changed, 51 insertions(+), 6 deletions(-)
- create mode 100755 tests/zfs-tests/tests/functional/cli_user/misc/arc_summary_002_neg.ksh
-
-diff --git a/tests/zfs-tests/tests/functional/cli_user/misc/Makefile.am b/tests/zfs-tests/tests/functional/cli_user/misc/Makefile.am
-index cf7502c27..75a3d0886 100644
---- a/tests/zfs-tests/tests/functional/cli_user/misc/Makefile.am
-+++ b/tests/zfs-tests/tests/functional/cli_user/misc/Makefile.am
-@@ -46,4 +46,5 @@ dist_pkgdata_SCRIPTS = \
-       zpool_upgrade_001_neg.ksh \
-       arcstat_001_pos.ksh \
-       arc_summary_001_pos.ksh \
-+      arc_summary_002_neg.ksh \
-       dbufstat_001_pos.ksh
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index 5da81347c..2472f87ea 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -977,9 +977,15 @@ def main():
-     global show_tunable_descriptions
-     global alternate_tunable_layout
--    opts, args = getopt.getopt(
--        sys.argv[1:], "adp:h", ["alternate", "description", "page=", "help"]
--    )
-+    try:
-+        opts, args = getopt.getopt(
-+            sys.argv[1:],
-+            "adp:h", ["alternate", "description", "page=", "help"]
-+        )
-+    except getopt.error as e:
-+        sys.stderr.write("Error: %s\n" % e.msg)
-+        usage()
-+        sys.exit(1)
-     args = {}
-     for opt, arg in opts:
-@@ -991,7 +997,7 @@ def main():
-             args['p'] = arg
-         if opt in ('-h', '--help'):
-             usage()
--            sys.exit()
-+            sys.exit(0)
-     Kstat = get_Kstat()
-@@ -1006,7 +1012,7 @@ def main():
-         except IndexError:
-             sys.stderr.write('the argument to -p must be between 1 and ' +
-                              str(len(unSub)) + '\n')
--            sys.exit()
-+            sys.exit(1)
-     else:
-         pages = unSub
-diff --git a/tests/runfiles/linux.run b/tests/runfiles/linux.run
-index 10bd110a6..f872c0cbf 100644
---- a/tests/runfiles/linux.run
-+++ b/tests/runfiles/linux.run
-@@ -366,7 +366,7 @@ tests = ['zdb_001_neg', 'zfs_001_neg', 'zfs_allow_001_neg',
-     'zpool_offline_001_neg', 'zpool_online_001_neg', 'zpool_remove_001_neg',
-     'zpool_replace_001_neg', 'zpool_scrub_001_neg', 'zpool_set_001_neg',
-     'zpool_status_001_neg', 'zpool_upgrade_001_neg', 'arcstat_001_pos',
--    'arc_summary_001_pos', 'dbufstat_001_pos']
-+    'arc_summary_001_pos', 'arc_summary_002_neg', 'dbufstat_001_pos']
- user =
- tags = ['functional', 'cli_user', 'misc']
-diff --git a/tests/zfs-tests/tests/functional/cli_user/misc/arc_summary_002_neg.ksh b/tests/zfs-tests/tests/functional/cli_user/misc/arc_summary_002_neg.ksh
-new file mode 100755
-index 000000000..e63552feb
---- /dev/null
-+++ b/tests/zfs-tests/tests/functional/cli_user/misc/arc_summary_002_neg.ksh
-@@ -0,0 +1,38 @@
-+#!/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 http://www.opensolaris.org/os/licensing.
-+# 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) 2015 by Lawrence Livermore National Security, LLC.
-+# All rights reserved.
-+#
-+
-+. $STF_SUITE/include/libtest.shlib
-+
-+typeset args=("-x" "-r" "-5" "-p 7" "--err" "-@")
-+
-+log_assert "arc_summary.py generates an error code with invalid options"
-+
-+for arg in "${args[@]}"; do
-+        log_mustnot eval "arc_summary.py $arg > /dev/null"
-+done
-+
-+log_pass "arc_summary.py generates an error code with invalid options"
--- 
-2.14.2
-
diff --git a/zfs-patches/0022-Handle-broken-pipes-in-arc_summary.patch b/zfs-patches/0022-Handle-broken-pipes-in-arc_summary.patch
deleted file mode 100644 (file)
index dcd0412..0000000
+++ /dev/null
@@ -1,70 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Giuseppe Di Natale <dinatale2@users.noreply.github.com>
-Date: Tue, 19 Dec 2017 13:19:24 -0800
-Subject: [PATCH] Handle broken pipes in arc_summary
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Using a command similar to 'arc_summary.py | head' causes
-a broken pipe exception. Gracefully exit in the case of a
-broken pipe in arc_summary.py.
-
-Reviewed-by: Richard Elling <Richard.Elling@RichardElling.com>
-Reviewed-by: loli10K <ezomori.nozomu@gmail.com>
-Signed-off-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Closes #6965
-Closes #6969
-(cherry picked from commit c2aacf20872856559972a27f7c3f9b4a6fe10cd2)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/arc_summary/arc_summary.py                              | 13 +++++++++++++
- .../tests/functional/cli_user/misc/arc_summary_001_pos.ksh  |  3 +++
- 2 files changed, 16 insertions(+)
-
-diff --git a/cmd/arc_summary/arc_summary.py b/cmd/arc_summary/arc_summary.py
-index 2472f87ea..f6dbb9bfb 100755
---- a/cmd/arc_summary/arc_summary.py
-+++ b/cmd/arc_summary/arc_summary.py
-@@ -47,6 +47,7 @@ import getopt
- import os
- import sys
- import time
-+import errno
- from subprocess import Popen, PIPE
- from decimal import Decimal as D
-@@ -55,6 +56,18 @@ show_tunable_descriptions = False
- alternate_tunable_layout = False
-+def handle_Exception(ex_cls, ex, tb):
-+    if ex is IOError:
-+        if ex.errno == errno.EPIPE:
-+            sys.exit()
-+
-+    if ex is KeyboardInterrupt:
-+        sys.exit()
-+
-+
-+sys.excepthook = handle_Exception
-+
-+
- def get_Kstat():
-     """Collect information on the ZFS subsystem from the /proc virtual
-     file system. The name "kstat" is a holdover from the Solaris utility
-diff --git a/tests/zfs-tests/tests/functional/cli_user/misc/arc_summary_001_pos.ksh b/tests/zfs-tests/tests/functional/cli_user/misc/arc_summary_001_pos.ksh
-index 67c11c8ab..6653b9c1a 100755
---- a/tests/zfs-tests/tests/functional/cli_user/misc/arc_summary_001_pos.ksh
-+++ b/tests/zfs-tests/tests/functional/cli_user/misc/arc_summary_001_pos.ksh
-@@ -37,4 +37,7 @@ while [[ $i -lt ${#args[*]} ]]; do
-         ((i = i + 1))
- done
-+log_must eval "arc_summary.py | head > /dev/null"
-+log_must eval "arc_summary.py | head -1 > /dev/null"
-+
- log_pass "arc_summary.py generates output and doesn't return an error code"
--- 
-2.14.2
-
diff --git a/zfs-patches/0023-Call-commit-callbacks-from-the-tail-of-the-list.patch b/zfs-patches/0023-Call-commit-callbacks-from-the-tail-of-the-list.patch
deleted file mode 100644 (file)
index 47d246e..0000000
+++ /dev/null
@@ -1,86 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: lidongyang <gnaygnodil@gmail.com>
-Date: Sat, 23 Dec 2017 05:19:51 +1100
-Subject: [PATCH] Call commit callbacks from the tail of the list
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Our zfs backed Lustre MDT had soft lockups while under heavy metadata
-workloads while handling transaction callbacks from osd_zfs.
-
-The problem is zfs is not taking advantage of the fast path in
-Lustre's trans callback handling, where Lustre will skip the calls
-to ptlrpc_commit_replies() when it already saw a higher transaction
-number.
-
-This patch corrects this, it also has a positive impact on metadata
-performance on Lustre with osd_zfs, plus some cleanup in the headers.
-
-A similar issue for ext4/ldiskfs is described on:
-https://jira.hpdd.intel.com/browse/LU-6527
-
-Reviewed-by: Olaf Faaland <faaland1@llnl.gov>
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Signed-off-by: Li Dongyang <dongyang.li@anu.edu.au>
-Closes #6986
-(cherry picked from commit 8d82a19def540bba43c8c7597142ff53f7a0b7e5)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- include/sys/dmu.h    | 5 +++++
- include/sys/dmu_tx.h | 4 ----
- module/zfs/dmu_tx.c  | 2 +-
- 3 files changed, 6 insertions(+), 5 deletions(-)
-
-diff --git a/include/sys/dmu.h b/include/sys/dmu.h
-index d24615262..bcdf7d646 100644
---- a/include/sys/dmu.h
-+++ b/include/sys/dmu.h
-@@ -713,11 +713,16 @@ void dmu_tx_mark_netfree(dmu_tx_t *tx);
-  * to stable storage and will also be called if the dmu_tx is aborted.
-  * If there is any error which prevents the transaction from being committed to
-  * disk, the callback will be called with a value of error != 0.
-+ *
-+ * When multiple callbacks are registered to the transaction, the callbacks
-+ * will be called in reverse order to let Lustre, the only user of commit
-+ * callback currently, take the fast path of its commit callback handling.
-  */
- typedef void dmu_tx_callback_func_t(void *dcb_data, int error);
- void dmu_tx_callback_register(dmu_tx_t *tx, dmu_tx_callback_func_t *dcb_func,
-     void *dcb_data);
-+void dmu_tx_do_callbacks(list_t *cb_list, int error);
- /*
-  * Free up the data blocks for a defined range of a file.  If size is
-diff --git a/include/sys/dmu_tx.h b/include/sys/dmu_tx.h
-index f16e1e858..d82a79310 100644
---- a/include/sys/dmu_tx.h
-+++ b/include/sys/dmu_tx.h
-@@ -145,10 +145,6 @@ uint64_t dmu_tx_get_txg(dmu_tx_t *tx);
- struct dsl_pool *dmu_tx_pool(dmu_tx_t *tx);
- void dmu_tx_wait(dmu_tx_t *tx);
--void dmu_tx_callback_register(dmu_tx_t *tx, dmu_tx_callback_func_t *dcb_func,
--    void *dcb_data);
--void dmu_tx_do_callbacks(list_t *cb_list, int error);
--
- /*
-  * These routines are defined in dmu_spa.h, and are called by the SPA.
-  */
-diff --git a/module/zfs/dmu_tx.c b/module/zfs/dmu_tx.c
-index 097fa774a..c3cc03a69 100644
---- a/module/zfs/dmu_tx.c
-+++ b/module/zfs/dmu_tx.c
-@@ -1200,7 +1200,7 @@ dmu_tx_do_callbacks(list_t *cb_list, int error)
- {
-       dmu_tx_callback_t *dcb;
--      while ((dcb = list_head(cb_list)) != NULL) {
-+      while ((dcb = list_tail(cb_list)) != NULL) {
-               list_remove(cb_list, dcb);
-               dcb->dcb_func(dcb->dcb_data, error);
-               kmem_free(dcb, sizeof (dmu_tx_callback_t));
--- 
-2.14.2
-
diff --git a/zfs-patches/0024-Fix-zpool-add-handling-of-nested-interior-VDEVs.patch b/zfs-patches/0024-Fix-zpool-add-handling-of-nested-interior-VDEVs.patch
deleted file mode 100644 (file)
index a3347d5..0000000
+++ /dev/null
@@ -1,302 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: LOLi <loli10K@users.noreply.github.com>
-Date: Thu, 28 Dec 2017 19:15:32 +0100
-Subject: [PATCH] Fix 'zpool add' handling of nested interior VDEVs
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-When replacing a faulted device which was previously handled by a spare
-multiple levels of nested interior VDEVs will be present in the pool
-configuration; the following example illustrates one of the possible
-situations:
-
-   NAME                          STATE     READ WRITE CKSUM
-   testpool                      DEGRADED     0     0     0
-     raidz1-0                    DEGRADED     0     0     0
-       spare-0                   DEGRADED     0     0     0
-         replacing-0             DEGRADED     0     0     0
-           /var/tmp/fault-dev    UNAVAIL      0     0     0  cannot open
-           /var/tmp/replace-dev  ONLINE       0     0     0
-         /var/tmp/spare-dev1     ONLINE       0     0     0
-       /var/tmp/safe-dev         ONLINE       0     0     0
-   spares
-     /var/tmp/spare-dev1         INUSE     currently in use
-
-This is safe and allowed, but get_replication() needs to handle this
-situation gracefully to let zpool add new devices to the pool.
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Signed-off-by: loli10K <ezomori.nozomu@gmail.com>
-Closes #6678
-Closes #6996
-(cherry picked from commit a8fa31b50b958306cd39c21e8518f776ee59f1b6)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- .../functional/cli_root/zpool_add/Makefile.am      |   3 +-
- cmd/zpool/zpool_vdev.c                             |   6 +-
- tests/runfiles/linux.run                           |   2 +-
- tests/zfs-tests/include/libtest.shlib              |  66 +++++++++++-
- .../zpool_add/add_nested_replacing_spare.ksh       | 111 +++++++++++++++++++++
- 5 files changed, 182 insertions(+), 6 deletions(-)
- create mode 100755 tests/zfs-tests/tests/functional/cli_root/zpool_add/add_nested_replacing_spare.ksh
-
-diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_add/Makefile.am b/tests/zfs-tests/tests/functional/cli_root/zpool_add/Makefile.am
-index 4b6b533fe..062028299 100644
---- a/tests/zfs-tests/tests/functional/cli_root/zpool_add/Makefile.am
-+++ b/tests/zfs-tests/tests/functional/cli_root/zpool_add/Makefile.am
-@@ -15,4 +15,5 @@ dist_pkgdata_SCRIPTS = \
-       zpool_add_009_neg.ksh \
-       zpool_add_010_pos.ksh \
-       add-o_ashift.ksh \
--      add_prop_ashift.ksh
-+      add_prop_ashift.ksh \
-+      add_nested_replacing_spare.ksh
-diff --git a/cmd/zpool/zpool_vdev.c b/cmd/zpool/zpool_vdev.c
-index 97faa5f9b..fd6bd9e76 100644
---- a/cmd/zpool/zpool_vdev.c
-+++ b/cmd/zpool/zpool_vdev.c
-@@ -860,9 +860,11 @@ get_replication(nvlist_t *nvroot, boolean_t fatal)
-                               /*
-                                * If this is a replacing or spare vdev, then
--                               * get the real first child of the vdev.
-+                               * get the real first child of the vdev: do this
-+                               * in a loop because replacing and spare vdevs
-+                               * can be nested.
-                                */
--                              if (strcmp(childtype,
-+                              while (strcmp(childtype,
-                                   VDEV_TYPE_REPLACING) == 0 ||
-                                   strcmp(childtype, VDEV_TYPE_SPARE) == 0) {
-                                       nvlist_t **rchild;
-diff --git a/tests/runfiles/linux.run b/tests/runfiles/linux.run
-index f872c0cbf..303c27529 100644
---- a/tests/runfiles/linux.run
-+++ b/tests/runfiles/linux.run
-@@ -228,7 +228,7 @@ tests = ['zpool_add_001_pos', 'zpool_add_002_pos', 'zpool_add_003_pos',
-     'zpool_add_004_pos', 'zpool_add_005_pos', 'zpool_add_006_pos',
-     'zpool_add_007_neg', 'zpool_add_008_neg', 'zpool_add_009_neg',
-     'zpool_add_010_pos',
--    'add-o_ashift', 'add_prop_ashift']
-+    'add-o_ashift', 'add_prop_ashift', 'add_nested_replacing_spare']
- tags = ['functional', 'cli_root', 'zpool_add']
- [tests/functional/cli_root/zpool_attach]
-diff --git a/tests/zfs-tests/include/libtest.shlib b/tests/zfs-tests/include/libtest.shlib
-index 345d1903d..86f172a6d 100644
---- a/tests/zfs-tests/include/libtest.shlib
-+++ b/tests/zfs-tests/include/libtest.shlib
-@@ -1988,6 +1988,31 @@ function check_hotspare_state # pool disk state{inuse,avail}
-       return 0
- }
-+#
-+# Wait until a hotspare transitions to a given state or times out.
-+#
-+# Return 0 when  pool/disk matches expected state, 1 on timeout.
-+#
-+function wait_hotspare_state # pool disk state timeout
-+{
-+      typeset pool=$1
-+      typeset disk=${2#$/DEV_DSKDIR/}
-+      typeset state=$3
-+      typeset timeout=${4:-60}
-+      typeset -i i=0
-+
-+      while [[ $i -lt $timeout ]]; do
-+              if check_hotspare_state $pool $disk $state; then
-+                      return 0
-+              fi
-+
-+              i=$((i+1))
-+              sleep 1
-+      done
-+
-+      return 1
-+}
-+
- #
- # Verify a given slog disk is inuse or avail
- #
-@@ -2026,6 +2051,31 @@ function check_vdev_state # pool disk state{online,offline,unavail}
-       return 0
- }
-+#
-+# Wait until a vdev transitions to a given state or times out.
-+#
-+# Return 0 when  pool/disk matches expected state, 1 on timeout.
-+#
-+function wait_vdev_state # pool disk state timeout
-+{
-+      typeset pool=$1
-+      typeset disk=${2#$/DEV_DSKDIR/}
-+      typeset state=$3
-+      typeset timeout=${4:-60}
-+      typeset -i i=0
-+
-+      while [[ $i -lt $timeout ]]; do
-+              if check_vdev_state $pool $disk $state; then
-+                      return 0
-+              fi
-+
-+              i=$((i+1))
-+              sleep 1
-+      done
-+
-+      return 1
-+}
-+
- #
- # Check the output of 'zpool status -v <pool>',
- # and to see if the content of <token> contain the <keyword> specified.
-@@ -3394,13 +3444,25 @@ function zed_stop
-       if [[ -f ${ZEDLET_DIR}/zed.pid ]]; then
-               zedpid=$(cat ${ZEDLET_DIR}/zed.pid)
-               kill $zedpid
--              wait $zedpid
-+              while ps -p $zedpid > /dev/null; do
-+                      sleep 1
-+              done
-               rm -f ${ZEDLET_DIR}/zed.pid
-       fi
--
-       return 0
- }
-+#
-+# Drain all zevents
-+#
-+function zed_events_drain
-+{
-+       while [ $(zpool events -H | wc -l) -ne 0 ]; do
-+             sleep 1
-+             zpool events -c >/dev/null
-+       done
-+}
-+
- #
- # Check is provided device is being active used as a swap device.
- #
-diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_add/add_nested_replacing_spare.ksh b/tests/zfs-tests/tests/functional/cli_root/zpool_add/add_nested_replacing_spare.ksh
-new file mode 100755
-index 000000000..b38079852
---- /dev/null
-+++ b/tests/zfs-tests/tests/functional/cli_root/zpool_add/add_nested_replacing_spare.ksh
-@@ -0,0 +1,111 @@
-+#!/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 http://www.opensolaris.org/os/licensing.
-+# 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 2017, loli10K <ezomori.nozomu@gmail.com>. All rights reserved.
-+#
-+
-+. $STF_SUITE/include/libtest.shlib
-+. $STF_SUITE/tests/functional/cli_root/zpool_create/zpool_create.shlib
-+
-+#
-+# DESCRIPTION:
-+#     'zpool add' works with nested replacing/spare vdevs
-+#
-+# STRATEGY:
-+#     1. Create a redundant pool with a spare device
-+#     2. Manually fault a device, wait for the hot-spare and then replace it:
-+#        this creates a situation where replacing and spare vdevs are nested.
-+#     3. Verify 'zpool add' is able to add new devices to the pool.
-+#
-+
-+verify_runnable "global"
-+
-+function cleanup
-+{
-+      zed_stop
-+      zed_cleanup
-+      log_must zinject -c all
-+      destroy_pool $TESTPOOL
-+      log_must rm -f $DATA_DEVS $SPARE_DEVS
-+}
-+
-+log_assert "'zpool add' works with nested replacing/spare vdevs"
-+log_onexit cleanup
-+
-+FAULT_DEV="$TEST_BASE_DIR/fault-dev"
-+SAFE_DEV1="$TEST_BASE_DIR/safe-dev1"
-+SAFE_DEV2="$TEST_BASE_DIR/safe-dev2"
-+SAFE_DEV3="$TEST_BASE_DIR/safe-dev3"
-+SAFE_DEVS="$SAFE_DEV1 $SAFE_DEV2 $SAFE_DEV3"
-+REPLACE_DEV="$TEST_BASE_DIR/replace-dev"
-+ADD_DEV="$TEST_BASE_DIR/add-dev"
-+DATA_DEVS="$FAULT_DEV $SAFE_DEVS $REPLACE_DEV $ADD_DEV"
-+SPARE_DEV1="$TEST_BASE_DIR/spare-dev1"
-+SPARE_DEV2="$TEST_BASE_DIR/spare-dev2"
-+SPARE_DEVS="$SPARE_DEV1 $SPARE_DEV2"
-+
-+# We need ZED running to work with spares
-+zed_setup
-+zed_start
-+# Clear events from previous runs
-+zed_events_drain
-+
-+for type in "mirror" "raidz1" "raidz2" "raidz3"
-+do
-+      # 1. Create a redundant pool with a spare device
-+      truncate -s $SPA_MINDEVSIZE $DATA_DEVS $SPARE_DEVS
-+      log_must zpool create $TESTPOOL $type $FAULT_DEV $SAFE_DEVS
-+      log_must zpool add $TESTPOOL spare $SPARE_DEV1
-+
-+      # 2.1 Fault a device, verify the spare is kicked in
-+      log_must zinject -d $FAULT_DEV -e nxio -T all -f 100 $TESTPOOL
-+      log_must zpool scrub $TESTPOOL
-+      log_must wait_vdev_state $TESTPOOL $FAULT_DEV "UNAVAIL" 60
-+      log_must wait_vdev_state $TESTPOOL $SPARE_DEV1 "ONLINE" 60
-+      log_must wait_hotspare_state $TESTPOOL $SPARE_DEV1 "INUSE"
-+      log_must check_state $TESTPOOL "" "DEGRADED"
-+
-+      # 2.2 Replace the faulted device: this creates a replacing vdev inside a
-+      #     spare vdev
-+      log_must zpool replace $TESTPOOL $FAULT_DEV $REPLACE_DEV
-+      log_must wait_vdev_state $TESTPOOL $REPLACE_DEV "ONLINE" 60
-+      zpool status | awk -v poolname="$TESTPOOL" -v type="$type" 'BEGIN {s=""}
-+          $1 ~ poolname {c=4}; (c && c--) { s=s$1":" }
-+          END { if (s != poolname":"type"-0:spare-0:replacing-0:") exit 1; }'
-+      if [[ $? -ne 0 ]]; then
-+              log_fail "Pool does not contain nested replacing/spare vdevs"
-+      fi
-+
-+      # 3. Verify 'zpool add' is able to add new devices
-+      log_must zpool add $TESTPOOL spare $SPARE_DEV2
-+      log_must wait_hotspare_state $TESTPOOL $SPARE_DEV2 "AVAIL"
-+      log_must zpool add -f $TESTPOOL $ADD_DEV
-+      log_must wait_vdev_state $TESTPOOL $ADD_DEV "ONLINE" 60
-+
-+      # Cleanup
-+      log_must zinject -c all
-+      destroy_pool $TESTPOOL
-+      log_must rm -f $DATA_DEVS $SPARE_DEVS
-+done
-+
-+log_pass "'zpool add' works with nested replacing/spare vdevs"
--- 
-2.14.2
-
diff --git a/zfs-patches/0025-zhack-fix-getopt-return-type.patch b/zfs-patches/0025-zhack-fix-getopt-return-type.patch
deleted file mode 100644 (file)
index 6016c30..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Nathaniel Wesley Filardo
- <VP331RHQ115POU58JFRLKB7OPA0L18E3@cmx.ietfng.org>
-Date: Tue, 9 Jan 2018 14:14:45 -0500
-Subject: [PATCH] zhack: fix getopt return type
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-This fixes zhack's command processing on ARM.  On ARM char
-is unsigned, and so, in promotion to an int, it will never
-compare equal to -1.
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Signed-off-by: Nathaniel Wesley Filardo <nwf@cs.jhu.edu>
-Closes #7016
-(cherry picked from commit a2ee6568c604fb455d6ee7fa51728fb2bc700dac)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/zhack/zhack.c | 6 +++---
- 1 file changed, 3 insertions(+), 3 deletions(-)
-
-diff --git a/cmd/zhack/zhack.c b/cmd/zhack/zhack.c
-index 70f88fc69..e15af8f4e 100644
---- a/cmd/zhack/zhack.c
-+++ b/cmd/zhack/zhack.c
-@@ -268,7 +268,7 @@ zhack_feature_enable_sync(void *arg, dmu_tx_t *tx)
- static void
- zhack_do_feature_enable(int argc, char **argv)
- {
--      char c;
-+      int c;
-       char *desc, *target;
-       spa_t *spa;
-       objset_t *mos;
-@@ -363,7 +363,7 @@ feature_decr_sync(void *arg, dmu_tx_t *tx)
- static void
- zhack_do_feature_ref(int argc, char **argv)
- {
--      char c;
-+      int c;
-       char *target;
-       boolean_t decr = B_FALSE;
-       spa_t *spa;
-@@ -483,7 +483,7 @@ main(int argc, char **argv)
-       char *path[MAX_NUM_PATHS];
-       const char *subcommand;
-       int rv = 0;
--      char c;
-+      int c;
-       g_importargs.path = path;
--- 
-2.14.2
-
diff --git a/zfs-patches/0026-Revert-raidz_map-and-_col-structure-types.patch b/zfs-patches/0026-Revert-raidz_map-and-_col-structure-types.patch
deleted file mode 100644 (file)
index 165e23b..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Nathaniel Wesley Filardo
- <VP331RHQ115POU58JFRLKB7OPA0L18E3@cmx.ietfng.org>
-Date: Tue, 9 Jan 2018 17:46:52 -0500
-Subject: [PATCH] Revert raidz_map and _col structure types
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-As part of the refactoring of ab9f4b0b824ab4cc64a4fa382c037f4154de12d6,
-several uint64_t-s and uint8_t-s were changed to other types.  This
-caused ZoL github issue #6981, an overflow of a size_t on a 32-bit ARM
-machine.  In absense of any strong motivation for the type changes, this
-simply puts them back, modulo the changes accumulated for ABD.
-
-Compile-tested on amd64 and run-tested on armhf.
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: Gvozden Neskovic <neskovic@gmail.com>
-Signed-off-by: Nathaniel Wesley Filardo <nwf@cs.jhu.edu>
-Closes #6981
-Closes #7023
-(cherry picked from commit 9fb09f79e573d377b2b041f620eac703be3acc3f)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- include/sys/vdev_raidz_impl.h | 34 +++++++++++++++++-----------------
- 1 file changed, 17 insertions(+), 17 deletions(-)
-
-diff --git a/include/sys/vdev_raidz_impl.h b/include/sys/vdev_raidz_impl.h
-index 4bd15e3d5..0799ed19d 100644
---- a/include/sys/vdev_raidz_impl.h
-+++ b/include/sys/vdev_raidz_impl.h
-@@ -102,30 +102,30 @@ typedef struct raidz_impl_ops {
- } raidz_impl_ops_t;
- typedef struct raidz_col {
--      size_t rc_devidx;               /* child device index for I/O */
--      size_t rc_offset;               /* device offset */
--      size_t rc_size;                 /* I/O size */
-+      uint64_t rc_devidx;             /* child device index for I/O */
-+      uint64_t rc_offset;             /* device offset */
-+      uint64_t rc_size;               /* I/O size */
-       abd_t *rc_abd;                  /* I/O data */
-       void *rc_gdata;                 /* used to store the "good" version */
-       int rc_error;                   /* I/O error for this device */
--      unsigned int rc_tried;          /* Did we attempt this I/O column? */
--      unsigned int rc_skipped;        /* Did we skip this I/O column? */
-+      uint8_t rc_tried;               /* Did we attempt this I/O column? */
-+      uint8_t rc_skipped;             /* Did we skip this I/O column? */
- } raidz_col_t;
- typedef struct raidz_map {
--      size_t rm_cols;                 /* Regular column count */
--      size_t rm_scols;                /* Count including skipped columns */
--      size_t rm_bigcols;              /* Number of oversized columns */
--      size_t rm_asize;                /* Actual total I/O size */
--      size_t rm_missingdata;          /* Count of missing data devices */
--      size_t rm_missingparity;        /* Count of missing parity devices */
--      size_t rm_firstdatacol;         /* First data column/parity count */
--      size_t rm_nskip;                /* Skipped sectors for padding */
--      size_t rm_skipstart;            /* Column index of padding start */
-+      uint64_t rm_cols;               /* Regular column count */
-+      uint64_t rm_scols;              /* Count including skipped columns */
-+      uint64_t rm_bigcols;            /* Number of oversized columns */
-+      uint64_t rm_asize;              /* Actual total I/O size */
-+      uint64_t rm_missingdata;        /* Count of missing data devices */
-+      uint64_t rm_missingparity;      /* Count of missing parity devices */
-+      uint64_t rm_firstdatacol;       /* First data column/parity count */
-+      uint64_t rm_nskip;              /* Skipped sectors for padding */
-+      uint64_t rm_skipstart;          /* Column index of padding start */
-       abd_t *rm_abd_copy;             /* rm_asize-buffer of copied data */
--      size_t rm_reports;              /* # of referencing checksum reports */
--      unsigned int rm_freed;          /* map no longer has referencing ZIO */
--      unsigned int rm_ecksuminjected; /* checksum error was injected */
-+      uintptr_t rm_reports;           /* # of referencing checksum reports */
-+      uint8_t rm_freed;               /* map no longer has referencing ZIO */
-+      uint8_t rm_ecksuminjected;      /* checksum error was injected */
-       raidz_impl_ops_t *rm_ops;       /* RAIDZ math operations */
-       raidz_col_t rm_col[1];          /* Flexible array of I/O columns */
- } raidz_map_t;
--- 
-2.14.2
-
diff --git a/zfs-patches/0027-Use-zap_count-instead-of-cached-z_size-for-unlink.patch b/zfs-patches/0027-Use-zap_count-instead-of-cached-z_size-for-unlink.patch
deleted file mode 100644 (file)
index ef96dcc..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Alex Zhuravlev <alexey.zhuravlev@intel.com>
-Date: Mon, 8 Jan 2018 10:57:47 -0800
-Subject: [PATCH] Use zap_count instead of cached z_size for unlink
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-As a performance optimization Lustre does not strictly update
-the SA_ZPL_SIZE when adding/removing from non-directory entries.
-This results in entries which cannot be removed through the ZPL
-layer even though the ZAP is empty and safe to remove.
-
-Resolve this issue by checking the zap_count() directly instead
-on relying on the cached SA_ZPL_SIZE.  Micro-benchmarks show no
-significant performance impact due to the additional overhead
-of using zap_count().
-
-Reviewed-by: Olaf Faaland <faaland1@llnl.gov>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Alex Zhuravlev <alexey.zhuravlev@intel.com>
-Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Closes #7019
-(cherry picked from commit 129e3e8dc32673809d1d3523a0e773567e281a4a)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- module/zfs/zfs_dir.c | 16 +++++++++++++++-
- 1 file changed, 15 insertions(+), 1 deletion(-)
-
-diff --git a/module/zfs/zfs_dir.c b/module/zfs/zfs_dir.c
-index c6ee30291..9a8bbccd9 100644
---- a/module/zfs/zfs_dir.c
-+++ b/module/zfs/zfs_dir.c
-@@ -977,11 +977,25 @@ zfs_link_destroy(zfs_dirlock_t *dl, znode_t *zp, dmu_tx_t *tx, int flag,
-  * Indicate whether the directory is empty.  Works with or without z_lock
-  * held, but can only be consider a hint in the latter case.  Returns true
-  * if only "." and ".." remain and there's no work in progress.
-+ *
-+ * The internal ZAP size, rather than zp->z_size, needs to be checked since
-+ * some consumers (Lustre) do not strictly maintain an accurate SA_ZPL_SIZE.
-  */
- boolean_t
- zfs_dirempty(znode_t *dzp)
- {
--      return (dzp->z_size == 2 && dzp->z_dirlocks == 0);
-+      zfsvfs_t *zfsvfs = ZTOZSB(dzp);
-+      uint64_t count;
-+      int error;
-+
-+      if (dzp->z_dirlocks != NULL)
-+              return (B_FALSE);
-+
-+      error = zap_count(zfsvfs->z_os, dzp->z_id, &count);
-+      if (error != 0 || count != 0)
-+              return (B_FALSE);
-+
-+      return (B_TRUE);
- }
- int
--- 
-2.14.2
-
diff --git a/zfs-patches/0028-Fix-incompatibility-with-Reiser4-patched-kernels.patch b/zfs-patches/0028-Fix-incompatibility-with-Reiser4-patched-kernels.patch
deleted file mode 100644 (file)
index d4e7cd6..0000000
+++ /dev/null
@@ -1,70 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Richard Yao <ryao@gentoo.org>
-Date: Tue, 9 Jan 2018 19:18:19 -0500
-Subject: [PATCH] Fix incompatibility with Reiser4 patched kernels
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-In ZFSOnLinux, our sources and build system are self contained such that
-we do not need to make changes to the Linux kernel sources. Reiser4 on
-the other hand exists solely as a kernel tree patch and opts to make
-changes to the kernel rather than adapt to it. After Linux 4.1 made a
-VFS change that replaced new_sync_read with do_sync_read, Reiser4's
-maintainer decided to modify the kernel VFS to export the old function.
-This caused our autotools check to misidentify the kernel API as
-predating Linux 4.1 on kernels that have been patched with Reiser4
-support, which breaks our build.
-
-Reiser4 really should be patched to stop doing this, but lets modify our
-check to be more strict to help the affected users of both filesystems.
-
-Also, we were not checking the types of arguments and return value of
-new_sync_read() and new_sync_write() . Lets fix that too.
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Signed-off-by: Richard Yao <ryao@gentoo.org>
-Closes #6241
-Closes #7021
-(cherry picked from commit ecc8af18125728bf03841ceb48b057e15d96362c)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- config/kernel-vfs-rw-iterate.m4 | 14 +++++++++++---
- 1 file changed, 11 insertions(+), 3 deletions(-)
-
-diff --git a/config/kernel-vfs-rw-iterate.m4 b/config/kernel-vfs-rw-iterate.m4
-index 9f8fe6559..ace54f707 100644
---- a/config/kernel-vfs-rw-iterate.m4
-+++ b/config/kernel-vfs-rw-iterate.m4
-@@ -32,15 +32,23 @@ dnl #
- dnl # Linux 4.1 API
- dnl #
- AC_DEFUN([ZFS_AC_KERNEL_NEW_SYNC_READ],
--      [AC_MSG_CHECKING([whether new_sync_read() is available])
-+      [AC_MSG_CHECKING([whether new_sync_read/write() are available])
-       ZFS_LINUX_TRY_COMPILE([
-               #include <linux/fs.h>
-       ],[
--              new_sync_read(NULL, NULL, 0, NULL);
-+                      ssize_t ret __attribute__ ((unused));
-+                      struct file *filp = NULL;
-+                      char __user *rbuf = NULL;
-+                      const char __user *wbuf = NULL;
-+                      size_t len = 0;
-+                      loff_t ppos;
-+
-+                      ret = new_sync_read(filp, rbuf, len, &ppos);
-+                      ret = new_sync_write(filp, wbuf, len, &ppos);
-       ],[
-               AC_MSG_RESULT(yes)
-               AC_DEFINE(HAVE_NEW_SYNC_READ, 1,
--                      [new_sync_read() is available])
-+                      [new_sync_read()/new_sync_write() are available])
-       ],[
-               AC_MSG_RESULT(no)
-       ])
--- 
-2.14.2
-
diff --git a/zfs-patches/0029-Remove-l2arc_nocompress-from-zfs-module-parameters-5.patch b/zfs-patches/0029-Remove-l2arc_nocompress-from-zfs-module-parameters-5.patch
deleted file mode 100644 (file)
index 164a222..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: DeHackEd <DeHackEd@users.noreply.github.com>
-Date: Tue, 16 Jan 2018 13:18:08 -0500
-Subject: [PATCH] Remove l2arc_nocompress from zfs-module-parameters(5)
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Parameter was removed in d3c2ae1c0806
-(OpenZFS 6950 - ARC should cache compressed data)
-
-Reviewed by: Brian Behlendorf <behlendorf1@llnl.gov>
-Signed-off-by: DHE <git@dehacked.net>
-Closes #7043
-(cherry picked from commit 2a7b736dcea1abad62cceb36947e757b98c0e330)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- man/man5/zfs-module-parameters.5 | 11 -----------
- 1 file changed, 11 deletions(-)
-
-diff --git a/man/man5/zfs-module-parameters.5 b/man/man5/zfs-module-parameters.5
-index 4c957029d..19e6becfd 100644
---- a/man/man5/zfs-module-parameters.5
-+++ b/man/man5/zfs-module-parameters.5
-@@ -96,17 +96,6 @@ successfully compressed before writing. A value of 100 disables this feature.
- Default value: \fB200\fR.
- .RE
--.sp
--.ne 2
--.na
--\fBl2arc_nocompress\fR (int)
--.ad
--.RS 12n
--Skip compressing L2ARC buffers
--.sp
--Use \fB1\fR for yes and \fB0\fR for no (default).
--.RE
--
- .sp
- .ne 2
- .na
--- 
-2.14.2
-
diff --git a/zfs-patches/0030-Fix-shellcheck-v0.4.6-warnings.patch b/zfs-patches/0030-Fix-shellcheck-v0.4.6-warnings.patch
deleted file mode 100644 (file)
index 3c4ed07..0000000
+++ /dev/null
@@ -1,93 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Brian Behlendorf <behlendorf1@llnl.gov>
-Date: Wed, 17 Jan 2018 10:17:16 -0800
-Subject: [PATCH] Fix shellcheck v0.4.6 warnings
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Resolve new warnings reported after upgrading to shellcheck
-version 0.4.6.  This patch contains no functional changes.
-
-* egrep is non-standard and deprecated. Use grep -E instead. [SC2196]
-* Check exit code directly with e.g. 'if mycmd;', not indirectly
-  with $?.  [SC2181]  Suppressed.
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Closes #7040
-(cherry picked from commit 9d1a39cec6ba98c33cf0e358d2bac35dc1552d01)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- cmd/zed/zed.d/zed-functions.sh                         | 4 ++--
- scripts/zloop.sh                                       | 6 +++---
- tests/zfs-tests/tests/functional/acl/acl_common.kshlib | 2 +-
- 3 files changed, 6 insertions(+), 6 deletions(-)
-
-diff --git a/cmd/zed/zed.d/zed-functions.sh b/cmd/zed/zed.d/zed-functions.sh
-index b7de5104f..ed6a95914 100644
---- a/cmd/zed/zed.d/zed-functions.sh
-+++ b/cmd/zed/zed.d/zed-functions.sh
-@@ -397,7 +397,7 @@ zed_rate_limit()
-     zed_lock "${lockfile}" "${lockfile_fd}"
-     time_now="$(date +%s)"
--    time_prev="$(egrep "^[0-9]+;${tag}\$" "${statefile}" 2>/dev/null \
-+    time_prev="$(grep -E "^[0-9]+;${tag}\$" "${statefile}" 2>/dev/null \
-         | tail -1 | cut -d\; -f1)"
-     if [ -n "${time_prev}" ] \
-@@ -406,7 +406,7 @@ zed_rate_limit()
-     else
-         umask_bak="$(umask)"
-         umask 077
--        egrep -v "^[0-9]+;${tag}\$" "${statefile}" 2>/dev/null \
-+        grep -E -v "^[0-9]+;${tag}\$" "${statefile}" 2>/dev/null \
-             > "${statefile}.$$"
-         echo "${time_now};${tag}" >> "${statefile}.$$"
-         mv -f "${statefile}.$$" "${statefile}"
-diff --git a/scripts/zloop.sh b/scripts/zloop.sh
-index 854c2048a..03e825059 100755
---- a/scripts/zloop.sh
-+++ b/scripts/zloop.sh
-@@ -70,12 +70,12 @@ function or_die
- # core file helpers
- origcorepattern="$(cat /proc/sys/kernel/core_pattern)"
--coreglob="$(egrep -o '^([^|%[:space:]]*)' /proc/sys/kernel/core_pattern)*"
-+coreglob="$(grep -E -o '^([^|%[:space:]]*)' /proc/sys/kernel/core_pattern)*"
- if [[ $coreglob = "*" ]]; then
-         echo "Setting core file pattern..."
-         echo "core" > /proc/sys/kernel/core_pattern
--        coreglob="$(egrep -o '^([^|%[:space:]]*)' \
-+        coreglob="$(grep -E -o '^([^|%[:space:]]*)' \
-             /proc/sys/kernel/core_pattern)*"
- fi
-@@ -235,7 +235,7 @@ while [[ $timeout -eq 0 ]] || [[ $curtime -le $((starttime + timeout)) ]]; do
-       echo "$desc" >>ztest.out
-       $cmd >>ztest.out 2>&1
-       ztrc=$?
--      egrep '===|WARNING' ztest.out >>ztest.history
-+      grep -E '===|WARNING' ztest.out >>ztest.history
-       $ZDB -U "$workdir/zpool.cache" -DD ztest >>ztest.ddt
-       store_core
-diff --git a/tests/zfs-tests/tests/functional/acl/acl_common.kshlib b/tests/zfs-tests/tests/functional/acl/acl_common.kshlib
-index def25d390..75bb82455 100644
---- a/tests/zfs-tests/tests/functional/acl/acl_common.kshlib
-+++ b/tests/zfs-tests/tests/functional/acl/acl_common.kshlib
-@@ -410,7 +410,7 @@ function get_xattr #<obj>
-       fi
-       for xattr in `runat $obj ls | \
--              /usr/xpg4/bin/egrep -v -e SUNWattr_ro -e SUNWattr_rw` ; do
-+              grep -E -v -e SUNWattr_ro -e SUNWattr_rw` ; do
-               runat $obj sum $xattr
-       done
- }
--- 
-2.14.2
-
diff --git a/zfs-patches/0031-Fix-Debian-packaging-on-ARMv7-ARM64.patch b/zfs-patches/0031-Fix-Debian-packaging-on-ARMv7-ARM64.patch
deleted file mode 100644 (file)
index c6729f4..0000000
+++ /dev/null
@@ -1,72 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: LOLi <loli10K@users.noreply.github.com>
-Date: Thu, 18 Jan 2018 19:15:41 +0100
-Subject: [PATCH] Fix Debian packaging on ARMv7/ARM64
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-When building packages on Debian-based systems specify the target
-architecture used by 'alien' to convert .rpm packages into .deb: this
-avoids detecting an incorrect value which results in the following
-errors:
-
-<package>.aarch64.rpm is for architecture aarch64 ; the package cannot be built on this system
-<package>.armv7l.rpm is for architecture armel ; the package cannot be built on this system
-
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Signed-off-by: loli10K <ezomori.nozomu@gmail.com>
-Closes #7046
-Closes #7058
-(cherry picked from commit 5b8ec2cf391f2b7fb2b3a254b4ec9cf9664a2502)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- config/deb.am | 9 ++++++---
- 1 file changed, 6 insertions(+), 3 deletions(-)
-
-diff --git a/config/deb.am b/config/deb.am
-index 98e98e45f..1b51f9316 100644
---- a/config/deb.am
-+++ b/config/deb.am
-@@ -18,8 +18,9 @@ deb-kmod: deb-local rpm-kmod
-       name=${PACKAGE}; \
-       version=${VERSION}-${RELEASE}; \
-       arch=`$(RPM) -qp $${name}-kmod-$${version}.src.rpm --qf %{arch} | tail -1`; \
-+      debarch=`$(DPKG) --print-architecture`; \
-       pkg1=kmod-$${name}*$${version}.$${arch}.rpm; \
--      fakeroot $(ALIEN) --bump=0 --scripts --to-deb $$pkg1; \
-+      fakeroot $(ALIEN) --bump=0 --scripts --to-deb --target=$$debarch $$pkg1; \
-       $(RM) $$pkg1
-@@ -27,14 +28,16 @@ deb-dkms: deb-local rpm-dkms
-       name=${PACKAGE}; \
-       version=${VERSION}-${RELEASE}; \
-       arch=`$(RPM) -qp $${name}-dkms-$${version}.src.rpm --qf %{arch} | tail -1`; \
-+      debarch=`$(DPKG) --print-architecture`; \
-       pkg1=$${name}-dkms-$${version}.$${arch}.rpm; \
--      fakeroot $(ALIEN) --bump=0 --scripts --to-deb $$pkg1; \
-+      fakeroot $(ALIEN) --bump=0 --scripts --to-deb --target=$$debarch $$pkg1; \
-       $(RM) $$pkg1
- deb-utils: deb-local rpm-utils
-       name=${PACKAGE}; \
-       version=${VERSION}-${RELEASE}; \
-       arch=`$(RPM) -qp $${name}-$${version}.src.rpm --qf %{arch} | tail -1`; \
-+      debarch=`$(DPKG) --print-architecture`; \
-       pkg1=$${name}-$${version}.$${arch}.rpm; \
-       pkg2=libnvpair1-$${version}.$${arch}.rpm; \
-       pkg3=libuutil1-$${version}.$${arch}.rpm; \
-@@ -57,7 +60,7 @@ deb-utils: deb-local rpm-utils
- ## which should NOT be mixed with the alien-generated debs created here
-       chmod +x $${path_prepend}/dh_shlibdeps; \
-       env PATH=$${path_prepend}:$${PATH} \
--      fakeroot $(ALIEN) --bump=0 --scripts --to-deb \
-+      fakeroot $(ALIEN) --bump=0 --scripts --to-deb --target=$$debarch \
-           $$pkg1 $$pkg2 $$pkg3 $$pkg4 $$pkg5 $$pkg6 $$pkg7 \
-           $$pkg8 $$pkg9; \
-       $(RM) $${path_prepend}/dh_shlibdeps; \
--- 
-2.14.2
-
diff --git a/zfs-patches/0032-OpenZFS-8835-Speculative-prefetch-in-ZFS-not-working.patch b/zfs-patches/0032-OpenZFS-8835-Speculative-prefetch-in-ZFS-not-working.patch
deleted file mode 100644 (file)
index f441536..0000000
+++ /dev/null
@@ -1,86 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Alexander Motin <mav@FreeBSD.org>
-Date: Mon, 20 Nov 2017 19:56:01 +0200
-Subject: [PATCH] OpenZFS 8835 - Speculative prefetch in ZFS not working for
- misaligned reads
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-In case of misaligned I/O sequential requests are not detected as such
-due to overlaps in logical block sequence:
-
-    dmu_zfetch(fffff80198dd0ae0, 27347, 9, 1)
-    dmu_zfetch(fffff80198dd0ae0, 27355, 9, 1)
-    dmu_zfetch(fffff80198dd0ae0, 27363, 9, 1)
-    dmu_zfetch(fffff80198dd0ae0, 27371, 9, 1)
-    dmu_zfetch(fffff80198dd0ae0, 27379, 9, 1)
-    dmu_zfetch(fffff80198dd0ae0, 27387, 9, 1)
-
-This patch makes single block overlap to be counted as a stream hit,
-improving performance up to several times.
-
-Authored by: Alexander Motin <mav@FreeBSD.org>
-Approved by: Gordon Ross <gwr@nexenta.com>
-Reviewed by: Matthew Ahrens <mahrens@delphix.com>
-Reviewed by: Allan Jude <allanjude@freebsd.org>
-Reviewed by: Gvozden Neskovic <neskovic@gmail.com>
-Reviewed by: George Melikov <mail@gmelikov.ru>
-Ported-by: Brian Behlendorf <behlendorf1@llnl.gov>
-
-OpenZFS-issue: https://www.illumos.org/issues/8835
-OpenZFS-commit: https://github.com/openzfs/openzfs/commit/aab6dd482a
-Closes #7062
-
-(cherry picked from commit 701ebd014af3a0c7485056d8c96ecfb379867fd8)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- module/zfs/dmu_zfetch.c | 24 +++++++++++++++++++-----
- 1 file changed, 19 insertions(+), 5 deletions(-)
-
-diff --git a/module/zfs/dmu_zfetch.c b/module/zfs/dmu_zfetch.c
-index 1bf5c4e34..e72e9ef9c 100644
---- a/module/zfs/dmu_zfetch.c
-+++ b/module/zfs/dmu_zfetch.c
-@@ -228,19 +228,33 @@ dmu_zfetch(zfetch_t *zf, uint64_t blkid, uint64_t nblks, boolean_t fetch_data)
-       rw_enter(&zf->zf_rwlock, RW_READER);
-+      /*
-+       * Find matching prefetch stream.  Depending on whether the accesses
-+       * are block-aligned, first block of the new access may either follow
-+       * the last block of the previous access, or be equal to it.
-+       */
-       for (zs = list_head(&zf->zf_stream); zs != NULL;
-           zs = list_next(&zf->zf_stream, zs)) {
--              if (blkid == zs->zs_blkid) {
-+              if (blkid == zs->zs_blkid || blkid + 1 == zs->zs_blkid) {
-                       mutex_enter(&zs->zs_lock);
-                       /*
-                        * zs_blkid could have changed before we
-                        * acquired zs_lock; re-check them here.
-                        */
--                      if (blkid != zs->zs_blkid) {
--                              mutex_exit(&zs->zs_lock);
--                              continue;
-+                      if (blkid == zs->zs_blkid) {
-+                              break;
-+                      } else if (blkid + 1 == zs->zs_blkid) {
-+                              blkid++;
-+                              nblks--;
-+                              if (nblks == 0) {
-+                                      /* Already prefetched this before. */
-+                                      mutex_exit(&zs->zs_lock);
-+                                      rw_exit(&zf->zf_rwlock);
-+                                      return;
-+                              }
-+                              break;
-                       }
--                      break;
-+                      mutex_exit(&zs->zs_lock);
-               }
-       }
--- 
-2.14.2
-
diff --git a/zfs-patches/0033-Cleanup-zloop-working-directory-after-each-pass.patch b/zfs-patches/0033-Cleanup-zloop-working-directory-after-each-pass.patch
deleted file mode 100644 (file)
index 700e98a..0000000
+++ /dev/null
@@ -1,67 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Don Brady <dev.fs.zfs@gmail.com>
-Date: Thu, 21 Sep 2017 11:17:56 -0600
-Subject: [PATCH] Cleanup zloop working directory after each pass
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Reviewed-by: George Melikov <mail@gmelikov.ru>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Reviewed by: John Kennedy <jwk404@gmail.com>
-Reviewed-by: Olaf Faaland <faaland1@llnl.gov>
-Signed-off-by: Don Brady <don.brady@delphix.com>
-Issue #6595
-Closes #6663
-(cherry picked from commit d1630dda5857175bad0ac7f6e142ae299606d88a)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- scripts/zloop.sh | 11 +++++++++--
- 1 file changed, 9 insertions(+), 2 deletions(-)
-
-diff --git a/scripts/zloop.sh b/scripts/zloop.sh
-index 03e825059..f0af87553 100755
---- a/scripts/zloop.sh
-+++ b/scripts/zloop.sh
-@@ -101,6 +101,7 @@ function store_core
- {
-       core="$(core_file)"
-       if [[ $ztrc -ne 0 ]] || [[ -f "$core" ]]; then
-+              df -h "$workdir" >>ztest.out
-               coreid=$(date "+zloop-%y%m%d-%H%M%S")
-               foundcrashes=$((foundcrashes + 1))
-@@ -150,7 +151,8 @@ function store_core
- # parse arguments
- # expected format: zloop [-t timeout] [-c coredir] [-- extra ztest args]
- coredir=$DEFAULTCOREDIR
--workdir=$DEFAULTWORKDIR
-+basedir=$DEFAULTWORKDIR
-+rundir="zloop-run"
- timeout=0
- size="512m"
- while getopts ":ht:s:c:f:" opt; do
-@@ -158,7 +160,7 @@ while getopts ":ht:s:c:f:" opt; do
-               t ) [[ $OPTARG -gt 0 ]] && timeout=$OPTARG ;;
-               s ) [[ $OPTARG ]] && size=$OPTARG ;;
-               c ) [[ $OPTARG ]] && coredir=$OPTARG ;;
--              f ) [[ $OPTARG ]] && workdir=$(readlink -f "$OPTARG") ;;
-+              f ) [[ $OPTARG ]] && basedir=$(readlink -f "$OPTARG") ;;
-               h ) usage
-                   exit 2
-                   ;;
-@@ -202,6 +204,11 @@ curtime=$starttime
- while [[ $timeout -eq 0 ]] || [[ $curtime -le $((starttime + timeout)) ]]; do
-       zopt="-VVVVV"
-+      # start each run with an empty directory
-+      workdir="$basedir/$rundir"
-+      or_die rm -rf "$workdir"
-+      or_die mkdir "$workdir"
-+
-       # switch between common arrangements & fully randomized
-       if [[ $((RANDOM % 2)) -eq 0 ]]; then
-               mirrors=2
--- 
-2.14.2
-
diff --git a/zfs-patches/0034-Extend-zloop.sh-for-automated-testing.patch b/zfs-patches/0034-Extend-zloop.sh-for-automated-testing.patch
deleted file mode 100644 (file)
index a65f83d..0000000
+++ /dev/null
@@ -1,165 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Brian Behlendorf <behlendorf1@llnl.gov>
-Date: Mon, 22 Jan 2018 12:48:39 -0800
-Subject: [PATCH] Extend zloop.sh for automated testing
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-In order to debug issues encountered by ztest during automated
-testing it's important that as much debugging information as
-possible by dumped at the time of the failure.  The following
-changes extend the zloop.sh script in order to make it easier
-to integrate with buildbot.
-
-* Add the `-m <maximum cores>` option to zloop.sh to place a
-  limit of the number of core dumps generated.  By default, the
-  existing behavior is maintained and no limit is set.
-
-* Add the `-l` option to create a 'ztest.core.N' symlink in the
-  current directory to the core directory. This functionality
-  is provided primarily for buildbot which expects log files to
-  have well known names.
-
-* Rename 'ztest.ddt' to 'ztest.zdb' and extend it to dump
-  additional basic information on failure for latter analysis.
-
-Reviewed-by: Tim Chase <tim@chase2k.com>
-Reviewed by: Thomas Caputi <tcaputi@datto.com>
-Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
-Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Closes #6999
-
-Conflicts:
-       scripts/zloop.sh
-(cherry picked from commit 137b3e6cff5552c5b0e137008fd274ad9a6f7a0d)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- scripts/zloop.sh | 42 ++++++++++++++++++++++++++++++++----------
- 1 file changed, 32 insertions(+), 10 deletions(-)
-
-diff --git a/scripts/zloop.sh b/scripts/zloop.sh
-index f0af87553..f39e91ef9 100755
---- a/scripts/zloop.sh
-+++ b/scripts/zloop.sh
-@@ -52,6 +52,8 @@ function usage
-           "    -s  Size of vdev devices.\n" \
-           "    -f  Specify working directory for ztest vdev files.\n" \
-           "    -c  Specify a core dump directory to use.\n" \
-+          "    -m  Max number of core dumps to allow before exiting.\n" \
-+          "    -l  Create 'ztest.core.N' symlink to core directory.\n" \
-           "    -h  Print this help message.\n" \
-           "" >&2
- }
-@@ -105,14 +107,24 @@ function store_core
-               coreid=$(date "+zloop-%y%m%d-%H%M%S")
-               foundcrashes=$((foundcrashes + 1))
-+              # zdb debugging
-+              zdbcmd="$ZDB -U "$workdir/zpool.cache" -dddMmDDG ztest"
-+              zdbdebug=$($zdbcmd 2>&1)
-+              echo -e "$zdbcmd\n" >>ztest.zdb
-+              echo "$zdbdebug" >>ztest.zdb
-+
-               dest=$coredir/$coreid
-               or_die mkdir -p "$dest"
-               or_die mkdir -p "$dest/vdev"
-+              if [[ $symlink -ne 0 ]]; then
-+                      or_die ln -sf "$dest" ztest.core.$foundcrashes
-+              fi
-+
-               echo "*** ztest crash found - moving logs to $dest"
-               or_die mv ztest.history "$dest/"
--              or_die mv ztest.ddt "$dest/"
-+              or_die mv ztest.zdb "$dest/"
-               or_die mv ztest.out "$dest/"
-               or_die mv "$workdir/ztest*" "$dest/vdev/"
-               or_die mv "$workdir/zpool.cache" "$dest/vdev/"
-@@ -120,7 +132,7 @@ function store_core
-               # check for core
-               if [[ -f "$core" ]]; then
-                       coreprog=$(core_prog "$core")
--                      corestatus=$($GDB --batch --quiet \
-+                      coredebug=$($GDB --batch --quiet \
-                           -ex "set print thread-events off" \
-                           -ex "printf \"*\n* Backtrace \n*\n\"" \
-                           -ex "bt" \
-@@ -132,19 +144,25 @@ function store_core
-                           -ex "thread apply all bt" \
-                           -ex "printf \"*\n* Backtraces (full) \n*\n\"" \
-                           -ex "thread apply all bt full" \
--                          -ex "quit" "$coreprog" "$core" | grep -v "New LWP")
-+                          -ex "quit" "$coreprog" "$core" 2>&1 | \
-+                          grep -v "New LWP")
-                       # Dump core + logs to stored directory
--                      echo "$corestatus" >>"$dest/status"
-+                      echo "$coredebug" >>"$dest/ztest.gdb"
-                       or_die mv "$core" "$dest/"
-                       # Record info in cores logfile
-                       echo "*** core @ $coredir/$coreid/$core:" | \
-                           tee -a ztest.cores
--                      echo "$corestatus" | tee -a ztest.cores
--                      echo "" | tee -a ztest.cores
-               fi
--              echo "continuing..."
-+
-+              if [[ $coremax -gt 0 ]] &&
-+                 [[ $foundcrashes -ge $coremax ]]; then
-+                      echo "exiting... max $coremax allowed cores"
-+                      exit 1
-+              else
-+                      echo "continuing..."
-+              fi
-       fi
- }
-@@ -155,12 +173,16 @@ basedir=$DEFAULTWORKDIR
- rundir="zloop-run"
- timeout=0
- size="512m"
--while getopts ":ht:s:c:f:" opt; do
-+coremax=0
-+symlink=0
-+while getopts ":ht:m:s:c:f:l" opt; do
-       case $opt in
-               t ) [[ $OPTARG -gt 0 ]] && timeout=$OPTARG ;;
-+              m ) [[ $OPTARG -gt 0 ]] && coremax=$OPTARG ;;
-               s ) [[ $OPTARG ]] && size=$OPTARG ;;
-               c ) [[ $OPTARG ]] && coredir=$OPTARG ;;
-               f ) [[ $OPTARG ]] && basedir=$(readlink -f "$OPTARG") ;;
-+              l ) symlink=1 ;;
-               h ) usage
-                   exit 2
-                   ;;
-@@ -178,6 +200,7 @@ ulimit -c unlimited
- if [[ -f "$(core_file)" ]]; then
-       echo -n "There's a core dump here you might want to look at first... "
-       core_file
-+      echo
-       exit 1
- fi
-@@ -192,7 +215,7 @@ if [[ ! -w $coredir ]]; then
- fi
- or_die rm -f ztest.history
--or_die rm -f ztest.ddt
-+or_die rm -f ztest.zdb
- or_die rm -f ztest.cores
- ztrc=0                # ztest return value
-@@ -243,7 +266,6 @@ while [[ $timeout -eq 0 ]] || [[ $curtime -le $((starttime + timeout)) ]]; do
-       $cmd >>ztest.out 2>&1
-       ztrc=$?
-       grep -E '===|WARNING' ztest.out >>ztest.history
--      $ZDB -U "$workdir/zpool.cache" -DD ztest >>ztest.ddt
-       store_core
--- 
-2.14.2
-
diff --git a/zfs-patches/0035-Fix-zfs-receive-o-when-used-with-e-d.patch b/zfs-patches/0035-Fix-zfs-receive-o-when-used-with-e-d.patch
deleted file mode 100644 (file)
index ae9dae4..0000000
+++ /dev/null
@@ -1,101 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: LOLi <loli10K@users.noreply.github.com>
-Date: Wed, 31 Jan 2018 00:54:33 +0100
-Subject: [PATCH] Fix 'zfs receive -o' when used with '-e|-d'
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-When used in conjunction with one of '-e' or '-d' zfs receive options
-none of the properties requested to be set (-o) are actually applied:
-this is caused by a wrong assumption made about the toplevel dataset
-in zfs_receive_one().
-
-Fix this by correctly detecting the toplevel dataset.
-
-Reviewed-by: Tony Hutter <hutter2@llnl.gov>
-Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
-Signed-off-by: loli10K <ezomori.nozomu@gmail.com>
-Closes #7088
-
-Requires-spl: refs/pull/679/head
-(cherry picked from commit 2f62fdd6447b1a765dfea3cc5bf9e35dc0901aff)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- lib/libzfs/libzfs_sendrecv.c                       |  5 +--
- .../zfs_receive/receive-o-x_props_override.ksh     | 36 ++++++++++++++++++++++
- 2 files changed, 39 insertions(+), 2 deletions(-)
-
-diff --git a/lib/libzfs/libzfs_sendrecv.c b/lib/libzfs/libzfs_sendrecv.c
-index db8079fb3..ec190022f 100644
---- a/lib/libzfs/libzfs_sendrecv.c
-+++ b/lib/libzfs/libzfs_sendrecv.c
-@@ -3252,7 +3252,7 @@ zfs_receive_one(libzfs_handle_t *hdl, int infd, const char *tosnap,
-       nvlist_t *oxprops = NULL; /* override (-o) and exclude (-x) props */
-       nvlist_t *origprops = NULL; /* original props (if destination exists) */
-       zfs_type_t type;
--      boolean_t toplevel;
-+      boolean_t toplevel = B_FALSE;
-       boolean_t zoned = B_FALSE;
-       begin_time = time(NULL);
-@@ -3586,7 +3586,8 @@ zfs_receive_one(libzfs_handle_t *hdl, int infd, const char *tosnap,
-               goto out;
-       }
--      toplevel = chopprefix[0] != '/';
-+      if (top_zfs && *top_zfs == NULL)
-+              toplevel = B_TRUE;
-       if (drrb->drr_type == DMU_OST_ZVOL) {
-               type = ZFS_TYPE_VOLUME;
-       } else if (drrb->drr_type == DMU_OST_ZFS) {
-diff --git a/tests/zfs-tests/tests/functional/cli_root/zfs_receive/receive-o-x_props_override.ksh b/tests/zfs-tests/tests/functional/cli_root/zfs_receive/receive-o-x_props_override.ksh
-index 7137fe278..e4e69851f 100755
---- a/tests/zfs-tests/tests/functional/cli_root/zfs_receive/receive-o-x_props_override.ksh
-+++ b/tests/zfs-tests/tests/functional/cli_root/zfs_receive/receive-o-x_props_override.ksh
-@@ -371,6 +371,42 @@ log_must eval "check_prop_source $dest type filesystem -"
- log_must eval "check_prop_source $dest atime off local"
- log_must eval "check_prop_source $destsub type volume -"
- log_must eval "check_prop_source $destsub atime - -"
-+# Cleanup
-+log_must zfs destroy -r -f $orig
-+log_must zfs destroy -r -f $dest
-+
-+#
-+# 3.8 Verify 'zfs recv -x|-o' works correctly when used in conjunction with -d
-+#     and -e options.
-+#
-+log_must zfs create -p $orig/1/2/3/4
-+log_must eval "zfs set copies=2 $orig"
-+log_must eval "zfs set atime=on $orig"
-+log_must eval "zfs set '$userprop:orig'='oldval' $orig"
-+log_must zfs snapshot -r $orig@snap1
-+log_must eval "zfs send -R $orig/1/2@snap1 > $streamfile_repl"
-+# Verify 'zfs recv -e'
-+log_must zfs create $dest
-+log_must eval "zfs receive -e -o copies=3 -x atime "\
-+      "-o '$userprop:orig'='newval' $dest < $streamfile_repl"
-+log_must datasetexists $dest/2/3/4
-+log_must eval "check_prop_source $dest/2 copies 3 local"
-+log_must eval "check_prop_inherit $dest/2/3/4 copies $dest/2"
-+log_must eval "check_prop_source $dest/2/3/4 atime on default"
-+log_must eval "check_prop_source $dest/2 '$userprop:orig' 'newval' local"
-+log_must eval "check_prop_inherit $dest/2/3/4 '$userprop:orig' $dest/2"
-+log_must zfs destroy -r -f $dest
-+# Verify 'zfs recv -d'
-+log_must zfs create $dest
-+typeset fs="$(echo $orig | awk -F'/' '{print $NF}')"
-+log_must eval "zfs receive -d -o copies=3 -x atime "\
-+      "-o '$userprop:orig'='newval' $dest < $streamfile_repl"
-+log_must datasetexists $dest/$fs/1/2/3/4
-+log_must eval "check_prop_source $dest/$fs/1/2 copies 3 local"
-+log_must eval "check_prop_inherit $dest/$fs/1/2/3/4 copies $dest/$fs/1/2"
-+log_must eval "check_prop_source $dest/$fs/1/2/3/4 atime on default"
-+log_must eval "check_prop_source $dest/$fs/1/2 '$userprop:orig' 'newval' local"
-+log_must eval "check_prop_inherit $dest/$fs/1/2/3/4 '$userprop:orig' $dest/$fs/1/2"
- # We don't need to cleanup here
- log_pass "ZFS receive property override and exclude options passed."
--- 
-2.14.2
-
diff --git a/zfs-patches/0036-Tag-zfs-0.7.6.patch b/zfs-patches/0036-Tag-zfs-0.7.6.patch
deleted file mode 100644 (file)
index 7c48216..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Tony Hutter <hutter2@llnl.gov>
-Date: Thu, 1 Feb 2018 10:02:58 -0800
-Subject: [PATCH] Tag zfs-0.7.6
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-META file and changelog updated.
-
-Signed-off-by: Tony Hutter <hutter2@llnl.gov>
-(cherry picked from commit e3b28e16ceaf59d7f550a149f863b2cfe67cf4ad)
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- rpm/generic/zfs-kmod.spec.in | 3 +++
- rpm/generic/zfs.spec.in      | 3 +++
- META                         | 2 +-
- 3 files changed, 7 insertions(+), 1 deletion(-)
-
-diff --git a/rpm/generic/zfs-kmod.spec.in b/rpm/generic/zfs-kmod.spec.in
-index f4c92b998..cb23b0a8f 100644
---- a/rpm/generic/zfs-kmod.spec.in
-+++ b/rpm/generic/zfs-kmod.spec.in
-@@ -191,6 +191,9 @@ chmod u+x ${RPM_BUILD_ROOT}%{kmodinstdir_prefix}/*/extra/*/*/*
- rm -rf $RPM_BUILD_ROOT
- %changelog
-+* Thu Feb 01 2018 Tony Hutter <hutter2@llnl.gov> - 0.7.6-1
-+- Released 0.7.6-1, detailed release notes are available at:
-+- https://github.com/zfsonlinux/zfs/releases/tag/zfs-0.7.6
- * Mon Dec 18 2017 Tony Hutter <hutter2@llnl.gov> - 0.7.5-1
- - Released 0.7.5-1, detailed release notes are available at:
- - https://github.com/zfsonlinux/zfs/releases/tag/zfs-0.7.5
-diff --git a/rpm/generic/zfs.spec.in b/rpm/generic/zfs.spec.in
-index afa45268a..8df57fa46 100644
---- a/rpm/generic/zfs.spec.in
-+++ b/rpm/generic/zfs.spec.in
-@@ -333,6 +333,9 @@ exit 0
- %endif
- %changelog
-+* Thu Feb 01 2018 Tony Hutter <hutter2@llnl.gov> - 0.7.6-1
-+- Released 0.7.6-1, detailed release notes are available at:
-+- https://github.com/zfsonlinux/zfs/releases/tag/zfs-0.7.6
- * Mon Dec 18 2017 Tony Hutter <hutter2@llnl.gov> - 0.7.5-1
- - Released 0.7.5-1, detailed release notes are available at:
- - https://github.com/zfsonlinux/zfs/releases/tag/zfs-0.7.5
-diff --git a/META b/META
-index 8bcb520b6..1f4686df7 100644
---- a/META
-+++ b/META
-@@ -1,7 +1,7 @@
- Meta:         1
- Name:         zfs
- Branch:       1.0
--Version:      0.7.5
-+Version:      0.7.6
- Release:      1
- Release-Tags: relext
- License:      CDDL
--- 
-2.14.2
-
diff --git a/zfs-patches/0037-Revert-cherry-pick-fix-distclean-which-removes-neede.patch b/zfs-patches/0037-Revert-cherry-pick-fix-distclean-which-removes-neede.patch
deleted file mode 100644 (file)
index e9e421a..0000000
+++ /dev/null
@@ -1,73 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: =?UTF-8?q?Fabian=20Gr=C3=BCnbichler?= <f.gruenbichler@proxmox.com>
-Date: Wed, 21 Feb 2018 09:40:06 +0100
-Subject: [PATCH] Revert "cherry-pick: fix distclean which removes needed
- files"
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-This reverts commit b7361d56f7039ad69e93e3e9b647da69b5fb647a.
-
-Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
----
- ...g-in-distclean-which-removes-needed-files.patch | 36 ----------------------
- debian/patches/series                              |  1 -
- 2 files changed, 37 deletions(-)
- delete mode 100644 debian/patches/0001-Fix-bug-in-distclean-which-removes-needed-files.patch
-
-diff --git a/debian/patches/0001-Fix-bug-in-distclean-which-removes-needed-files.patch b/debian/patches/0001-Fix-bug-in-distclean-which-removes-needed-files.patch
-deleted file mode 100644
-index e16758b03..000000000
---- a/debian/patches/0001-Fix-bug-in-distclean-which-removes-needed-files.patch
-+++ /dev/null
-@@ -1,36 +0,0 @@
--From b1490dd43e3c98649c7d23928d908f5bb019411b Mon Sep 17 00:00:00 2001
--From: David Quigley <dpquigl@users.noreply.github.com>
--Date: Wed, 13 Sep 2017 12:45:04 -0600
--Subject: [PATCH 001/144] Fix bug in distclean which removes needed files
--
--Running distclean removes the following files because of an error
--in Makefile.am
--
--deleted:    tests/zfs-tests/include/commands.cfg
--deleted:    tests/zfs-tests/include/libtest.shlib
--deleted:    tests/zfs-tests/include/math.shlib
--deleted:    tests/zfs-tests/include/properties.shlib
--deleted:    tests/zfs-tests/include/zpool_script.shlib
--
--Reviewed-by: George Melikov <mail@gmelikov.ru>
--Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
--Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov>
--Signed-off-by: David Quigley <david.quigley@intel.com>
--Closes #6636
-----
-- tests/zfs-tests/include/Makefile.am | 2 +-
-- 1 file changed, 1 insertion(+), 1 deletion(-)
--
--diff --git a/tests/zfs-tests/include/Makefile.am b/tests/zfs-tests/include/Makefile.am
--index 579e1356e..24633ccc3 100644
----- a/tests/zfs-tests/include/Makefile.am
--+++ b/tests/zfs-tests/include/Makefile.am
--@@ -10,4 +10,4 @@ dist_pkgdata_SCRIPTS = \
-- EXTRA_DIST=default.cfg.in
-- 
-- distclean-local::
---     -$(RM) $(dist_pkgdata_SCRIPTS)
--+     -$(RM) default.cfg
---- 
--2.11.0
--
-diff --git a/debian/patches/series b/debian/patches/series
-index e4189aa05..6d5874440 100644
---- a/debian/patches/series
-+++ b/debian/patches/series
-@@ -7,5 +7,4 @@ enable-zed.patch
- 0008-dracut-make-module-setup.sh-shebang-explicit.patch
- 0009-add-man-page-reference-to-systemd-units.patch
- 0010-fix-install-path-of-zpool.d-scripts.patch
--0001-Fix-bug-in-distclean-which-removes-needed-files.patch
- 2000-increase-default-zcmd-allocation-to-256K.patch
--- 
-2.14.2
-
index 78ecd28a42c59293ecd46b8b586e5878c7b0283b..5b7bede078032d52550fe3136323fa0c151358bf 100644 (file)
@@ -1,37 +1,4 @@
 0001-remove-DKMS-modules-and-dracut-build.patch
 0002-import-with-d-dev-disk-by-id-in-scan-service.patch
 0003-Use-user-namespaces-for-FSETID-policy-check.patch
-0004-Fix-ARC-hit-rate.patch
-0005-always-load-ZFS-module-on-boot.patch
-0006-Use-sbin-openrc-run-for-openrc-init-scripts.patch
-0007-vdev_mirror-load-balancing-fixes.patch
-0008-Fix-zfs_ioc_pool_sync-should-not-use-fnvlist.patch
-0009-dmu_objset-release-bonus-buffer-in-failure-path.patch
-0010-Fix-bug-in-distclean-which-removes-needed-files.patch
-0011-Rewrite-of-function-fBytes-in-arc_summary.py.patch
-0012-Minor-code-cleanup-in-arc_summary.py.patch
-0013-Rewrite-fHits-in-arc_summary.py-with-SI-units.patch
-0014-Add-documentation-strings-to-arc_summary.py.patch
-0015-Sort-output-of-tunables-in-arc_summary.py.patch
-0016-Fix-arc_summary.py-d-crash-with-Python3.patch
-0017-Minor-code-cleanups-in-arc_python.py.patch
-0018-Fix-data-on-evict_skips-in-arc_summary.py.patch
-0019-Update-for-cppcheck-v1.80.patch
-0020-OpenZFS-8794-cstyle-generates-warnings-with-recent-p.patch
-0021-Handle-invalid-options-in-arc_summary.patch
-0022-Handle-broken-pipes-in-arc_summary.patch
-0023-Call-commit-callbacks-from-the-tail-of-the-list.patch
-0024-Fix-zpool-add-handling-of-nested-interior-VDEVs.patch
-0025-zhack-fix-getopt-return-type.patch
-0026-Revert-raidz_map-and-_col-structure-types.patch
-0027-Use-zap_count-instead-of-cached-z_size-for-unlink.patch
-0028-Fix-incompatibility-with-Reiser4-patched-kernels.patch
-0029-Remove-l2arc_nocompress-from-zfs-module-parameters-5.patch
-0030-Fix-shellcheck-v0.4.6-warnings.patch
-0031-Fix-Debian-packaging-on-ARMv7-ARM64.patch
-0032-OpenZFS-8835-Speculative-prefetch-in-ZFS-not-working.patch
-0033-Cleanup-zloop-working-directory-after-each-pass.patch
-0034-Extend-zloop.sh-for-automated-testing.patch
-0035-Fix-zfs-receive-o-when-used-with-e-d.patch
-0036-Tag-zfs-0.7.6.patch
-0037-Revert-cherry-pick-fix-distclean-which-removes-neede.patch
+0004-always-load-ZFS-module-on-boot.patch