NVIDIA DriveOS Linux NSR SDK API Reference

7.0.3.0 Release
2D Surface and Synchronization

Detailed Description

The NvMedia 2D NvSci API encompasses all NvMedia 2D handling for NvSciBuf NvSciSync related functions.

6

Functions

NvMediaStatus NvMedia2DFillNvSciBufAttrList (NvMedia2D const *const handle, NvSciBufAttrList const attrList)
 Fills the NvMedia 2D specific NvSciBuf attributes. More...
 
NvMediaStatus NvMedia2DFillNvSciSyncAttrList (NvMedia2D const *const handle, NvSciSyncAttrList const attrList, NvMediaNvSciSyncClientType const clientType)
 Fills the NvMedia 2D specific NvSciSync attributes. More...
 
NvMediaStatus NvMedia2DRegisterNvSciBufObj (NvMedia2D const *const handle, NvSciBufObj const bufObj)
 Register an NvSciBufObj with NvMedia 2D. More...
 
NvMediaStatus NvMedia2DRegisterNvSciSyncObj (NvMedia2D const *const handle, NvMediaNvSciSyncObjType const syncObjType, NvSciSyncObj const syncObj)
 Register an NvSciSyncObj with NvMedia 2D. More...
 
NvMediaStatus NvMedia2DUnregisterNvSciBufObj (NvMedia2D const *const handle, NvSciBufObj const bufObj)
 Unregisters an NvSciBufObj with NvMedia2D. More...
 
NvMediaStatus NvMedia2DUnregisterNvSciSyncObj (NvMedia2D const *const handle, NvSciSyncObj const syncObj)
 Unregisters an NvSciSyncObj with NvMedia2D. More...
 
NvMediaStatus NvMedia2DSetNvSciSyncObjforEOF (NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvSciSyncObj const syncObj)
 Specifies the NvSciSyncObj to be used for EOF event. More...
 
NvMediaStatus NvMedia2DInsertPreNvSciSyncFence (NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvSciSyncFence const *const syncFence)
 Insert an NvSciSyncFence as a pre-fence. More...
 
NvMediaStatus NvMedia2DGetEOFNvSciSyncFence (NvMedia2D const *const handle, NvMedia2DComposeResult const *const result, NvSciSyncFence *const syncFence)
 Gets an EOF NvSciSyncFence for an NvMedia2DCompose() operation. More...
 
NvMediaStatus NvMedia2DSetSrcNvSciBufObj (NvMedia2D const *const handle, NvMedia2DComposeParameters const params, uint32_t const index, NvSciBufObj const srcSurface)
 Sets the surface for a source layer. More...
 
NvMediaStatus NvMedia2DSetDstNvSciBufObj (NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvSciBufObj const dstSurface)
 Sets the surface for the destination. More...
 
NvMediaStatus NvMedia2DSetTnrOutputNvSciBufObj (NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvSciBufObj const tnrOutputSurface)
 Sets the output surface for the TNR operation. More...
 
NvMediaStatus NvMedia2DSetTnrPreviousNvSciBufObj (NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvSciBufObj const tnrPreviousSurface)
 Sets the previous surface for TNR operation. More...
 
NvMediaStatus NvMedia2DSetXSobelOutputNvSciBufObj (NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvSciBufObj const xsobelOutputSurface)
 Sets the surface for XSobel output. More...
 
NvMediaStatus NvMedia2DSetXSobelDownsampledNvSciBufObj (NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvSciBufObj const xsobelDownsampledSurface)
 Sets the surface for 4x4 downsampled XSobel output. More...
 

Function Documentation

◆ NvMedia2DFillNvSciBufAttrList()

NvMediaStatus NvMedia2DFillNvSciBufAttrList ( NvMedia2D const *const  handle,
NvSciBufAttrList const  attrList 
)

Fills the NvMedia 2D specific NvSciBuf attributes.

This function updates the input NvSciBufAttrList with values equivalent to the following public attribute key-values:

NvSciBufGeneralAttrKey_PeerHwEngineArray set to

  • engName: NvSciBufHwEngName_Vic
  • platName: the platform this API is used on
