summaryrefslogtreecommitdiff
blob: eb418ccc957a91f7222670c1334b59cff434082d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
diff --git a/driver/linux/check_kernel_headers.sh b/driver/linux/check_kernel_headers.sh
index b0b9b851c0a1..7afec9fae138 100755
--- a/driver/linux/check_kernel_headers.sh
+++ b/driver/linux/check_kernel_headers.sh
@@ -330,6 +330,19 @@ else
   echo no
 fi
 
+# timer_setup() added in v4.14-rc3
+echo -n "  checking (in kernel headers) timer_setup() availability ... "
+if test -e ${LINUX_HDR}/include/linux/timer.h > /dev/null ; then
+  if grep timer_setup ${LINUX_HDR}/include/linux/timer.h > /dev/null ; then
+    echo "#define HAVE_TIMER_SETUP 1" >> ${TMP_CHECKS_NAME}
+    echo yes
+  else
+    echo no
+  fi
+else
+  echo no
+fi
+
 # add the footer
 echo "" >> ${TMP_CHECKS_NAME}
 echo "#endif /* __knem_checks_h__ */" >> ${TMP_CHECKS_NAME}
diff --git a/driver/linux/knem_main.c b/driver/linux/knem_main.c
index e12aad3c0ea5..ddae2af14449 100644
--- a/driver/linux/knem_main.c
+++ b/driver/linux/knem_main.c
@@ -2610,9 +2610,17 @@ knem_kthread_func(void *data)
 
 #ifdef KNEM_HAVE_DMA_ENGINE
 static void
+#ifdef HAVE_TIMER_SETUP
+knem_dmacpy_cleanup_timer_handler(struct timer_list *t)
+#else
 knem_dmacpy_cleanup_timer_handler(unsigned long data)
+#endif
 {
+#ifdef HAVE_TIMER_SETUP
+	struct knem_context * ctx = from_timer(ctx, t, dmacpy_cleanup_timer);
+#else
 	struct knem_context * ctx = (void *) data;
+#endif
 
 	wake_up(&ctx->kthread_work_wq);
 	knem_counter_inc(DMACPY_CLEANUP_TIMEOUT);
@@ -2665,7 +2673,11 @@ knem_miscdev_open(struct inode * inode, struct file * file)
 	if (ctx->dmacpy_chan) {
 		INIT_LIST_HEAD(&ctx->dmacpy_cleanup_work_list);
 		spin_lock_init(&ctx->dmacpy_cleanup_work_lock);
+#ifdef HAVE_TIMER_SETUP
+		timer_setup(&ctx->dmacpy_cleanup_timer, knem_dmacpy_cleanup_timer_handler, 0);
+#else
 		setup_timer(&ctx->dmacpy_cleanup_timer, knem_dmacpy_cleanup_timer_handler, (unsigned long) ctx);
+#endif
 #if (defined CONFIG_NUMA) && (defined KNEM_HAVE_CPUMASK_OF_NODE)
 		{
 			int node = dev_to_node(ctx->dmacpy_chan->device->dev);