add remaining spl-0.7.6 changes as patches
since Debian unstable has not been updated yet
This commit is contained in:
		
							parent
							
								
									b199710aee
								
							
						
					
					
						commit
						c43065ced4
					
				
							
								
								
									
										143
									
								
								spl-patches/0002-Linux-4.15-compat-timer-updates.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										143
									
								
								spl-patches/0002-Linux-4.15-compat-timer-updates.patch
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,143 @@
 | 
			
		||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Tony Hutter <hutter2@llnl.gov>
 | 
			
		||||
Date: Thu, 21 Dec 2017 10:56:32 -0800
 | 
			
		||||
Subject: [PATCH] Linux 4.15 compat: timer updates
 | 
			
		||||
MIME-Version: 1.0
 | 
			
		||||
Content-Type: text/plain; charset=UTF-8
 | 
			
		||||
Content-Transfer-Encoding: 8bit
 | 
			
		||||
 | 
			
		||||
Use timer_setup() macro and new timeout function definition.
 | 
			
		||||
 | 
			
		||||
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
 | 
			
		||||
Signed-off-by: Tony Hutter <hutter2@llnl.gov>
 | 
			
		||||
Closes #670
 | 
			
		||||
Closes #671
 | 
			
		||||
(cherry picked from commit 71513af020c0522560dc86668db46b49068787b3)
 | 
			
		||||
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
 | 
			
		||||
