SHA256
1
0
forked from pool/drbd

Accepting request 437365 from home:wanghaisu:branches:network:ha-clustering:Factory

bsc#1006176, compat with kernel 4.8 with 9.0.5

OBS-URL: https://build.opensuse.org/request/show/437365
OBS-URL: https://build.opensuse.org/package/show/network:ha-clustering:Factory/drbd?expand=0&rev=36
This commit is contained in:
nick wang 2016-10-26 03:56:30 +00:00 committed by Git OBS Bridge
parent 524400d0e7
commit 73a7d7f261
12 changed files with 34 additions and 176 deletions

View File

@ -7,10 +7,10 @@
To update to a new release, change "revision" to the desired To update to a new release, change "revision" to the desired
git commit hash and bump "version" if necessary git commit hash and bump "version" if necessary
<param name="version">9.0.2</param> <param name="version">9.0.5</param>
--> -->
<param name="versionformat">9.0.2+git.%h</param> <param name="versionformat">9.0.5+git.%h</param>
<param name="revision">14d2eead95f99a7de1c0b3e3f335a30b8d486bcb</param> <param name="revision">8d53d3e73f85f8d98f100a0127ccb574a97c5f64</param>
</service> </service>
<service name="recompress" mode="disabled"> <service name="recompress" mode="disabled">

View File

@ -1,34 +0,0 @@
diff -Naur drbd-9.0.2+git.14d2eea.orig/drbd-headers/linux/genl_magic_struct.h drbd-9.0.2+git.14d2eea/drbd-headers/linux/genl_magic_struct.h
--- drbd-9.0.2+git.14d2eea.orig/drbd-headers/linux/genl_magic_struct.h 2016-06-09 08:08:48.682443819 +0800
+++ drbd-9.0.2+git.14d2eea/drbd-headers/linux/genl_magic_struct.h 2016-06-09 21:58:38.138780397 +0800
@@ -13,7 +13,7 @@
# error "you need to define GENL_MAGIC_INCLUDE_FILE before inclusion"
#endif
-#include <linux/netlink.h>
+#include <net/netlink.h>
#include <linux/genetlink.h>
#include <linux/types.h>
#include "compat.h"
@@ -86,9 +86,21 @@
__field(attr_nr, attr_flag, name, NLA_U32, __s32, \
nla_get_u32, nla_put_u32, true)
#endif
+#ifdef COMPAT_HAVE_ALIGNED_NLA_U64_PAD
#define __u64_field(attr_nr, attr_flag, name) \
__field(attr_nr, attr_flag, name, NLA_U64, __u64, \
nla_get_u64, nla_put_u64, false)
+#else
+
+static inline int nla_put_u64_0pad(struct sk_buff *skb, int attrtype, u64 value)
+{
+ return nla_put_64bit(skb, attrtype, sizeof(u64), &value, 0);
+}
+
+#define __u64_field(attr_nr, attr_flag, name) \
+ __field(attr_nr, attr_flag, name, NLA_U64, __u64, \
+ nla_get_u64, nla_put_u64_0pad, false)
+#endif
#define __str_field(attr_nr, attr_flag, name, maxlen) \
__array(attr_nr, attr_flag, name, NLA_NUL_STRING, char, maxlen, \
nla_strlcpy, nla_put, false)

View File

@ -1,10 +0,0 @@
diff -Naur drbd-9.0.2+git.14d2eea.orig/drbd/drbd-kernel-compat/tests/have_aligned_nla_u64_pad.c drbd-9.0.2+git.14d2eea/drbd/drbd-kernel-compat/tests/have_aligned_nla_u64_pad.c
--- drbd-9.0.2+git.14d2eea.orig/drbd/drbd-kernel-compat/tests/have_aligned_nla_u64_pad.c 1970-01-01 08:00:00.000000000 +0800
+++ drbd-9.0.2+git.14d2eea/drbd/drbd-kernel-compat/tests/have_aligned_nla_u64_pad.c 2016-06-09 07:56:36.081322856 +0800
@@ -0,0 +1,6 @@
+#include <net/netlink.h>
+
+void foo(void)
+{
+ nla_put_u64(NULL, 0, 0);
+}

