drm: Add Linux async functions
authorFrançois Tigeot <ftigeot@wolfpond.org>
Fri, 23 Oct 2015 19:53:16 +0000 (21:53 +0200)
committerFrançois Tigeot <ftigeot@wolfpond.org>
Fri, 23 Oct 2015 19:53:55 +0000 (21:53 +0200)
sys/dev/drm/drm/Makefile
sys/dev/drm/include/linux/async.h [new file with mode: 0644]
sys/dev/drm/linux_async.c [new file with mode: 0644]

index d69e382..fac5190 100644 (file)
@@ -37,6 +37,7 @@ SRCS  = \
        drm_sysfs.c \
        drm_vm.c \
        drm_vma_manager.c \
+       linux_async.c \
        linux_compat.c \
        linux_hdmi.c \
        linux_list_sort.c \
diff --git a/sys/dev/drm/include/linux/async.h b/sys/dev/drm/include/linux/async.h
new file mode 100644 (file)
index 0000000..751e647
--- /dev/null
@@ -0,0 +1,45 @@
+/*
+ * Copyright (c) 2015 François Tigeot
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice unmodified, this list of conditions, and the following
+ *    disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef _LINUX_ASYNC_H_
+#define _LINUX_ASYNC_H_
+
+#include <linux/types.h>
+#include <linux/list.h>
+
+typedef u64 async_cookie_t;
+typedef void (*async_func_t) (void *data, async_cookie_t cookie);
+
+extern async_cookie_t async_schedule(async_func_t func, void *data);
+
+static inline void async_synchronize_full(void) {
+       /*
+        * XXX: This function is supposed to wait until all asynchronous
+        * function calls have been done
+        */
+}
+
+#endif /* _LINUX_ASYNC_H_ */
diff --git a/sys/dev/drm/linux_async.c b/sys/dev/drm/linux_async.c
new file mode 100644 (file)
index 0000000..3810453
--- /dev/null
@@ -0,0 +1,50 @@
+/*-
+ * Copyright (c) 2015 François Tigeot
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice unmodified, this list of conditions, and the following
+ *    disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <sys/spinlock2.h>
+#include <linux/async.h>
+
+static async_cookie_t cookie_counter = 1;
+
+/* Protects cookie_counter */
+static struct lock linux_async_lock;
+LOCK_SYSINIT(linux_async_lock, &linux_async_lock, "lasync", LK_CANRECURSE);
+
+/* async_schedule: schedule a function for asynchronous execution */
+async_cookie_t async_schedule(async_func_t func, void *data)
+{
+       async_cookie_t cookie;
+
+       lockmgr(&linux_async_lock, LK_EXCLUSIVE);
+       cookie_counter++;
+       cookie = cookie_counter;
+       lockmgr(&linux_async_lock, LK_RELEASE);
+
+       /* XXX: Just run the function synchronously for now */
+       func(data, cookie);
+
+       return cookie;
+}