---
 | 
			
		||||
 module/spl/spl-taskq.c | 27 +++++++++++++++++++++++++--
 | 
			
		||||
 config/spl-build.m4    | 34 ++++++++++++++++++++++++++++++++++
 | 
			
		||||
 2 files changed, 59 insertions(+), 2 deletions(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/module/spl/spl-taskq.c b/module/spl/spl-taskq.c
 | 
			
		||||
index 7cad9f7..89c53a5 100644
 | 
			
		||||
--- a/module/spl/spl-taskq.c
 | 
			
		||||
+++ b/module/spl/spl-taskq.c
 | 
			
		||||
@@ -209,9 +209,9 @@ task_done(taskq_t *tq, taskq_ent_t *t)
 | 
			
		||||
  * add it to the priority list in order for immediate processing.
 | 
			
		||||
  */
 | 
			
		||||
 static void
 | 
			
		||||
-task_expire(unsigned long data)
 | 
			
		||||
+task_expire_impl(taskq_ent_t *t)
 | 
			
		||||
 {
 | 
			
		||||
-	taskq_ent_t *w, *t = (taskq_ent_t *)data;
 | 
			
		||||
+	taskq_ent_t *w;
 | 
			
		||||
 	taskq_t *tq = t->tqent_taskq;
 | 
			
		||||
 	struct list_head *l;
 | 
			
		||||
 	unsigned long flags;
 | 
			
		||||
@@ -245,6 +245,21 @@ task_expire(unsigned long data)
 | 
			
		||||
 	wake_up(&tq->tq_work_waitq);
 | 
			
		||||
 }
 | 
			
		||||
 
 | 
			
		||||
+#ifdef HAVE_KERNEL_TIMER_FUNCTION_TIMER_LIST
 | 
			
		||||
+static void
 | 
			
		||||
+task_expire(struct timer_list *tl)
 | 
			
		||||
+{
 | 
			
		||||
+	taskq_ent_t *t = from_timer(t, tl, tqent_timer);
 | 
			
		||||
+	task_expire_impl(t);
 | 
			
		||||
+}
 | 
			
		||||
+#else
 | 
			
		||||
+static void
 | 
			
		||||
+task_expire(unsigned long data)
 | 
			
		||||
+{
 | 
			
		||||
+	task_expire_impl((taskq_ent_t *)data);
 | 
			
		||||
+}
 | 
			
		||||
+#endif
 | 
			
		||||
+
 | 
			
		||||
 /*
 | 
			
		||||
  * Returns the lowest incomplete taskqid_t.  The taskqid_t may
 | 
			
		||||
  * be queued on the pending list, on the priority list, on the
 | 
			
		||||
@@ -590,7 +605,9 @@ taskq_dispatch(taskq_t *tq, task_func_t func, void *arg, uint_t flags)
 | 
			
		||||
 	t->tqent_func = func;
 | 
			
		||||
 	t->tqent_arg = arg;
 | 
			
		||||
 	t->tqent_taskq = tq;
 | 
			
		||||
+#ifndef HAVE_KERNEL_TIMER_FUNCTION_TIMER_LIST
 | 
			
		||||
 	t->tqent_timer.data = 0;
 | 
			
		||||
+#endif
 | 
			
		||||
 	t->tqent_timer.function = NULL;
 | 
			
		||||
 	t->tqent_timer.expires = 0;
 | 
			
		||||
 	t->tqent_birth = jiffies;
 | 
			
		||||
@@ -640,7 +657,9 @@ taskq_dispatch_delay(taskq_t *tq, task_func_t func, void *arg,
 | 
			
		||||
 	t->tqent_func = func;
 | 
			
		||||
 	t->tqent_arg = arg;
 | 
			
		||||
 	t->tqent_taskq = tq;
 | 
			
		||||
+#ifndef HAVE_KERNEL_TIMER_FUNCTION_TIMER_LIST
 | 
			
		||||
 	t->tqent_timer.data = (unsigned long)t;
 | 
			
		||||
+#endif
 | 
			
		||||
 	t->tqent_timer.function = task_expire;
 | 
			
		||||
 	t->tqent_timer.expires = (unsigned long)expire_time;
 | 
			
		||||
 	add_timer(&t->tqent_timer);
 | 
			
		||||
@@ -732,7 +751,11 @@ taskq_init_ent(taskq_ent_t *t)
 | 
			
		||||
 {
 | 
			
		||||
 	spin_lock_init(&t->tqent_lock);
 | 
			
		||||
 	init_waitqueue_head(&t->tqent_waitq);
 | 
			
		||||
+#ifdef HAVE_KERNEL_TIMER_FUNCTION_TIMER_LIST
 | 
			
		||||
+	timer_setup(&t->tqent_timer, NULL, 0);
 | 
			
		||||
+#else
 | 
			
		||||
 	init_timer(&t->tqent_timer);
 | 
			
		||||
+#endif
 | 
			
		||||
 	INIT_LIST_HEAD(&t->tqent_list);
 | 
			
		||||
 	t->tqent_id = 0;
 | 
			
		||||
 	t->tqent_func = NULL;
 | 
			
		||||
diff --git a/config/spl-build.m4 b/config/spl-build.m4
 | 
			
		||||
index accf675..25013b5 100644
 | 
			
		||||
--- a/config/spl-build.m4
 | 
			
		||||
+++ b/config/spl-build.m4
 | 
			
		||||
@@ -56,6 +56,7 @@ AC_DEFUN([SPL_AC_CONFIG_KERNEL], [
 | 
			
		||||
 	SPL_AC_WAIT_QUEUE_HEAD_ENTRY
 | 
			
		||||
 	SPL_AC_KERNEL_WRITE
 | 
			
		||||
 	SPL_AC_KERNEL_READ
 | 
			
		||||
+	SPL_AC_KERNEL_TIMER_FUNCTION_TIMER_LIST
 | 
			
		||||
 ])
 | 
			
		||||
 
 | 
			
		||||
 AC_DEFUN([SPL_AC_MODULE_SYMVERS], [
 | 
			
		||||
@@ -1755,3 +1756,36 @@ AC_DEFUN([SPL_AC_KERNEL_READ], [
 | 
			
		||||
 	])
 | 
			
		||||
 	EXTRA_KCFLAGS="$tmp_flags"
 | 
			
		||||
 ])
 | 
			
		||||
+
 | 
			
		||||
+dnl #
 | 
			
		||||
+dnl # 4.15 API change
 | 
			
		||||
+dnl # https://lkml.org/lkml/2017/11/25/90
 | 
			
		||||
+dnl # Check if timer_list.func get passed a timer_list or an unsigned long
 | 
			
		||||
+dnl # (older kernels).  Also sanity check the from_timer() and timer_setup()
 | 
			
		||||
+dnl # macros are available as well, since they will be used in the same newer
 | 
			
		||||
+dnl # kernels that support the new timer_list.func signature.
 | 
			
		||||
+dnl #
 | 
			
		||||
+AC_DEFUN([SPL_AC_KERNEL_TIMER_FUNCTION_TIMER_LIST], [
 | 
			
		||||
+	AC_MSG_CHECKING([whether timer_list.function gets a timer_list])
 | 
			
		||||
+	tmp_flags="$EXTRA_KCFLAGS"
 | 
			
		||||
+	EXTRA_KCFLAGS="-Werror"
 | 
			
		||||
+	SPL_LINUX_TRY_COMPILE([
 | 
			
		||||
+		#include <linux/timer.h>
 | 
			
		||||
+		void task_expire(struct timer_list *tl) {}
 | 
			
		||||
+	],[
 | 
			
		||||
+		#ifndef from_timer
 | 
			
		||||
+		#error "No from_timer() macro"
 | 
			
		||||
+		#endif
 | 
			
		||||
+
 | 
			
		||||
+		struct timer_list timer;
 | 
			
		||||
+		timer.function = task_expire;
 | 
			
		||||
+		timer_setup(&timer, NULL, 0);
 | 
			
		||||
+	],[
 | 
			
		||||
+		AC_MSG_RESULT(yes)
 | 
			
		||||
+		AC_DEFINE(HAVE_KERNEL_TIMER_FUNCTION_TIMER_LIST, 1,
 | 
			
		||||
+		    [timer_list.function gets a timer_list])
 | 
			
		||||
+	],[
 | 
			
		||||
+		AC_MSG_RESULT(no)
 | 
			
		||||
+	])
 | 
			
		||||
+	EXTRA_KCFLAGS="$tmp_flags"
 | 
			
		||||
+])
 | 
			
		||||
-- 
 | 
			
		||||
2.14.2
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										65
									
								
								spl-patches/0003-Fix-Debian-packaging-on-ARMv7-ARM64.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								spl-patches/0003-Fix-Debian-packaging-on-ARMv7-ARM64.patch
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,65 @@
 | 
			
		||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: LOLi <loli10K@users.noreply.github.com>
 | 
			
		||||
Date: Thu, 18 Jan 2018 19:14:18 +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 zfsonlinux/zfs#7046
 | 
			
		||||
Closes #678
 | 
			
		||||
(cherry picked from commit 9ee1fc8b4cb7fdcda88e161d9fc2bbe50427972c)
 | 
			
		||||
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 e05a175..f745c91 100644
 | 
			
		||||
--- a/config/deb.am
 | 
			
		||||
+++ b/config/deb.am
 | 
			
		||||
@@ -32,24 +32,27 @@ 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
 | 
			
		||||
 
 | 
			
		||||
 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; \
 | 
			
		||||
-	fakeroot $(ALIEN) --bump=0 --scripts --to-deb $$pkg1; \
 | 
			
		||||
+	fakeroot $(ALIEN) --bump=0 --scripts --to-deb --target=$$debarch $$pkg1; \
 | 
			
		||||
 	$(RM) $$pkg1
 | 
			
		||||
 
 | 
			
		||||
 deb: deb-kmod deb-dkms deb-utils
 | 
			
		||||
-- 
 | 
			
		||||
2.14.2
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										63
									
								
								spl-patches/0004-Tag-spl-0.7.6.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								spl-patches/0004-Tag-spl-0.7.6.patch
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,63 @@
 | 
			
		||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Tony Hutter <hutter2@llnl.gov>
 | 
			
		||||
Date: Thu, 1 Feb 2018 10:02:27 -0800
 | 
			
		||||
Subject: [PATCH] Tag spl-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 3cc0ea2a461788408aa2325e8ecb4e7f209633a8)
 | 
			
		||||
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
 | 
			
		||||
---
 | 
			
		||||
 rpm/generic/spl-kmod.spec.in | 3 +++
 | 
			
		||||
 rpm/generic/spl.spec.in      | 3 +++
 | 
			
		||||
 META                         | 2 +-
 | 
			
		||||
 3 files changed, 7 insertions(+), 1 deletion(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/rpm/generic/spl-kmod.spec.in b/rpm/generic/spl-kmod.spec.in
 | 
			
		||||
index af7132d..eb38c21 100644
 | 
			
		||||
--- a/rpm/generic/spl-kmod.spec.in
 | 
			
		||||
+++ b/rpm/generic/spl-kmod.spec.in
 | 
			
		||||
@@ -167,6 +167,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/spl.spec.in b/rpm/generic/spl.spec.in
 | 
			
		||||
index f619475..0338a47 100644
 | 
			
		||||
--- a/rpm/generic/spl.spec.in
 | 
			
		||||
+++ b/rpm/generic/spl.spec.in
 | 
			
		||||
@@ -34,6 +34,9 @@ make install DESTDIR=%{?buildroot}
 | 
			
		||||
 %{_mandir}/man5/*
 | 
			
		||||
 
 | 
			
		||||
 %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 c66cd11..4b0c0bb 100644
 | 
			
		||||
--- a/META
 | 
			
		||||
+++ b/META
 | 
			
		||||
@@ -1,7 +1,7 @@
 | 
			
		||||
 Meta:         1
 | 
			
		||||
 Name:         spl
 | 
			
		||||
 Branch:       1.0
 | 
			
		||||
-Version:      0.7.5
 | 
			
		||||
+Version:      0.7.6
 | 
			
		||||
 Release:      1
 | 
			
		||||
 Release-Tags: relext
 | 
			
		||||
 License:      GPL
 | 
			
		||||
-- 
 | 
			
		||||
2.14.2
 | 
			
		||||
 | 
			
		||||
@ -1 +1,4 @@
 | 
			
		||||
0001-remove-DKMS-and-module-build.patch
 | 
			
		||||
0002-Linux-4.15-compat-timer-updates.patch
 | 
			
		||||
0003-Fix-Debian-packaging-on-ARMv7-ARM64.patch
 | 
			
		||||
0004-Tag-spl-0.7.6.patch
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user