SyncFence
  public
  
  final
  
  class
  SyncFence
  
    extends Object
  
  
  
  
  
      implements
      
        AutoCloseable, 
      
        Parcelable
      
  
  
| java.lang.Object | |
| ↳ | android.hardware.SyncFence | 
A SyncFence represents a synchronization primitive which signals when hardware units have completed work on a particular resource. They initially start in an unsignaled state and make a one-time transition to either a signaled or error state. SyncFences are created by various device APIs in response to submitting tasks to the device. They cannot be created nor signaled by userspace. As a result, this means that a SyncFence will make always make forward progress.
SyncFence's generally come in one of two varieties. "Presentation fences" refer to a SyncFence when the writing to a buffer has finished. "Release fences" then refer to when the reading from a buffer has finished.
For example, a GPU rendering to a framebuffer may generate a synchronization fence, e.g., an EGLSync or VkFence, which signals when rendering has completed. Once the fence signals, then the backing storage for the framebuffer may be safely read from, such as for display or for media encoding. This would be referred to as a "presentation fence."
Similarly when using an ImageWriter it is possible that an
 Image returned by ImageWriter.dequeueInputImage() may already
 have a fence set on it. This would be what is referred to as either
 a "release fence" or an "acqurie fence" and indicates the fence that the writer must wait
 on before writing to the underlying buffer. In the case of ImageWriter this is done
 automatically when eg Image.getPlanes() is called, however when using
 Image.getHardwareBuffer() it is the caller's responsibility to ensure the
 release fence has signaled before writing to the buffer.
Summary
| Constants | |
|---|---|
| long | SIGNAL_TIME_INVALIDAn invalid signal time. | 
| long | SIGNAL_TIME_PENDINGA pending signal time. | 
| Inherited constants | 
|---|
| Fields | |
|---|---|
| 
    public
    static
    final
    Creator<SyncFence> | CREATOR
 | 
| Public constructors | |
|---|---|
| 
      SyncFence(SyncFence other)
      Creates a copy of the SyncFence from an existing one. | |
| Public methods | |
|---|---|
| 
        
        
        
        
        
        boolean | 
      await(Duration timeout)
      Waits for a SyncFence to signal for up to the timeout duration. | 
| 
        
        
        
        
        
        boolean | 
      awaitForever()
      Waits forever for a SyncFence to signal. | 
| 
        
        
        
        
        
        void | 
      close()
      Close the SyncFence. | 
| 
        
        
        
        
        
        int | 
      describeContents()
      Describe the kinds of special objects contained in this Parcelable instance's marshaled representation. | 
| 
        
        
        
        
        
        long | 
      getSignalTime()
      Returns the time in nanoseconds that the fence signaled in the CLOCK_MONOTONIC time domain. | 
| 
        
        
        
        
        
        boolean | 
      isValid()
      Checks if the SyncFile object is valid. | 
| 
        
        
        
        
        
        void | 
      writeToParcel(Parcel out, int flags)
      Flatten this object into a Parcel. | 
| Inherited methods | |
|---|---|
Constants
SIGNAL_TIME_INVALID
public static final long SIGNAL_TIME_INVALID
An invalid signal time. Represents either the signal time for a SyncFence that isn't valid
 (that is, isValid() is false), or if an error occurred while attempting to retrieve
 the signal time.
Constant Value: -1 (0xffffffffffffffff)
SIGNAL_TIME_PENDING
public static final long SIGNAL_TIME_PENDING
A pending signal time. This is equivalent to the max value of a long, representing an infinitely far point in the future.
Constant Value: 9223372036854775807 (0x7fffffffffffffff)
Fields
Public constructors
SyncFence
public SyncFence (SyncFence other)
Creates a copy of the SyncFence from an existing one. Both fences must be closed() independently.
| Parameters | |
|---|---|
| other | SyncFence: This value cannot benull. | 
Public methods
await
public boolean await (Duration timeout)
Waits for a SyncFence to signal for up to the timeout duration.
 An invalid SyncFence, that is if isValid() is false, is treated equivalently
 to a SyncFence that has already signaled. That is, wait() will immediately return true.
| Parameters | |
|---|---|
| timeout | Duration: The timeout duration. If the duration is negative, then this waits forever.
 This value cannot benull. | 
| Returns | |
|---|---|
| boolean | true if the fence signaled or isn't valid, false otherwise. | 
awaitForever
public boolean awaitForever ()
Waits forever for a SyncFence to signal.
 An invalid SyncFence, that is if isValid() is false, is treated equivalently
 to a SyncFence that has already signaled. That is, wait() will immediately return true.
| Returns | |
|---|---|
| boolean | true if the fence signaled or isn't valid, false otherwise. | 
close
public void close ()
Close the SyncFence. This implementation closes the underlying OS resources allocated this stream.
describeContents
public int describeContents ()
Describe the kinds of special objects contained in this Parcelable
 instance's marshaled representation. For example, if the object will
 include a file descriptor in the output of writeToParcel(android.os.Parcel, int),
 the return value of this method must include the
 CONTENTS_FILE_DESCRIPTOR bit.
| Returns | |
|---|---|
| int | a bitmask indicating the set of special object types marshaled
 by this Parcelable object instance.
 Value is either 0orCONTENTS_FILE_DESCRIPTOR | 
getSignalTime
public long getSignalTime ()
Returns the time in nanoseconds that the fence signaled in the CLOCK_MONOTONIC time domain.
 This corresponds to System.nanoTime() but may also be compared to
 SystemClock.uptimeMillis() after adjusting for milliseconds vs. nanoseconds.
 If the fence isn't valid, that is if isValid() is false, then this returns
 SIGNAL_TIME_INVALID. Similarly, if an error occurs while trying to access the
 signal time, then SIGNAL_TIME_INVALID is also returned.
 If the fence hasn't yet signaled, then SIGNAL_TIME_PENDING is returned.
| Returns | |
|---|---|
| long | The time the fence signaled, SIGNAL_TIME_INVALIDif there's an error,
         orSIGNAL_TIME_PENDINGif the fence hasn't signaled yet. | 
isValid
public boolean isValid ()
Checks if the SyncFile object is valid.
| Returns | |
|---|---|
| boolean | trueif the file descriptor represents a valid, open file;falseotherwise. | 
writeToParcel
public void writeToParcel (Parcel out, int flags)
Flatten this object into a Parcel.
| Parameters | |
|---|---|
| out | Parcel: The Parcel in which the object should be written.
 This value cannot benull. | 
| flags | int: Additional flags about how the object should be written.
              May be0orParcelable.PARCELABLE_WRITE_RETURN_VALUE | 
