Session Management¶
Functions to manage sessions.
API¶
MFXInit¶
-
mfxStatus
MFXInit
(mfxIMPL impl, mfxVersion *ver, mfxSession *session)¶ Creates and initializes a session in the legacy mode for compatibility with Intel(r) Media SDK applications. This function is deprecated starting from API version 2.0, applications must use MFXLoad with mfxCreateSession to select the implementation and initialize the session.
Call this function before calling any other API function. If the desired implementation specified by
impl
is MFX_IMPL_AUTO, the function will search for the platform-specific implementation. If the function cannot find the platform-specific implementation, it will use the software implementation instead.The
ver
argument indicates the desired version of the library implementation. The loaded implementation will have an API version compatible to the specified version (equal in the major version number, and no less in the minor version number.) If the desired version is not specified, the default is to use the API version from the library release with which an application is built.Production applications should always specify the minimum API version that meets the functional requirements. For example, if an application uses only H.264 decoding as described in API v1.0, the application should initialize the library with API v1.0. This ensures backward compatibility.
- Deprecated:
Deprecated in API version 2.3. Use MFXLoad and MFXCreateSession to initialize the session. Use MFX_DEPRECATED_OFF macro to turn off the deprecation message visualization.
- Return
MFX_ERR_NONE The function completed successfully. The output parameter contains the handle of the session.
MFX_ERR_UNSUPPORTED The function cannot find the desired legacy Intel(r) Media SDK implementation or version.
- Since
This function is available since API version 1.0.
- Parameters
[in] impl
: mfxIMPL enumerator that indicates the desired legacy Intel(r) Media SDK implementation.[in] ver
: Pointer to the minimum library version or zero, if not specified.[out] session
: Pointer to the legacy Intel(r) Media SDK session handle.
MFXInitEx¶
-
mfxStatus
MFXInitEx
(mfxInitParam par, mfxSession *session)¶ Creates and initializes a session in the legacy mode for compatibility with Intel(r) Media SDK applications. This function is deprecated starting from API version 2.0, applications must use MFXLoad with mfxCreateSession to select the implementation and initialize the session.
Call this function before calling any other API functions. If the desired implementation specified by
par
is MFX_IMPL_AUTO, the function will search for the platform-specific implementation. If the function cannot find the platform-specific implementation, it will use the software implementation instead.The argument
par.Version
indicates the desired version of the implementation. The loaded implementation will have an API version compatible to the specified version (equal in the major version number, and no less in the minor version number.) If the desired version is not specified, the default is to use the API version from the library release with which an application is built.Production applications should always specify the minimum API version that meets the functional requirements. For example, if an application uses only H.264 decoding as described in API v1.0, the application should initialize the library with API v1.0. This ensures backward compatibility.
The argument
par.ExternalThreads
specifies threading mode. Value 0 means that the implementation should create and handle work threads internally (this is essentially the equivalent of the regular MFXInit).- Deprecated:
Deprecated in API version 2.3. Use MFXLoad and MFXCreateSession to initialize the session. Use MFX_DEPRECATED_OFF macro to turn off the deprecation message visualization.
- Return
MFX_ERR_NONE The function completed successfully. The output parameter contains the handle of the session.
MFX_ERR_UNSUPPORTED The function cannot find the desired implementation or version.
- Since
This function is available since API version 1.14.
- Parameters
[in] par
: mfxInitParam structure that indicates the desired implementation, minimum library version and desired threading mode.[out] session
: Pointer to the session handle.
MFXInitialize¶
-
mfxStatus
MFXInitialize
(mfxInitializationParam par, mfxSession *session)¶ Creates and initializes a session starting from API version 2.0. This function is used by the dispatcher. The dispatcher creates and fills the mfxInitializationParam structure according to mfxConfig values set by an application. Calling this function directly is not recommended. Instead, applications must call the mfxCreateSession function.
- Return
MFX_ERR_NONE The function completed successfully. The output parameter contains the handle of the session.
MFX_ERR_UNSUPPORTED The function cannot find the desired implementation or version.
- Since
This function is available since API version 2.0.
- Parameters
[in] par
: mfxInitializationParam structure that indicates the minimum library version and acceleration type.[out] session
: Pointer to the session handle.
Important
The MFXInitialize()
function is mandatory for any implementation.
MFXClose¶
-
mfxStatus
MFXClose
(mfxSession session)¶ Completes and deinitializes a session. Any active tasks in execution or in queue are aborted. The application cannot call any API function after calling this function.
All child sessions must be disjoined before closing a parent session.
- Return
MFX_ERR_NONE The function completed successfully.
- Since
This function is available since API version 1.0.
- Parameters
[in] session
: session handle.
Important
The MFXClose()
function is mandatory for any implementation.
MFXQueryIMPL¶
-
mfxStatus
MFXQueryIMPL
(mfxSession session, mfxIMPL *impl)¶ Returns the implementation type of a given session.
- Return
MFX_ERR_NONE The function completed successfully.
- Since
This function is available since API version 1.0.
- Parameters
[in] session
: Session handle.[out] impl
: Pointer to the implementation type
MFXQueryVersion¶
-
mfxStatus
MFXQueryVersion
(mfxSession session, mfxVersion *version)¶ Returns the implementation version.
- Return
MFX_ERR_NONE The function completed successfully.
- Since
This function is available since API version 1.0.
- Parameters
[in] session
: Session handle.[out] version
: Pointer to the returned implementation version.
MFXJoinSession¶
-
mfxStatus
MFXJoinSession
(mfxSession session, mfxSession child)¶ Joins the child session to the current session.
After joining, the two sessions share thread and resource scheduling for asynchronous operations. However, each session still maintains its own device manager and buffer/frame allocator. Therefore, the application must use a compatible device manager and buffer/frame allocator to share data between two joined sessions.
The application can join multiple sessions by calling this function multiple times. When joining the first two sessions, the current session becomes the parent responsible for thread and resource scheduling of any later joined sessions.
Joining of two parent sessions is not supported.
- Return
MFX_ERR_NONE The function completed successfully.
MFX_WRN_IN_EXECUTION Active tasks are executing or in queue in one of the sessions. Call this function again after all tasks are completed.
MFX_ERR_UNSUPPORTED The child session cannot be joined with the current session.
- Since
This function is available since API version 1.1.
- Parameters
[inout] session
: The current session handle.[in] child
: The child session handle to be joined
MFXDisjoinSession¶
-
mfxStatus
MFXDisjoinSession
(mfxSession session)¶ Removes the joined state of the current session.
After disjoining, the current session becomes independent. The application must ensure there is no active task running in the session before calling this API function.
- Return
MFX_ERR_NONE The function completed successfully.
MFX_WRN_IN_EXECUTION Active tasks are executing or in queue in one of the sessions. Call this function again after all tasks are completed.
MFX_ERR_UNDEFINED_BEHAVIOR The session is independent, or this session is the parent of all joined sessions.
- Since
This function is available since API version 1.1.
- Parameters
[inout] session
: The current session handle.
MFXCloneSession¶
-
mfxStatus
MFXCloneSession
(mfxSession session, mfxSession *clone)¶ Creates a clean copy of the current session.
The cloned session is an independent session and does not inherit any user-defined buffer, frame allocator, or device manager handles from the current session. This function is a light-weight equivalent of MFXJoinSession after MFXInit.
- Return
MFX_ERR_NONE The function completed successfully.
- Since
This function is available since API version 1.1.
- Parameters
[in] session
: The current session handle.[out] clone
: Pointer to the cloned session handle.
MFXSetPriority¶
-
mfxStatus
MFXSetPriority
(mfxSession session, mfxPriority priority)¶ Sets the current session priority.
- Return
MFX_ERR_NONE The function completed successfully.
- Since
This function is available since API version 1.1.
- Parameters
[in] session
: The current session handle.[in] priority
: Priority value.
MFXGetPriority¶
-
mfxStatus
MFXGetPriority
(mfxSession session, mfxPriority *priority)¶ Returns the current session priority.
- Return
MFX_ERR_NONE The function completed successfully.
- Since
This function is available since API version 1.1.
- Parameters
[in] session
: The current session handle.[out] priority
: Pointer to the priority value.