-Subproject commit 5601d8209e1588bed0aaecd98e914cc5b649b6bf
+Subproject commit 751356d3540d352bb6d27a20d584a020db1b4e1d
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
-
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
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
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
+ 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'
+++ /dev/null
-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
-
--- /dev/null
+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
+
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
+++ /dev/null
-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
-
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