Parameters
[in]handleNot used. Can be NULL.
[out]attrListPointer to an NvSciBufAttrList struct that will be populated with the NvSciBuf attributes.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKAttributes filled successfully.
NVMEDIA_STATUS_BAD_PARAMETERThe attributes have already been filled, or attrList is invalid.
NVMEDIA_STATUS_INVALID_STATEThe function was called in incorrect system state.
NVMEDIA_STATUS_ERRORAn internal failure occurred when trying to populate the attribute list.
Precondition
  • attrList must be valid NvSciBufAttrList handle.


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: Yes
    • Runtime: No
    • De-Init: No

◆ NvMedia2DFillNvSciSyncAttrList()

NvMediaStatus NvMedia2DFillNvSciSyncAttrList ( NvMedia2D const *const  handle,
NvSciSyncAttrList const  attrList,
NvMediaNvSciSyncClientType const  clientType 
)

Fills the NvMedia 2D specific NvSciSync attributes.

This function updates the input NvSciSyncAttrList with values equivalent to the following public attribute key-values:

NvSciSyncAttrKey_RequiredPerm set to

  • NvSciSyncAccessPerm_WaitOnly for clientType NVMEDIA_WAITER
  • NvSciSyncAccessPerm_SignalOnly for clientType NVMEDIA_SIGNALER
  • NvSciSyncAccessPerm_WaitSignal for clientType NVMEDIA_SIGNALER_WAITER

NvSciSyncAttrKey_PrimitiveInfo set to

  • NvSciSyncAttrValPrimitiveType_Syncpoint

The application must not set these attributes for the same NvSciSyncAttrList that is passed to this function.

When clientType is NVMEDIA_SIGNALER or NVMEDIA_SIGNALER_WAITER, some of the attribute values returned in attrList are tied to the specific NvMedia2D context instance passed in handle. NvSciSyncObjs created using such attribute values must not be used after the NvMedia2D context instance has been destroyed.

Parameters
[in]handlePointer to the NvMedia2D context.
[out]attrListPointer to an NvSciSyncAttrList struct that will be populated with the NvSciSync attributes.
[in]clientTypeAn NvMediaNvSciSyncClientType, to indicate whether the attributes filled should be for a waiter or a signaler. The value should be either:
  • NVMEDIA_WAITER
  • NVMEDIA_SIGNALER
  • NVMEDIA_SIGNALER_WAITER.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKAttributes filled successfully.
NVMEDIA_STATUS_BAD_PARAMETERThe attributes have already been filled, or one of the parameters has an invalid value. This could be:
  • handle is NULL
  • attrList is invalid
  • clientType is invalid.
NVMEDIA_STATUS_INVALID_STATEThe function was called in incorrect system state.
NVMEDIA_STATUS_ERRORAn internal failure occurred when trying to populate the attribute list.
Precondition
  • handle must be valid NvMedia2D handle created with NvMedia2DCreate().
  • attrList must be valid NvSciSyncAttrList handle.


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: Yes
    • Runtime: No
    • De-Init: No

◆ NvMedia2DGetEOFNvSciSyncFence()

NvMediaStatus NvMedia2DGetEOFNvSciSyncFence ( NvMedia2D const *const  handle,
NvMedia2DComposeResult const *const  result,
NvSciSyncFence *const  syncFence 
)

Gets an EOF NvSciSyncFence for an NvMedia2DCompose() operation.

The expiry of an EOF NvSciSyncFence associated with an NvMedia2DCompose() operation indicates that the corresponding NvMedia2DCompose() operation has finished.

To be able to get the EOF fence using this function, the NvSciSyncObj to be used for EOF event needs to have been set for the NvMedia2DComposeParameters handle used with the NvMedia2DCompose() operation with NvMedia2DSetNvSciSyncObjforEOF().

For example, in this sequence of code:

expiry of syncFence indicates that the preceding NvMedia2DCompose() operation has finished.

For a given NvSciSyncObj used for the EOF event, the EOF fence for an NvMedia2DCompose() operation can be queried using this function only until the next operation using the same NvSciSyncObj for the EOF event is submitted. When more operations are submitted, the NvMedia2DComposeResult structs for the previous operations are no longer considered valid by this function.

The fence returned in syncFence is tied to the specific NvMedia2D context instance passed in handle and must not be used after the NvMedia2D context instance has been destroyed.