View File

@ -1,31 +0,0 @@
diff --git a/drbd/drbd_debugfs.c b/drbd/drbd_debugfs.c
index 91292c3..959a576 100644
--- a/drbd/drbd_debugfs.c
+++ b/drbd/drbd_debugfs.c
@@ -1074,7 +1074,7 @@ static int drbd_single_open_peer_device(struct file *file,
parent = file->f_path.dentry->d_parent;
if (!parent || !parent->d_inode)
goto out;
- mutex_lock(&parent->d_inode->i_mutex);
+ inode_lock(d_inode(parent));
if (!simple_positive(file->f_path.dentry))
goto out_unlock;
@@ -1083,7 +1083,7 @@ static int drbd_single_open_peer_device(struct file *file,
if (got_connection && got_device) {
int ret;
- mutex_unlock(&parent->d_inode->i_mutex);
+ inode_unlock(d_inode(parent));
ret = single_open(file, show, peer_device);
if (ret) {
kref_put(&connection->kref, drbd_destroy_connection);
@@ -1097,7 +1097,7 @@ static int drbd_single_open_peer_device(struct file *file,
if (got_device)
kref_put(&device->kref, drbd_destroy_device);
out_unlock:
- mutex_unlock(&parent->d_inode->i_mutex);
+ inode_unlock(d_inode(parent));
out:
return -ESTALE;
}

View File

@ -1,24 +0,0 @@
diff -Naur drbd-9.0.2+git.14d2eea.orig/drbd/drbd-kernel-compat/drbd_wrappers.h drbd-9.0.2+git.14d2eea/drbd/drbd-kernel-compat/drbd_wrappers.h
--- drbd-9.0.2+git.14d2eea.orig/drbd/drbd-kernel-compat/drbd_wrappers.h 2016-06-08 17:52:23.920376490 +0800
+++ drbd-9.0.2+git.14d2eea/drbd/drbd-kernel-compat/drbd_wrappers.h 2016-06-08 21:14:33.692708703 +0800
@@ -677,6 +677,10 @@
#define blk_queue_max_hw_sectors(q, max) blk_queue_max_sectors(q, max)
#endif
+#ifndef COMPAT_HAVE_BLK_QUEUE_FLUSH
+#define blk_queue_flush(q, f) blk_queue_write_cache(q, true, true)
+#endif
+
#ifndef COMPAT_HAVE_BLK_QUEUE_MAX_SEGMENTS
static inline void blk_queue_max_segments(struct request_queue *q, unsigned short max_segments)
{
diff -Naur drbd-9.0.2+git.14d2eea.orig/drbd/drbd-kernel-compat/tests/have_blk_queue_flush.c drbd-9.0.2+git.14d2eea/drbd/drbd-kernel-compat/tests/have_blk_queue_flush.c
--- drbd-9.0.2+git.14d2eea.orig/drbd/drbd-kernel-compat/tests/have_blk_queue_flush.c 1970-01-01 08:00:00.000000000 +0800
+++ drbd-9.0.2+git.14d2eea/drbd/drbd-kernel-compat/tests/have_blk_queue_flush.c 2016-06-08 21:13:40.324918430 +0800
@@ -0,0 +1,6 @@
+#include <linux/blkdev.h>
+
+void dummy(struct request_queue *q, unsigned int flush)
+{
+ blk_queue_flush(q, flush);
+}

View File

@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:e6b1003e42a0541b5a589d4576a8e4271e17aafbf595df40fd4b91cf87432d6e
size 288998

View File

@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:3fff0223e279ed5f09c785bda8a8eb2cbf314a22267bd5e57c648171059b2759
size 297575

View File

@ -1,10 +0,0 @@
diff -Naur drbd-9.0.1+git.86e4439.orig/drbd/Kbuild drbd-9.0.1+git.86e4439/drbd/Kbuild
--- drbd-9.0.1+git.86e4439.orig/drbd/Kbuild 2016-04-13 21:42:44.957501769 +0800
+++ drbd-9.0.1+git.86e4439/drbd/Kbuild 2016-04-13 21:43:05.622500374 +0800
@@ -133,5 +133,5 @@
echo >&2 "Your DRBD source tree is broken. Unpack again."; \
exit 1; \
fi ; \
- echo -e "\t\t\" build by $$USER@$$HOSTNAME, `date "+%F %T"`\";\n}"; \
+ echo -e "\t\t\" build by $$USER\";\n}"; \
mv -f $@.new $@

View File

@ -1,3 +1,20 @@
-------------------------------------------------------------------
Mon Oct 24 06:35:26 UTC 2016 - nwang@suse.com
- bsc#1006176, compat with kernel 4.8 with 9.0.5
-------------------------------------------------------------------
Mon Oct 24 06:33:56 UTC 2016 - nwang@suse.com
- Upgrade 9.0.2 to 9.0.5
- Remove patch compat-4.7-9902af79-i_mutex.patch
Remove patch compat-4.7-fe8fb75e-blk_queue_write_cache.patch
Remove patch compat-4.7-50225243-kill-nla_put_u64.patch
Remove patch compat-4.7-1dee3f59-align-nla-u64.patch
Remove patch drbd-buildcompare.patch
Remove patch kernel-4.5-compat.patch
Remove patch temp.patch
------------------------------------------------------------------- -------------------------------------------------------------------
Wed Jun 8 06:03:05 UTC 2016 - nwang@suse.com Wed Jun 8 06:03:05 UTC 2016 - nwang@suse.com

View File

@ -23,7 +23,7 @@
%endif %endif
Name: drbd Name: drbd
Version: 9.0.2+git.14d2eea Version: 9.0.5+git.8d53d3e
Release: 0 Release: 0
Summary: DRBD driver for Linux Summary: DRBD driver for Linux
License: GPL-2.0 License: GPL-2.0
@ -34,29 +34,19 @@ Source1: preamble
#In kernel is: kernel/drivers/block/drbd/drbd.ko #In kernel is: kernel/drivers/block/drbd/drbd.ko
Source2: Module.supported Source2: Module.supported
Source3: drbd_git_revision Source3: drbd_git_revision
Patch0: drbd-buildcompare.patch
Patch1: kernel-4.5-compat.patch
Patch2: compat-4.7-9902af79-i_mutex.patch
Patch3: compat-4.7-fe8fb75e-blk_queue_write_cache.patch
#Patch4 should work together with Patch5
Patch4: compat-4.7-50225243-kill-nla_put_u64.patch
Patch5: compat-4.7-1dee3f59-align-nla-u64.patch
BuildRequires: kernel-source BuildRequires: kernel-source
BuildRequires: kernel-syms BuildRequires: kernel-syms
BuildRequires: module-init-tools BuildRequires: module-init-tools
%if 0%{?buildrt} == 1
BuildRequires: kernel-source-rt
BuildRequires: kernel-syms-rt
%endif
Requires: drbd-utils >= 8.9.6 Requires: drbd-utils >= 8.9.6
Supplements: drbd-utils >= 8.9.6 Supplements: drbd-utils >= 8.9.6
Obsoletes: drbd-kmp < %{version} Obsoletes: drbd-kmp < %{version}
BuildRoot: %{_tmppath}/%{name}-%{version}-build BuildRoot: %{_tmppath}/%{name}-%{version}-build
ExcludeArch: i586 s390 ExcludeArch: i586 s390
%kernel_module_package -n drbd -p %{_sourcedir}/preamble
%kernel_module_package -n drbd -p %_sourcedir/preamble %if 0%{?buildrt} == 1
BuildRequires: kernel-source-rt
BuildRequires: kernel-syms-rt
%endif
%description %description
Drbd is a distributed replicated block device. It mirrors a block Drbd is a distributed replicated block device. It mirrors a block
@ -66,20 +56,15 @@ raid 1. It is a building block for setting up clusters.
%package KMP %package KMP
Summary: Kernel driver for DRBD Summary: Kernel driver for DRBD
Group: Productivity/Clustering/HA Group: Productivity/Clustering/HA
Url: http://drbd.linbit.com/
%description KMP %description KMP
This module is the kernel-dependent driver for DRBD. This is split out so This module is the kernel-dependent driver for DRBD. This is split out so
that multiple kernel driver versions can be installed, one for each that multiple kernel driver versions can be installed, one for each
installed kernel. installed kernel.
%prep %prep
%setup -q -n drbd-%{version} %setup -q -n drbd-%{version}
%patch0 -p1
%patch1 -p1
%patch2 -p1
%patch3 -p1
%patch4 -p1
%patch5 -p1
mkdir source mkdir source
cp -a drbd/. source/. || : cp -a drbd/. source/. || :
@ -93,10 +78,10 @@ ln -s ../scripts obj/
export CONFIG_BLK_DEV_DRBD=m export CONFIG_BLK_DEV_DRBD=m
export EXTRA_CFLAGS='-DVERSION=\"%{version}\"' export EXTRA_CFLAGS='-DVERSION=\"%{version}\"'
for flavor in %flavors_to_build; do for flavor in %{flavors_to_build}; do
rm -rf $flavor rm -rf $flavor
cp -r source $flavor cp -r source $flavor
cp %_sourcedir/Module.supported $flavor cp %{_sourcedir}/Module.supported $flavor
export DRBDSRC="$PWD/obj/$flavor" export DRBDSRC="$PWD/obj/$flavor"
make -C %{kernel_source $flavor} modules M=$PWD/$flavor make -C %{kernel_source $flavor} modules M=$PWD/$flavor
done done

View File

@ -1 +1 @@
GIT-hash: 14d2eead95f99a7de1c0b3e3f335a30b8d486bcb GIT-hash: c7888383cd94c74c84705d73b41fbfc41d4d6676

View File

@ -1,35 +0,0 @@
diff -Naur drbd-9.0.1+git.86e4439.orig/drbd/drbd-kernel-compat/drbd_wrappers.h drbd-9.0.1+git.86e4439/drbd/drbd-kernel-compat/drbd_wrappers.h
--- drbd-9.0.1+git.86e4439.orig/drbd/drbd-kernel-compat/drbd_wrappers.h 2016-04-08 21:56:02.872683041 +0800
+++ drbd-9.0.1+git.86e4439/drbd/drbd-kernel-compat/drbd_wrappers.h 2016-04-08 22:03:05.732665258 +0800
@@ -1529,31 +1529,6 @@
}
#endif
-#ifndef COMPAT_HAVE_IB_CQ_INIT_ATTR
-#include <rdma/ib_verbs.h>
-
-struct ib_cq_init_attr {
- unsigned int cqe;
- int comp_vector;
- u32 flags;
-};
-
-static inline struct ib_cq *
-drbd_ib_create_cq(struct ib_device *device,
- ib_comp_handler comp_handler,
- void (*event_handler)(struct ib_event *, void *),
- void *cq_context,
- const struct ib_cq_init_attr *cq_attr)
-{
- return ib_create_cq(device, comp_handler, event_handler, cq_context,
- cq_attr->cqe, cq_attr->comp_vector);
-}
-
-#define ib_create_cq(DEV, COMP_H, EVENT_H, CTX, ATTR) \
- drbd_ib_create_cq(DEV, COMP_H, EVENT_H, CTX, ATTR)
-#endif
-
-
#ifndef COMPAT_RDMA_CREATE_ID_HAS_NET_NS
/* Since linux v4.4 it has a network namespace as first argument */
#define rdma_create_id(NS, H, C, P, T) rdma_create_id(H, C, P, T)