Prechádzať zdrojové kódy

Merge pull request #189 from linD026/master

Improve the compatibility and fix the missing header
Jim Huang 2 rokov pred
rodič
commit
45ac4087d0
2 zmenil súbory, kde vykonal 10 pridanie a 0 odobranie
  1. 1 0
      examples/chardev2.c
  2. 9 0
      examples/completions.c

+ 1 - 0
examples/chardev2.c

@@ -11,6 +11,7 @@
 #include <linux/module.h> /* Specifically, a module */
 #include <linux/printk.h>
 #include <linux/types.h>
+#include <linux/uaccess.h> /* for get_user and put_user */
 
 #include <asm/errno.h>
 

+ 9 - 0
examples/completions.c

@@ -7,6 +7,7 @@
 #include <linux/kthread.h>
 #include <linux/module.h>
 #include <linux/printk.h>
+#include <linux/version.h>
 
 static struct {
     struct completion crank_comp;
@@ -18,7 +19,11 @@ static int machine_crank_thread(void *arg)
     pr_info("Turn the crank\n");
 
     complete_all(&machine.crank_comp);
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 17, 0)
+    kthread_complete_and_exit(&machine.crank_comp, 0);
+#else
     complete_and_exit(&machine.crank_comp, 0);
+#endif
 }
 
 static int machine_flywheel_spinup_thread(void *arg)
@@ -28,7 +33,11 @@ static int machine_flywheel_spinup_thread(void *arg)
     pr_info("Flywheel spins up\n");
 
     complete_all(&machine.flywheel_comp);
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 17, 0)
+    kthread_complete_and_exit(&machine.flywheel_comp, 0);
+#else
     complete_and_exit(&machine.flywheel_comp, 0);
+#endif
 }
 
 static int completions_init(void)