This function will clear syncFence before updating and returning it's new value.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]resultPointer to the NvMedia2DComposeResult struct.
[out]syncFencePointer to an NvSciSyncFence that will be populated with the EOF fence.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKEOF fence returned successfully.
NVMEDIA_STATUS_BAD_PARAMETERNo NvSciSyncObj was set for the operation EOF event, or one of the parameters has an invalid value. This could be:
  • handle is NULL
  • result is NULL or invalid
  • syncFence is NULL.
NVMEDIA_STATUS_ERRORAn internal failure occurred when trying to get the fence object.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: No
    • Runtime: Yes
    • De-Init: No
See also
NvMedia2DRegisterNvSciSyncObj()
NvMedia2DSetNvSciSyncObjforEOF()

◆ NvMedia2DInsertPreNvSciSyncFence()

NvMediaStatus NvMedia2DInsertPreNvSciSyncFence ( NvMedia2D const *const  handle,
NvMedia2DComposeParameters const  params,
NvSciSyncFence const *const  syncFence 
)

Insert an NvSciSyncFence as a pre-fence.

This function inserts the specified NvSciSyncFence as a pre-fence to the compose operation. The NvMedia2DCompose() operation is started only after the expiry of the syncFence.

For example, in this sequence of code:

the NvMedia2DCompose () operation is assured to start only after the expiry of syncFence.

You can set a maximum of 16 prefences by calling NvMedia2DInsertPreNvSciSyncFence().

Parameters
[in]handlePointer to the NvMedia2D context.
[in]paramsAn NvMedia2DComposeParameters handle.
[in]syncFencePointer to an NvSciSyncFence.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKPre-fence inserted successfully.
NVMEDIA_STATUS_BAD_PARAMETERThe sync object or its duplicate is not registered as an PRESYNC type with NvMedia 2D, or one of the parameters has an invalid value. This could be:
  • handle is NULL
  • params is invalid
  • syncFence is NULL.
NVMEDIA_STATUS_INSUFFICIENT_BUFFERINGMaximum number of registered pre-fences has been reached.
NVMEDIA_STATUS_ERRORAn internal failure occurred when trying to insert the pre-fence.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: No
    • Runtime: Yes
    • De-Init: No
See also
NvMedia2DRegisterNvSciSyncObj()

◆ NvMedia2DRegisterNvSciBufObj()

NvMediaStatus NvMedia2DRegisterNvSciBufObj ( NvMedia2D const *const  handle,
NvSciBufObj const  bufObj 
)

Register an NvSciBufObj with NvMedia 2D.

Every NvSciBufObj used by NvMedia 2D must be registered by a call to this function before it is used.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]bufObjThe NvSciBufObj to be registered.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKBuffer registered successfully.
NVMEDIA_STATUS_BAD_PARAMETERReturned when:
  • handle is NULL
  • bufObj is invalid
  • bufObj or its duplicate has already been registered.
NVMEDIA_STATUS_INSUFFICIENT_BUFFERINGMaximum number of registered buffers has been reached.
NVMEDIA_STATUS_INVALID_STATEThe function was called in incorrect system state.
NVMEDIA_STATUS_ERRORAn internal failure occurred when trying to register the buffer.
Precondition
  • handle must be valid NvMedia2D handle created with NvMedia2DCreate().
  • bufObj must be valid NvSciBufObj handle.


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: Yes
    • Runtime: No
    • De-Init: No
See also
NvMedia2DUnregisterNvSciBufObj()

◆ NvMedia2DRegisterNvSciSyncObj()

NvMediaStatus NvMedia2DRegisterNvSciSyncObj ( NvMedia2D const *const  handle,
NvMediaNvSciSyncObjType const  syncObjType,
NvSciSyncObj const  syncObj 
)

Register an NvSciSyncObj with NvMedia 2D.

Every NvSciSyncObj used by NvMedia 2D must be registered by a call to this function before it is used. Also the NvSciSyncObjs associated with any NvSciSyncFences passed to NvMedia2DInsertPreNvSciSyncFence() must be registered.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]syncObjTypeAn NvMediaNvSciSyncClientType, to indicate what event the sync object will represent. Must be one of
  • NVMEDIA_PRESYNCOBJ
  • NVMEDIA_EOFSYNCOBJ
  • NVMEDIA_EOF_PRESYNCOBJ
