Add the new API to the internal sync.h file. As there is two different APIs we will need to discovery dynamically which one to use. v2: Fix Documentation Test: Sync unit tests still passes. Change-Id: I2ab3cd46e48ba5d9c73d54f9583b1a8141566581
163 lines
4.5 KiB
C
163 lines
4.5 KiB
C
/*
|
|
* sync.h
|
|
*
|
|
* Copyright 2012 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 __SYS_CORE_SYNC_H
|
|
#define __SYS_CORE_SYNC_H
|
|
|
|
#include <sys/cdefs.h>
|
|
#include <stdint.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
__BEGIN_DECLS
|
|
|
|
struct sync_legacy_merge_data {
|
|
int32_t fd2;
|
|
char name[32];
|
|
int32_t fence;
|
|
};
|
|
|
|
struct sync_fence_info_data {
|
|
uint32_t len;
|
|
char name[32];
|
|
int32_t status;
|
|
uint8_t pt_info[0];
|
|
};
|
|
|
|
struct sync_pt_info {
|
|
uint32_t len;
|
|
char obj_name[32];
|
|
char driver_name[32];
|
|
int32_t status;
|
|
uint64_t timestamp_ns;
|
|
uint8_t driver_data[0];
|
|
};
|
|
|
|
#define SYNC_IOC_MAGIC '>'
|
|
|
|
/**
|
|
* DOC: SYNC_IOC_LEGACY_WAIT - wait for a fence to signal
|
|
*
|
|
* pass timeout in milliseconds. Waits indefinitely timeout < 0.
|
|
*
|
|
* This is the legacy version of the Sync API before the de-stage that happened
|
|
* on Linux kernel 4.7.
|
|
*/
|
|
#define SYNC_IOC_LEGACY_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
|
|
*
|
|
* This is the legacy version of the Sync API before the de-stage that happened
|
|
* on Linux kernel 4.7.
|
|
*/
|
|
#define SYNC_IOC_LEGACY_MERGE _IOWR(SYNC_IOC_MAGIC, 1, \
|
|
struct sync_legacy_merge_data)
|
|
|
|
/**
|
|
* DOC: SYNC_IOC_LEGACY_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.
|
|
*
|
|
* This is the legacy version of the Sync API before the de-stage that happened
|
|
* on Linux kernel 4.7.
|
|
*/
|
|
#define SYNC_IOC_LEGACY_FENCE_INFO _IOWR(SYNC_IOC_MAGIC, 2,\
|
|
struct sync_fence_info_data)
|
|
|
|
struct sync_merge_data {
|
|
char name[32];
|
|
int32_t fd2;
|
|
int32_t fence;
|
|
uint32_t flags;
|
|
uint32_t pad;
|
|
};
|
|
|
|
struct sync_file_info {
|
|
char name[32];
|
|
int32_t status;
|
|
uint32_t flags;
|
|
uint32_t num_fences;
|
|
uint32_t pad;
|
|
|
|
uint64_t sync_fence_info;
|
|
};
|
|
|
|
struct sync_fence_info {
|
|
char obj_name[32];
|
|
char driver_name[32];
|
|
int32_t status;
|
|
uint32_t flags;
|
|
uint64_t timestamp_ns;
|
|
};
|
|
|
|
/**
|
|
* Mainline API:
|
|
*
|
|
* Opcodes 0, 1 and 2 were burned during a API change to avoid users of the
|
|
* old API to get weird errors when trying to handling sync_files. The API
|
|
* change happened during the de-stage of the Sync Framework when there was
|
|
* no upstream users available.
|
|
*/
|
|
|
|
/**
|
|
* 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
|
|
*
|
|
* This is the new version of the Sync API after the de-stage that happened
|
|
* on Linux kernel 4.7.
|
|
*/
|
|
#define SYNC_IOC_MERGE _IOWR(SYNC_IOC_MAGIC, 3, struct sync_merge_data)
|
|
|
|
/**
|
|
* DOC: SYNC_IOC_FILE_INFO - get detailed information on a sync_file
|
|
*
|
|
* Takes a struct sync_file_info. If num_fences is 0, the field is updated
|
|
* with the actual number of fences. If num_fences is > 0, the system will
|
|
* use the pointer provided on sync_fence_info to return up to num_fences of
|
|
* struct sync_fence_info, with detailed fence information.
|
|
*
|
|
* This is the new version of the Sync API after the de-stage that happened
|
|
* on Linux kernel 4.7.
|
|
*/
|
|
#define SYNC_IOC_FILE_INFO _IOWR(SYNC_IOC_MAGIC, 4, struct sync_file_info)
|
|
|
|
/* timeout in msecs */
|
|
int sync_wait(int fd, int timeout);
|
|
int sync_merge(const char *name, int fd1, int fd2);
|
|
struct sync_fence_info_data *sync_fence_info(int fd);
|
|
struct sync_pt_info *sync_pt_info(struct sync_fence_info_data *info,
|
|
struct sync_pt_info *itr);
|
|
void sync_fence_info_free(struct sync_fence_info_data *info);
|
|
|
|
__END_DECLS
|
|
|
|
#endif /* __SYS_CORE_SYNC_H */
|