blob: 496fb2c3b3e6a723200b0ed7a384ed886bde4732 [file] [log] [blame]
Mauro Carvalho Chehabc16f2912017-05-18 22:26:04 -03001===================
2Sync File API Guide
3===================
Gustavo Padovanc784c822016-04-28 10:47:00 -03004
Mauro Carvalho Chehabc16f2912017-05-18 22:26:04 -03005:Author: Gustavo Padovan <gustavo at padovan dot org>
Gustavo Padovanc784c822016-04-28 10:47:00 -03006
7This document serves as a guide for device drivers writers on what the
8sync_file API is, and how drivers can support it. Sync file is the carrier of
Chris Wilsonf54d1862016-10-25 13:00:45 +01009the fences(struct dma_fence) that are needed to synchronize between drivers or
Javier Martinez Canillasfac84342016-05-14 02:28:36 -040010across process boundaries.
Gustavo Padovanc784c822016-04-28 10:47:00 -030011
12The sync_file API is meant to be used to send and receive fence information
13to/from userspace. It enables userspace to do explicit fencing, where instead
14of attaching a fence to the buffer a producer driver (such as a GPU or V4L
15driver) sends the fence related to the buffer to userspace via a sync_file.
16
17The sync_file then can be sent to the consumer (DRM driver for example), that
18will not use the buffer for anything before the fence(s) signals, i.e., the
19driver that issued the fence is not using/processing the buffer anymore, so it
20signals that the buffer is ready to use. And vice-versa for the consumer ->
21producer part of the cycle.
22
23Sync files allows userspace awareness on buffer sharing synchronization between
24drivers.
25
26Sync file was originally added in the Android kernel but current Linux Desktop
27can benefit a lot from it.
28
29in-fences and out-fences
30------------------------
31
32Sync files can go either to or from userspace. When a sync_file is sent from
33the driver to userspace we call the fences it contains 'out-fences'. They are
34related to a buffer that the driver is processing or is going to process, so
Chris Wilsonf54d1862016-10-25 13:00:45 +010035the driver creates an out-fence to be able to notify, through
36dma_fence_signal(), when it has finished using (or processing) that buffer.
37Out-fences are fences that the driver creates.
Gustavo Padovanc784c822016-04-28 10:47:00 -030038
39On the other hand if the driver receives fence(s) through a sync_file from
Tamara Diaconita7bc41a62017-03-16 17:39:46 +020040userspace we call these fence(s) 'in-fences'. Receiving in-fences means that
Gustavo Padovanc784c822016-04-28 10:47:00 -030041we need to wait for the fence(s) to signal before using any buffer related to
42the in-fences.
43
44Creating Sync Files
45-------------------
46
47When a driver needs to send an out-fence userspace it creates a sync_file.
48
Mauro Carvalho Chehabc16f2912017-05-18 22:26:04 -030049Interface::
50
Chris Wilsonf54d1862016-10-25 13:00:45 +010051 struct sync_file *sync_file_create(struct dma_fence *fence);
Gustavo Padovanc784c822016-04-28 10:47:00 -030052
53The caller pass the out-fence and gets back the sync_file. That is just the
54first step, next it needs to install an fd on sync_file->file. So it gets an
Mauro Carvalho Chehabc16f2912017-05-18 22:26:04 -030055fd::
Gustavo Padovanc784c822016-04-28 10:47:00 -030056
57 fd = get_unused_fd_flags(O_CLOEXEC);
58
Mauro Carvalho Chehabc16f2912017-05-18 22:26:04 -030059and installs it on sync_file->file::
Gustavo Padovanc784c822016-04-28 10:47:00 -030060
61 fd_install(fd, sync_file->file);
62
63The sync_file fd now can be sent to userspace.
64
65If the creation process fail, or the sync_file needs to be released by any
66other reason fput(sync_file->file) should be used.
67
Gustavo Padovan395dec62016-08-05 10:39:37 -030068Receiving Sync Files from Userspace
69-----------------------------------
70
71When userspace needs to send an in-fence to the driver it passes file descriptor
72of the Sync File to the kernel. The kernel can then retrieve the fences
73from it.
74
Mauro Carvalho Chehabc16f2912017-05-18 22:26:04 -030075Interface::
76
Chris Wilsonf54d1862016-10-25 13:00:45 +010077 struct dma_fence *sync_file_get_fence(int fd);
Gustavo Padovan395dec62016-08-05 10:39:37 -030078
79
80The returned reference is owned by the caller and must be disposed of
Chris Wilsonf54d1862016-10-25 13:00:45 +010081afterwards using dma_fence_put(). In case of error, a NULL is returned instead.
Gustavo Padovan395dec62016-08-05 10:39:37 -030082
Gustavo Padovanc784c822016-04-28 10:47:00 -030083References:
Mauro Carvalho Chehabc16f2912017-05-18 22:26:04 -030084
851. struct sync_file in include/linux/sync_file.h
862. All interfaces mentioned above defined in include/linux/sync_file.h