blob: 489286673ae75342adf908ed9444a3ef055f3360 [file] [log] [blame]
Erik Gilling196b3a52012-03-07 15:30:33 -08001/*
2 * sync.c
3 *
4 * Copyright 2012 Google, Inc
5 *
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 */
18
19#include <fcntl.h>
20#include <stdint.h>
21#include <string.h>
22
Jamie Gennis3be33e42012-06-13 16:40:54 -070023#include <linux/sync.h>
24#include <linux/sw_sync.h>
25
Erik Gilling196b3a52012-03-07 15:30:33 -080026#include <sys/ioctl.h>
27#include <sys/stat.h>
28#include <sys/types.h>
29
Erik Gilling984d3572012-08-21 18:21:18 -070030int sync_wait(int fd, int timeout)
Erik Gilling196b3a52012-03-07 15:30:33 -080031{
Erik Gilling984d3572012-08-21 18:21:18 -070032 __s32 to = timeout;
Erik Gilling196b3a52012-03-07 15:30:33 -080033
34 return ioctl(fd, SYNC_IOC_WAIT, &to);
35}
36
37int sync_merge(const char *name, int fd1, int fd2)
38{
39 struct sync_merge_data data;
40 int err;
41
42 data.fd2 = fd2;
43 strlcpy(data.name, name, sizeof(data.name));
44
45 err = ioctl(fd1, SYNC_IOC_MERGE, &data);
46 if (err < 0)
47 return err;
48
49 return data.fence;
50}
51
52struct sync_fence_info_data *sync_fence_info(int fd)
53{
54 struct sync_fence_info_data *info;
55 int err;
56
57 info = malloc(4096);
58 if (info == NULL)
59 return NULL;
60
61 info->len = 4096;
62 err = ioctl(fd, SYNC_IOC_FENCE_INFO, info);
63 if (err < 0) {
64 free(info);
65 return NULL;
66 }
67
68 return info;
69}
70
71struct sync_pt_info *sync_pt_info(struct sync_fence_info_data *info,
72 struct sync_pt_info *itr)
73{
74 if (itr == NULL)
75 itr = (struct sync_pt_info *) info->pt_info;
76 else
77 itr = (struct sync_pt_info *) ((__u8 *)itr + itr->len);
78
79 if ((__u8 *)itr - (__u8 *)info >= (int)info->len)
80 return NULL;
81
82 return itr;
83}
84
85void sync_fence_info_free(struct sync_fence_info_data *info)
86{
87 free(info);
88}
89
90
91int sw_sync_timeline_create(void)
92{
93 return open("/dev/sw_sync", O_RDWR);
94}
95
96int sw_sync_timeline_inc(int fd, unsigned count)
97{
98 __u32 arg = count;
99
100 return ioctl(fd, SW_SYNC_IOC_INC, &arg);
101}
102
103int sw_sync_fence_create(int fd, const char *name, unsigned value)
104{
105 struct sw_sync_create_fence_data data;
106 int err;
107
108 data.value = value;
109 strlcpy(data.name, name, sizeof(data.name));
110
111 err = ioctl(fd, SW_SYNC_IOC_CREATE_FENCE, &data);
112 if (err < 0)
113 return err;
114
115 return data.fence;
116}