[in]syncObjThe NvSciSyncObj to be registered.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKSync object registered successfully.
NVMEDIA_STATUS_BAD_PARAMETEROne of the parameters has an invalid value. This could be:
  • handle is NULL
  • syncObjType is invalid
  • syncObj is invalid, or the sync object or its duplicate has been already registered.
NVMEDIA_STATUS_INSUFFICIENT_BUFFERINGMaximum number of registered sync objects has been reached.
NVMEDIA_STATUS_INVALID_STATEThe function was called in incorrect system state.
NVMEDIA_STATUS_ERRORAn internal failure occurred when trying to register the sync object.
Precondition
  • handle must be valid NvMedia2D handle created with NvMedia2DCreate().
  • syncObj must be valid NvSciSyncObj handle.


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: Yes
    • Runtime: No
    • De-Init: No
See also
NvMedia2DUnregisterNvSciSyncObj()
NvMedia2DAttributes.maxRegisteredSyncs

◆ NvMedia2DSetDstNvSciBufObj()

NvMediaStatus NvMedia2DSetDstNvSciBufObj ( NvMedia2D const *const  handle,
NvMedia2DComposeParameters const  params,
NvSciBufObj const  dstSurface 
)

Sets the surface for the destination.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]paramsAn NvMedia2DComposeParameters handle.
[in]dstSurfaceThe NvSciBufObj to be used for the destination surface.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKParameters set successfully.
NVMEDIA_STATUS_BAD_PARAMETEROne of the parameters has an invalid value. This could be:
  • handle is NULL
  • params is invalid
  • dstSurface or its duplicate was not registered.
NVMEDIA_STATUS_ERRORAn internal failure occurred.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: No
    • Runtime: Yes
    • De-Init: No
See also
NvMedia2DComposeParameters
NvMedia2DCompose()
NvMedia2DRegisterNvSciBufObj()

◆ NvMedia2DSetNvSciSyncObjforEOF()

NvMediaStatus NvMedia2DSetNvSciSyncObjforEOF ( NvMedia2D const *const  handle,
NvMedia2DComposeParameters const  params,
NvSciSyncObj const  syncObj 
)

Specifies the NvSciSyncObj to be used for EOF event.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]paramsAn NvMedia2DComposeParameters handle.
[in]syncObjThe NvSciSyncObj to be used for the EOF fence.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKEOF fence set successfully.
NVMEDIA_STATUS_BAD_PARAMETERThe sync object or its duplicate is not registered as an EOF event type with NvMedia 2D, or one of the parameters has an invalid value. This could be:
  • handle is NULL
  • params is invalid
  • syncObj is invalid.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: No
    • Runtime: Yes
    • De-Init: No
See also
NvMedia2DRegisterNvSciSyncObj()

◆ NvMedia2DSetSrcNvSciBufObj()

NvMediaStatus NvMedia2DSetSrcNvSciBufObj ( NvMedia2D const *const  handle,
NvMedia2DComposeParameters const  params,
uint32_t const  index,
NvSciBufObj const  srcSurface 
)

Sets the surface for a source layer.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]paramsAn NvMedia2DComposeParameters handle.
[in]indexIndex of source layer to configure. Must be in range [0, 15].
[in]srcSurfaceThe NvSciBufObj to be used for the source surface.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKParameters set successfully.
NVMEDIA_STATUS_BAD_PARAMETEROne of the parameters has an invalid value. This could be:
  • handle is NULL
  • params is invalid
  • index is out of range
  • srcSurface or its duplicate was not registered.
NVMEDIA_STATUS_ERRORAn internal failure occurred.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: No
    • Runtime: Yes
    • De-Init: No
See also
NvMedia2DComposeParameters
NvMedia2DCompose()
NvMedia2DRegisterNvSciBufObj()

◆ NvMedia2DSetTnrOutputNvSciBufObj()

NvMediaStatus NvMedia2DSetTnrOutputNvSciBufObj ( NvMedia2D const *const  handle,
NvMedia2DComposeParameters const  params,
NvSciBufObj const  tnrOutputSurface 
)

