| Index: third_party/libsync/include/linux/sync.h
 | 
| diff --git a/third_party/libsync/include/linux/sync.h b/third_party/libsync/include/linux/sync.h
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..edb6ce83816092349e9b1f66585c911c06b4f36b
 | 
| --- /dev/null
 | 
| +++ b/third_party/libsync/include/linux/sync.h
 | 
| @@ -0,0 +1,103 @@
 | 
| +/*
 | 
| + *  Copyright 2016 Google, Inc
 | 
| + *
 | 
| + *  Licensed under the Apache License, Version 2.0 (the "License");
 | 
| + *  you may not use this file except in compliance with the License.
 | 
| + *  You may obtain a copy of the License at
 | 
| + *
 | 
| + *      http://www.apache.org/licenses/LICENSE-2.0
 | 
| + *
 | 
| + *  Unless required by applicable law or agreed to in writing, software
 | 
| + *  distributed under the License is distributed on an "AS IS" BASIS,
 | 
| + *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
| + *  See the License for the specific language governing permissions and
 | 
| + *  limitations under the License.
 | 
| + */
 | 
| +
 | 
| +#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 */
 | 
| 
 |