mirror of https://github.com/OpenIPC/firmware.git
101 lines
3.1 KiB
Diff
101 lines
3.1 KiB
Diff
--- linux-4.9.37/drivers/fence/_sync.h 1970-01-01 03:00:00.000000000 +0300
|
|
+++ linux-4.9.y/drivers/fence/_sync.h 2021-06-07 13:01:33.000000000 +0300
|
|
@@ -0,0 +1,97 @@
|
|
+/*
|
|
+ * Copyright (C) 2012 Google, Inc.
|
|
+ *
|
|
+ * This program is distributed in the hope that it will be useful,
|
|
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
+ * GNU General Public License for more details.
|
|
+ *
|
|
+ */
|
|
+
|
|
+#ifndef _UAPI_LINUX_SYNC_H
|
|
+#define _UAPI_LINUX_SYNC_H
|
|
+
|
|
+#include <linux/ioctl.h>
|
|
+#include <linux/types.h>
|
|
+
|
|
+/**
|
|
+ * struct sync_merge_data - data passed to merge ioctl
|
|
+ * @fd2: file descriptor of second fence
|
|
+ * @name: name of new fence
|
|
+ * @fence: returns the fd of the new fence to userspace
|
|
+ */
|
|
+struct sync_merge_data {
|
|
+ __s32 fd2; /* fd of second fence */
|
|
+ char name[32]; /* name of new fence */
|
|
+ __s32 fence; /* fd on newly created fence */
|
|
+};
|
|
+
|
|
+/**
|
|
+ * struct sync_pt_info - detailed sync_pt information
|
|
+ * @len: length of sync_pt_info including any driver_data
|
|
+ * @obj_name: name of parent sync_timeline
|
|
+ * @driver_name: name of driver implementing the parent
|
|
+ * @status: status of the sync_pt 0:active 1:signaled <0:error
|
|
+ * @timestamp_ns: timestamp of status change in nanoseconds
|
|
+ * @driver_data: any driver dependent data
|
|
+ */
|
|
+struct sync_pt_info {
|
|
+ __u32 len;
|
|
+ char obj_name[32];
|
|
+ char driver_name[32];
|
|
+ __s32 status;
|
|
+ __u64 timestamp_ns;
|
|
+
|
|
+ __u8 driver_data[0];
|
|
+};
|
|
+
|
|
+/**
|
|
+ * struct sync_fence_info_data - data returned from fence info ioctl
|
|
+ * @len: ioctl caller writes the size of the buffer its passing in.
|
|
+ * ioctl returns length of sync_fence_data returned to userspace
|
|
+ * including pt_info.
|
|
+ * @name: name of fence
|
|
+ * @status: status of fence. 1: signaled 0:active <0:error
|
|
+ * @pt_info: a sync_pt_info struct for every sync_pt in the fence
|
|
+ */
|
|
+struct sync_fence_info_data {
|
|
+ __u32 len;
|
|
+ char name[32];
|
|
+ __s32 status;
|
|
+
|
|
+ __u8 pt_info[0];
|
|
+};
|
|
+
|
|
+#define SYNC_IOC_MAGIC '>'
|
|
+
|
|
+/**
|
|
+ * DOC: SYNC_IOC_WAIT - wait for a fence to signal
|
|
+ *
|
|
+ * pass timeout in milliseconds. Waits indefinitely timeout < 0.
|
|
+ */
|
|
+#define SYNC_IOC_WAIT _IOW(SYNC_IOC_MAGIC, 0, __s32)
|
|
+
|
|
+/**
|
|
+ * DOC: SYNC_IOC_MERGE - merge two fences
|
|
+ *
|
|
+ * Takes a struct sync_merge_data. Creates a new fence containing copies of
|
|
+ * the sync_pts in both the calling fd and sync_merge_data.fd2. Returns the
|
|
+ * new fence's fd in sync_merge_data.fence
|
|
+ */
|
|
+#define SYNC_IOC_MERGE _IOWR(SYNC_IOC_MAGIC, 1, struct sync_merge_data)
|
|
+
|
|
+/**
|
|
+ * DOC: SYNC_IOC_FENCE_INFO - get detailed information on a fence
|
|
+ *
|
|
+ * Takes a struct sync_fence_info_data with extra space allocated for pt_info.
|
|
+ * Caller should write the size of the buffer into len. On return, len is
|
|
+ * updated to reflect the total size of the sync_fence_info_data including
|
|
+ * pt_info.
|
|
+ *
|
|
+ * pt_info is a buffer containing sync_pt_infos for every sync_pt in the fence.
|
|
+ * To iterate over the sync_pt_infos, use the sync_pt_info.len field.
|
|
+ */
|
|
+#define SYNC_IOC_FENCE_INFO _IOWR(SYNC_IOC_MAGIC, 2,\
|
|
+ struct sync_fence_info_data)
|
|
+
|
|
+#endif /* _UAPI_LINUX_SYNC_H */
|