Sets the output surface for the TNR operation.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]paramsAn NvMedia2DComposeParameters handle.
[in]tnrOutputSurfaceThe NvSciBufObj to be used for the destination surface.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKParameters set successfully.
NVMEDIA_STATUS_BAD_PARAMETEROne of the parameters has an invalid value. This could be:
  • handle is NULL
  • params is invalid
  • tnrOutputSurface is invalid
  • tnrOutputSurface or its duplicate was not registered.
NVMEDIA_STATUS_ERRORAn internal failure occurred.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: No
    • Runtime: Yes
    • De-Init: No
See also
NvMedia2DComposeParameters
NvMedia2DCompose()
NvMedia2DRegisterNvSciBufObj()

◆ NvMedia2DSetTnrPreviousNvSciBufObj()

NvMediaStatus NvMedia2DSetTnrPreviousNvSciBufObj ( NvMedia2D const *const  handle,
NvMedia2DComposeParameters const  params,
NvSciBufObj const  tnrPreviousSurface 
)

Sets the previous surface for TNR operation.

The previous surface is the surface used as the TNR output surface with the previous NvMedia2DCompose() call.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]paramsAn NvMedia2DComposeParameters handle.
[in]tnrPreviousSurfaceThe NvSciBufObj to be used as a previous surface.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKParameters set successfully.
NVMEDIA_STATUS_BAD_PARAMETEROne of the parameters has an invalid value. This could be:
  • handle is NULL
  • params is invalid
  • tnrPreviousSurface is invalid
  • tnrPreviousSurface or its duplicate was not registered.
NVMEDIA_STATUS_ERRORAn internal failure occurred.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: No
    • Runtime: Yes
    • De-Init: No
See also
NvMedia2DComposeParameters
NvMedia2DCompose()
NvMedia2DRegisterNvSciBufObj()

◆ NvMedia2DSetXSobelDownsampledNvSciBufObj()

NvMediaStatus NvMedia2DSetXSobelDownsampledNvSciBufObj ( NvMedia2D const *const  handle,
NvMedia2DComposeParameters const  params,
NvSciBufObj const  xsobelDownsampledSurface 
)

Sets the surface for 4x4 downsampled XSobel output.

The surface must be a single-plane surface with format compatible with the first plane of the source surface. The surface dimensions must equal the destination rectangle dimensions rounded up to the nearest multiple of 4, and then divided by 4. For example, if the destination rectangle is 640x478 pixels, the 4x4 downsampled XSobel surface must be 160x120 pixels.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]paramsAn NvMedia2DComposeParameters handle.
[in]xsobelDownsampledSurfaceThe NvSciBufObj to be used for the destination downsampled XSobel surface.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKParameters set successfully.
NVMEDIA_STATUS_BAD_PARAMETEROne of the parameters has an invalid value. This could be:
  • handle is NULL
  • params is invalid
  • xsobelDownsampledSurface is invalid
  • xsobelDownsampledSurface or its duplicate was not registered.
NVMEDIA_STATUS_ERRORAn internal failure occurred.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: No
    • Runtime: Yes
    • De-Init: No
See also
NvMedia2DComposeParameters
NvMedia2DCompose()
NvMedia2DRegisterNvSciBufObj()

◆ NvMedia2DSetXSobelOutputNvSciBufObj()

NvMediaStatus NvMedia2DSetXSobelOutputNvSciBufObj ( NvMedia2D const *const  handle,
NvMedia2DComposeParameters const  params,
NvSciBufObj const  xsobelOutputSurface 
)

Sets the surface for XSobel output.

The surface must be a single-plane surface with format compatible with the first plane of the source surface. The surface dimensions must equal the destination rectangle dimensions.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]paramsAn NvMedia2DComposeParameters handle.
[in]xsobelOutputSurfaceThe NvSciBufObj to be used for the destination XSobel surface.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKParameters set successfully.
NVMEDIA_STATUS_BAD_PARAMETEROne of the parameters has an invalid value. This could be:
  • handle is NULL
  • params is invalid
  • xsobelOutputSurface is invalid
  • xsobelOutputSurface or its duplicate was not registered.
NVMEDIA_STATUS_ERRORAn internal failure occurred.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: No
    • Runtime: Yes
    • De-Init: No
See also
NvMedia2DComposeParameters
NvMedia2DCompose()
NvMedia2DRegisterNvSciBufObj()

◆ NvMedia2DUnregisterNvSciBufObj()

