Releases: uxlfoundation/oneAPI-spec
oneAPI-v1.4-rev-1
Changes since 1.3
oneMath (previously named oneMKL)
- Renamed oneMKL to oneMath
- Added programmatic versioning
- Significantly updated sparse BLAS APIs
- Improved type safety of DFT set_value and get_value APIs
- Const-qualified USM pointers for input matrices in LAPACK APIs
- Added out-of-place BLAS trmm and trsm APIs
- Added sparse BLAS APIs to support creation of matrices in the coordinate (COO) format
- Added beta and gamma distribution RNG device APIs
- Introduced external workspace for DFT APIs
- Supported more datatypes and extended parameter type for some RNG distribution device APIs
- Added alpha parameter to sparse BLAS trsv
- Added sorted_by_rows property to sparse BLAS matrix properties
- Constrained data_type in real-real in-place DFT APIs
- Constrained alpha and beta parameters to have same memory type in sparse BLAS APIs
- Fixed bugs
oneDNN
- no changes
oneDAL
- no changes
oneDPL
- Added a specification version macro
- Defined requirements for oneDPL header files
- Added new algorithms: transform_if, sort_by_key, stable_sort_by_key, histogram
- Added parallel range algorithms: 22 new algorithms in namespace oneapi::dpl::ranges
- Improved specifications of execution policies, iterators, and buffer wrappers and restructured the Parallel API section for improved access to these specification sections
- Improved C++ standard compliance of random number generators
oneTBB
- Added a specification version macro
- Added the specification of blocked_rangeNd
oneCCL
- no changes
oneAPI-v1.4-provisional-rev-1
This is a pre-release version of 1.4.
oneAPI-v1.3-rev-1
Changes since 1.2
oneDPL
- Specified how random number generators and distributions support sycl::vec
- Incremental improvements and fixes
oneCCL
- For oneCCL, we added new APIs for point to point send/recv operations.
Level Zero
- See Level Zero
oneTBB
- Allowed using pointers to class functions and members in place of function objects
- Incremental improvements and fixes, including fixes in the oneTBB named requirements
oneMKL
- Introduced RNG Device API
- Added complex version of BLAS SYR/SYR2/SYMV
- Added optional index_base parameter for BLAS IAMAX/IAMIN
- Allow either values or pointers for scalar parameters to BLAS
functions with USM interfaces - Added DFT move/copy constructor/assignment to descriptor class
- Added forward/backward strides to DFT API
- Added SYCL queue to Sparse BLAS matrix handle initialization API
- Added NNZ argument to Sparse BLAS set_csr_data API
- Fixed bugs
oneAPI-v1.3-provisional-rev-1
oneVPL-v2.9
New in this release:
- Deprecated :cpp:member:
mfxExtCodingOption2::BitrateLimit
. - Added note that applications must call MFXVideoENCODE_Query() to check for support of :cpp:struct:
mfxExtChromaLocInfo
and :cpp:struct:mfxExtHEVCRegion
extension buffers. - Added AV1 HDR metadata description and further clarified :cpp:struct:
mfxExtMasteringDisplayColourVolume
and :cpp:struct:mfxExtContentLightLevelInfo
. - Added deprecation messages to the functions :cpp:func:
MFXQueryAdapters
, :cpp:func:MFXQueryAdaptersDecode
, and :cpp:func:MFXQueryAdaptersNumber
.
Applications should use the process described in :ref:oneVPL Dispatcher <onevpl-dispatcher>
to enumerate and select adapters. - Fixed multiple spelling errors.
- Added extension buffer :cpp:struct:
mfxExtSyncSubmission
to return submission synchronization sync point. - Added extension buffer :cpp:struct:
mfxExtVPPPercEncPrefilter
to control perceptual encoding prefilter. - Deprecated
mfxPlatform::CodeName
and corresponding enum values. - Added :cpp:member:
mfxExtendedDeviceId::RevisionID
and :cpp:struct:extDeviceUUID
to be aligned across multiple domains including compute and specify device UUID accordingly. - Added extension buffer :cpp:struct:
mfxExtTuneEncodeQuality
and correspondent enumeration to specify encoding tuning option. - Updated description of :cpp:func:
MFXEnumImplementations
to clarify that the input :cpp:type:mfxImplCapsDeliveryFormat
determines the type of structure returned. - Updated mfxvideo++.h to use MFXLoad API.
oneAPI-v1.2-rev-1
Changes since 1.1
-
SYCL
The following extensions were added:
- sycl_ext_oneapi_assert - Support for device-side assert.
- sycl_ext_oneapi_default_context - Adds the concept of a platform default context.
- sycl_ext_oneapi_discard_queue_events - Adds a queue property that can optimize queues in some circumstances.
- sycl_ext_oneapi_srgb - Exposes sRGB support for images.
- sycl_ext_oneapi_usm_device_read_only - Adds a property for USM allocations.
-
oneDPL
The following updates were added in oneDPL specification for version 1.2:
- The content was reorganized.
- API for random number generation was added.
- Incremental improvements and bug fixes.
-
oneDNN
This is a new major release of oneDNN spec, which breaks compatibility with previously published versions.
- oneDNN Graph extension: a graph extension is added to allow seamless fusion of operations, and more flexibility for
backend specific optimizations. - reworked quantization workflow: in order to support dynamic quantization efficiently and allow better reuse of
primitive objects, quantization parameters are no longer passed at primitive creation, but at primitive execution.
This also allows to pass quantization parameters from device memory, instead of passing them from host memory. - opaque memory descriptors, and removal of operation descriptors: this allows more flexibility for oneDNN
implementation to add new memory layouts and primitive extensions without breaking compatibility. - Better support for type conversion fusion: all primitives now take separate descriptors for input and output,
which allows to fuse type conversions to all primitives.
- oneDNN Graph extension: a graph extension is added to allow seamless fusion of operations, and more flexibility for
-
Level Zero
-
oneTBB
The following updates were added in oneTBB specification for version 1.2:
- Support for core types and thread-per-core limit was added to task_arena constraints.
- API of concurrent_queue and concurrent_bounded_queue was extended to better match C++ standard containers.
- Incremental improvements and bug fixes.
-
oneVPL
This release updates oneVPL specification to version 2.8.0. New features include:
- Encode statistics API: A new API is introduced to provide access to encoder statistics at frame, tile,
slice, or block levels. - Improved multi-adapter support: Extended device ID reporting is added to provide additional properties
for device matching and identification outside of oneVPL. - Priority loading option for custom libraries: The environment variable ONEVPL_PRIORITY_PATH may be used to
force loading of user-defined libraries with highest priority. - ONEVPL_EXPERIMENTAL macro for introduction of experimental API features: Applications may access experimental
API features by defining ONEVPL_EXPERIMENTAL at build time. - Session initialization controls: New dispatcher configuration properties are introduced to set the number of
threads, configure the device copy mode, or attach extension buffers during session initialization. - Camera Processing API: A new API is introduced for processing Camera RAW data.
- Support for new video color formats: New color formats are added including 4:4:4 XYUV and
16-bit floating-point ABGR.
- Encode statistics API: A new API is introduced to provide access to encoder statistics at frame, tile,
-
oneMKL
The following updates were added in oneMKL specification for version 1.2:
- Dense matrix copy and transpose routines were added in the BLAS-like extensions
- half/bfloat16 precision support were added to several L1 BLAS routines
- The supported precisions for BLAS gemm and gemm_batch were updated
- Several routines in BLAS had const attributes properly assigned to arguments
- Add a missing constraint on parameter "n" for LAPACK orgqr routines
- Improve directories tree of VM, RNG, Stats domains of oneMKL. Fix minor issues in RNG
- Other changes include minor clarifications and bug fixes.
oneVPL v2.8
New in this release:
- Introduced MFX_FOURCC_ABGR16F FourCC for 16-bit float point (per channel) 4:4:4 ABGR format.
- Clarified the mfxExtMasteringDisplayColourVolume::DisplayPrimariesX, mfxExtMasteringDisplayColourVolume::DisplayPrimariesY for the video processing usage.
- Added MFX_CONTENT_NOISY_VIDEO in ContentInfo definition.
- Added Camera Processing API for Camera RAW data.
- Introduced hint to disable external video frames caching for GPU copy.
- Clarified usage of mfxExtMasteringDisplayColourVolume::InsertPayloadToggle and mfxExtContentLightLevelInfo::InsertPayloadToggle during decode operations.
- Fixed multiple spelling errors.
- Experimental API: introduced mfxExtMBQP::Pitch value for QP map defined in mfxExtMBQP.
- Clarified when MFXEnumImplementations() may be called for implementation capabilities query.
- Added table with filenames included in the dispatcher’s search process.
Bug Fixes:
- Fixed Experimental API table to note that mfxExtRefListCtrl and MFX_EXTBUFF_UNIVERSAL_REFLIST_CTRL were moved to production in version 2.8.
oneAPI-v1.2-provisional-rev-1
cleanup for 1.2 provisional rev 1 (#436)
oneVPL v2.7.1
Bug Fixes:
- changed use of word "interface" in header to avoid conflict with MSVC reserved words.
oneVPL v2.7.0
New in this release:
- mfxExtVppAuxData::RepeatedFrame flag has been un-deprecated.
- Clarified GPUCopy control behavior.
- Introduced MFX_FOURCC_XYUV FourCC for non-alpha packed 4:4:4 format.
- Notice added to the mfxFrameSurfaceInterface::OnComplete to clarify when library can call this callback.
- Annotated missed aliases mfxExtHEVCRefListCtrl, mfxExtHEVCRefLists, mfxExtHEVCTemporalLayers.
- Refined description of mfxExtMasteringDisplayColourVolume and mfxExtContentLightLevelInfo for HDR SEI decoder usage.
- Experimental API: introduced interface to get statistics after encode.
- New dispatcher config properties:
- Pass through extension buffer to mfxInitializationParam.
- Select host or device responsible for the memory copy between host and device.
Bug Fixes:
- Fixed misprint in mfxExtDeviceAffinityMask description.
- MFXVideoENCODE_Query description fixed for query mode 1.