NvMediaStatus NvMedia2DUnregisterNvSciBufObj ( NvMedia2D const *const  handle,
NvSciBufObj const  bufObj 
)

Unregisters an NvSciBufObj with NvMedia2D.

Every NvSciBufObj registered with NvMedia2D by NvMedia2DRegisterNvSciBufObj() must be unregistered before you call NvMedia2DDestroy().

Parameters
[in]handlePointer to the NvMedia2D context.
[in]bufObjThe NvSciBufObj to be unregistered.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKBuffer unregistered successfully.
NVMEDIA_STATUS_BAD_PARAMETEROne of the parameters has an invalid value. This could be:
  • handle is NULL
  • bufObj is invalid
  • bufObj or its duplicate was not registered.
NVMEDIA_STATUS_INVALID_STATEThe function was called in incorrect system state.
NVMEDIA_STATUS_PENDINGThe buffer is still being used by a pending operation.
NVMEDIA_STATUS_ERRORAn internal failure occurred when trying to unregister the buffer.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: Yes
    • Runtime: No
    • De-Init: Yes
See also
NvMedia2DRegisterNvSciBufObj()

◆ NvMedia2DUnregisterNvSciSyncObj()

NvMediaStatus NvMedia2DUnregisterNvSciSyncObj ( NvMedia2D const *const  handle,
NvSciSyncObj const  syncObj 
)

Unregisters an NvSciSyncObj with NvMedia2D.

Every NvSciSyncObj registered with NvMedia2D by NvMedia2DRegisterNvSciSyncObj() must be unregistered before you call NvMedia2DDestroy().

Before the application calls this function, it must ensure that any NvMedia2DCompose() operation that uses the NvSciSyncObj has completed. If this function is called while NvSciSyncObj is still in use by any NvMedia2DCompose() operation, an error will be returned.

Parameters
[in]handlePointer to the NvMedia2D context.
[in]syncObjThe NvSciSyncObj to be unregistered.
Returns
An NvMediaStatus return code.
Return values
NVMEDIA_STATUS_OKSync object unregistered successfully.
NVMEDIA_STATUS_BAD_PARAMETEROne of the parameters has an invalid value. This could be:
  • handle is NULL
  • syncObj is invalid, or the sync object or its duplicate was not registered.
NVMEDIA_STATUS_INVALID_STATEThe function was called in incorrect system state.
NVMEDIA_STATUS_PENDINGThe sync object is still being used by a pending operation.
NVMEDIA_STATUS_ERRORAn internal failure occurred when trying to unregister the sync object.
Precondition


Usage considerations

  • Allowed context for the API call
    • Interrupt handler: No
    • Signal handler: No
    • Thread-safe: Yes, with the following conditions:
      • Each thread uses different NvMedia2D handle
    • Re-entrant: No
    • Async/Sync: Sync
  • Required privileges: None
  • API group
    • Init: Yes
    • Runtime: No
    • De-Init: Yes
See also
NvMedia2DRegisterNvSciSyncObj()
NvMedia2DSetNvSciSyncObjforEOF
NvMediaStatus NvMedia2DSetNvSciSyncObjforEOF(NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvSciSyncObj const syncObj)
Specifies the NvSciSyncObj to be used for EOF event.
handle
const WFDCommitType const WFDHandle handle
Definition: wfdext.h:124
NvMedia2DInsertPreNvSciSyncFence
NvMediaStatus NvMedia2DInsertPreNvSciSyncFence(NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvSciSyncFence const *const syncFence)
Insert an NvSciSyncFence as a pre-fence.
NvMedia2DCompose
NvMediaStatus NvMedia2DCompose(NvMedia2D const *const handle, NvMedia2DComposeParameters const params, NvMedia2DComposeResult *const result)
Performs a 2D compose operation.
params
DW_API_PUBLIC dwPointCloudRangeImageCreatorParams const *const params
Definition: PointCloudRangeImageCreator.h:292
NvMedia2DGetEOFNvSciSyncFence
NvMediaStatus NvMedia2DGetEOFNvSciSyncFence(NvMedia2D const *const handle, NvMedia2DComposeResult const *const result, NvSciSyncFence *const syncFence)
Gets an EOF NvSciSyncFence for an NvMedia2DCompose() operation.