NVIDIA DRIVE OS Linux SDK API Reference

6.0.8 Release
nvmedia_dla.h
Go to the documentation of this file.
1 /*
2  * SPDX-FileCopyrightText: Copyright (c) 2017-2023 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
3  * SPDX-License-Identifier: LicenseRef-NvidiaProprietary
4  *
5  * NVIDIA CORPORATION, its affiliates and licensors retain all intellectual
6  * property and proprietary rights in and to this material, related
7  * documentation and any modifications thereto. Any use, reproduction,
8  * disclosure or distribution of this material and related documentation
9  * without an express license agreement from NVIDIA CORPORATION or
10  * its affiliates is strictly prohibited.
11  */
12 
20 #ifndef NVMEDIA_DLA_H
21 #define NVMEDIA_DLA_H
22 
23 #ifdef __cplusplus
24 extern "C" {
25 #endif
26 
27 #include "nvmedia_core.h"
28 #include "nvmedia_tensor.h"
29 
51 #define NVMEDIA_DLA_VERSION_MAJOR 4
52 
53 #define NVMEDIA_DLA_VERSION_MINOR 0
54 
55 #define NVMEDIA_DLA_VERSION_PATCH 0
56 
67 #define NVMEDIA_DLA_TENSOR_DESC_NAME_MAX_LEN (80U)
68 
70 #define NVMEDIA_DLA_DEFAULT_TASKTIMEOUT (100000U)
71 
78 typedef struct NvMediaDla NvMediaDla;
79 
83 typedef struct {
85  uint8_t major;
87  uint8_t minor;
89  uint8_t subMinor;
91 
95 typedef enum {
99 
103 typedef struct {
107 
111 typedef struct {
117 
125 
129 typedef struct {
131  uint8_t const *loadable;
133  uint64_t loadableSize;
135 
139 typedef struct {
143  uint32_t numArgs;
145 
149 typedef struct {
155  uint32_t numAttrs;
157 
194  NvMediaVersion *version
195 );
196 
231  const uint32_t dlaId
232 );
233 
259 NvMediaDla *
260 NvMediaDlaCreate(void);
261 
293  NvMediaDla *dla
294 );
295 
332  const NvMediaDla *dla,
333  NvMediaDlaUMDVersion *version
334 );
335 
370  const NvMediaDla *dla,
371  uint16_t *numEngines
372 );
373 
410  const NvMediaDla *dla,
411  uint32_t *maxOutstandingTasks
412 );
413 
455  NvMediaDla *dla,
456  uint32_t dlaId,
457  uint32_t numTasks
458 );
459 
498  const NvMediaDla *dla,
499  uint32_t *dlaId
500 );
501 
540  const NvMediaDla *dla,
541  uint32_t *numTasks
542 );
543 
579  NvMediaDla *dla,
580  NvMediaDlaLoadable **loadable
581 );
582 
617  const NvMediaDla *dla,
618  NvMediaDlaLoadable *loadable
619 );
620 
667  const NvMediaDla *dla,
668  const NvMediaDlaBinaryLoadable binaryLoadable,
669  NvMediaDlaLoadable *loadable
670 );
671 
716  const NvMediaDla *dla,
717  NvMediaDlaLoadable *loadable
718 );
719 
756  NvMediaDla *dla,
757  const NvMediaDlaLoadable *loadable
758 );
759 
798  const NvMediaDla *dla,
799  int32_t *numOfInputTensors
800 );
801 
843  const NvMediaDla *dla,
844  const uint32_t idx,
845  NvMediaDlaTensorDescriptor *descriptor
846 );
847 
886  const NvMediaDla *dla,
887  int32_t *numOfOutputTensors
888 );
889 
932  const NvMediaDla *dla,
933  const uint32_t idx,
934  NvMediaDlaTensorDescriptor *descriptor
935 );
936 
973  const NvMediaDla *dla,
974  const NvMediaDlaData *dlaData,
975  uint32_t flags
976 );
977 
1015  const NvMediaDla *dla,
1016  const NvMediaDlaData *dlaData
1017 );
1018 
1052  NvMediaDla *dla
1053 );
1054 
1090  NvMediaDla *dla
1091 );
1092 
1166  NvMediaDla *dla,
1167  const NvMediaDlaArgs *inputArgs,
1168  const NvMediaDlaArgs *scratchpadArgs,
1169  const NvMediaDlaArgs *outputArgs,
1170  uint32_t taskTimeout
1171 );
1172 
1241  NvMediaDla *dla,
1242  const NvMediaDlaArgs *inputArgs,
1243  const NvMediaDlaArgs *scratchpadArgs,
1244  const NvMediaDlaArgs *outputArgs
1245 );
1246 
1247 /*
1248  * \defgroup history_nvmedia_dla History
1249  * Provides change history for the NvMedia DLA API.
1250  *
1251  * \section history_nvmedia_dla Version History
1252  *
1253  * <b> Version 1.0 </b> Oct 31, 2017
1254  * - Initial Release.
1255  *
1256  * <b> Version 1.1 </b> Feb 12, 2018
1257  * - Add separate functionality to load from memory.
1258  *
1259  * <b> Version 1.2 </b> Mar 12, 2018
1260  * - Add query API's for version, num engines, maxOutstandingRequests.
1261  *
1262  * <c> Version 1.3 </b> Mar 26, 2018
1263  * - Add helper to query tensor descriptor.
1264  *
1265  * <c> Version 1.4 </b> May 3, 2018
1266  * - Add dynamic task timeout support.
1267  *
1268  * <c> Version 2.0 </b> June 26, 2018
1269  * - Remove load using filename functionality.
1270  *
1271  * <c> Version 2.1 </b> August 13, 2018
1272  * - Add NvMediaDlaPingById. NvMediaDlaPing will be deprecated in the future.
1273  *
1274  * <c> Version 2.2 </b> Oct 1, 2018
1275  * - Add new API NvMediaDlaGetUMDVersion and data structure NvMediaDlaUMDVersion.
1276  *
1277  * <c> Version 2.3 </b> Dec 14, 2018
1278  * - Add new API NvMediaLoadableIdCreate, NvMediaLoadableIdDestroy,
1279  * NvMediaDlaAppendLoadable, NvMediaDlaLoadLoadable, NvMediaDlaSetCurrentLoadable,
1280  * NvMediaDlaInit, NvMediaDlaGetScratchpadDescriptor and NvMediaDlaBindScratchpad.
1281  * - Add new structure NvMediaDlaLoadableId, NvMediaDlaLoadable and NvMediaDlaScratchpadDescriptor.
1282  *
1283  * <c> Version 2.4 </b> Jan 9, 2019
1284  * - Remove NvMediaImage as Dla data.
1285  *
1286  * <c> Version 2.5 </b> Mar 7, 2019
1287  * - Rename NvMediaLoadableIdCreate to NvMediaDlaLoadableIdCreate.
1288  * - Rename NvMediaLoadableIdDestroy to NvMediaDlaLoadableIdDestroy.
1289  *
1290  * <c> Version 2.6 </b> Mar 11, 2019
1291  * - Add new API NvMediaDlaDataRegister and NvMediaDlaDataUnRegister.
1292  *
1293  * <c> Version 2.7 </b> Mar 13, 2019
1294  * - Deprecate NvMediaDlaPing API.
1295  *
1296  * <c> Version 2.8 </b> Mar 14, 2019
1297  * - Deprecate NvMediaDlaSubmit API.
1298  *
1299  * <c> Version 3.0 </b> April 19, 2019
1300  * - Add NvMediaDlaSubmit as new API for task submission.
1301  * - Move to new APIs for NvMediaDla programming.
1302  * - Mark NvMediaDlaLoadFromMemory, NvMediaDlaSubmitTimeout
1303  * and NvMediaDlaGetMaxOutstandingRequests as deprecated APIs.
1304  *
1305  * <c> Version 3.1 </b> July 08, 2019
1306  * - Remove the restriction of calling sequence for data registration.
1307  *
1308  * <c> Version 3.2 </b> July 30, 2019
1309  * - Deleting NvMediaDlaGetScratchpadDescriptor and NvMediaDlaBindScratchpad.
1310  * - added const for parameters in APIs that do not modify the parameter
1311  *
1312  * <c> Version 3.3 </b> Sep 9th, 2019
1313  * - Deprecate following APIs: NvMediaDlaLoadFromMemory, NvMediaDlaSubmitTimeout
1314  * and NvMediaDlaGetMaxOutstandingRequests
1315  *
1316  * <c> Version 3.4 </b> Jan 22, 2020
1317  * - Add const to NvMediaDlaSubmit to comply with MISRA rule 8.13
1318  *
1319  * <c> Version 3.5 </b> Mar 28, 2020
1320  * - Update possible return status of NvMediaDlaGetNumEngines, NvMediaDlaGetInstanceId,
1321  * NvMediaDlaGetNumTasks, NvMediaDlaSubmit.
1322  *
1323  * <c> Version 3.6 </b> Apr 24, 2020
1324  * - Removed const from NvMediaDlaSetCurrentLoadable and
1325  * NvMediaDlaRemoveLoadable to support new functionality
1326  *
1327  * <c> Version 3.7 </b> Nov 30, 2020
1328  * - Updated doxygen comments for NvMediaDlaSubmit.
1329  *
1330  * <c> Version 3.8 </b> Jan 5, 2021
1331  * - Updated last sentence of NvMediaDlaSubmit restrictions.
1332  *
1333  * <c> Version 3.9 </b> Mar 1, 2021
1334  * - Updated doxy comments for NvMediaDlaSubmit,NvMediaDlaGetInput/OutputTensorDescriptor.
1335  *
1336  * <c> Version 3.10 </b> Mar 22, 2021
1337  * - Updated doxy comments for NvMediaDlaAppendLoadable.
1338  *
1339  * <c> Version 3.11 </b> Jul 20, 2021
1340  * - Added "submit with bypass execution" feature (NvMediaDlaSubmitBypass).
1341  *
1342  * <b> Version 3.12 </b> August 20, 2021
1343  * - Update doxygen comments for All APIs to have Thread safety information and API Group information
1344  *
1345  * <b> Version 4.0 </b> September 2, 2021
1346  * - Adding Const Qualifier for loadable member in NvMediaDlaBinaryLoadable
1347  *
1348  * <b> Version 4.0 </b> February 08, 2022
1349  * - Updated the doxygen comments with usage considerations for all APIs.
1350  *
1351  * <b> Version 4.0 </b> April 04, 2022
1352  * - Updated doxy comments for NvMediaDlaAppendLoadable, NvMediaDlaRemoveLoadable.
1353  * - Updated valid range for structures.
1354  *
1355  * <b> Version 4.0.0 </b> May 10, 2022
1356  * - Added patch version number macro: NVMEDIA_DLA_VERSION_PATCH.
1357  *
1358  */
1363 #ifdef __cplusplus
1364 }
1365 #endif
1366 
1367 #endif // NVMEDIA_DLA_H
NvMediaDlaDataPointer::tensor
NvMediaTensor * tensor
A pointer to NvMediaTensor.
Definition: nvmedia_dla.h:105
NvMediaDlaGetNumOfInputTensors
NvMediaStatus NvMediaDlaGetNumOfInputTensors(const NvMediaDla *dla, int32_t *numOfInputTensors)
Gets the number of input tensors for the current loadable in the NvMediaDla context.
NvMediaDlaUMDVersion::minor
uint8_t minor
Minor version.
Definition: nvmedia_dla.h:87
NvMediaDlaArgs
Holds input and output DLA data.
Definition: nvmedia_dla.h:139
NvMediaDlaSubmit
NvMediaStatus NvMediaDlaSubmit(NvMediaDla *dla, const NvMediaDlaArgs *inputArgs, const NvMediaDlaArgs *scratchpadArgs, const NvMediaDlaArgs *outputArgs, uint32_t taskTimeout)
Submits a job to the DLA to run the network on a set of input NvMediaDla arguments and a timeout valu...
NvMediaDlaDataPointer
Holds pointers to the DLA data.
Definition: nvmedia_dla.h:103
NvMediaDlaDataUnregister
NvMediaStatus NvMediaDlaDataUnregister(const NvMediaDla *dla, const NvMediaDlaData *dlaData)
Unregisters an NvMediaDlaData after use.
NvMediaStatus
NvMediaStatus
Defines all possible error codes.
Definition: nvmedia_core.h:104
NvMediaDlaLoadable
struct NvMediaDlaLoadable NvMediaDlaLoadable
Holds a handle to NvMediaDlaLoadable.
Definition: nvmedia_dla.h:124
NvMediaDlaInit
NvMediaStatus NvMediaDlaInit(NvMediaDla *dla, uint32_t dlaId, uint32_t numTasks)
Configures the context for a particular DLA engine.
NvMediaDlaBinaryLoadable::loadable
const uint8_t * loadable
Pointer to in-memory loadable.
Definition: nvmedia_dla.h:131
NvMediaDlaRemoveLoadable
NvMediaStatus NvMediaDlaRemoveLoadable(NvMediaDla *dla)
Removes the current loadable from the provided NvMediaDla context.
nvmedia_tensor.h
NVIDIA Media Interface: Tensor Processing
NvMediaVersion
Holds NvMedia version information.
Definition: nvmedia_core.h:164
NvMediaDlaUMDVersion
Holds the DLA UMD version.
Definition: nvmedia_dla.h:83
NvMediaDlaArgs::numArgs
uint32_t numArgs
Number of NvMediaDlaData.
Definition: nvmedia_dla.h:143
NvMediaDlaDataRegister
NvMediaStatus NvMediaDlaDataRegister(const NvMediaDla *dla, const NvMediaDlaData *dlaData, uint32_t flags)
Registers an NvMediaDlaData for use with an NvMediaDla handle.
NvMediaDlaAppendLoadable
NvMediaStatus NvMediaDlaAppendLoadable(const NvMediaDla *dla, const NvMediaDlaBinaryLoadable binaryLoadable, NvMediaDlaLoadable *loadable)
Appends a loadable to the NvMediaDla context.
NvMediaDlaUMDVersion::major
uint8_t major
Major version.
Definition: nvmedia_dla.h:85
NvMediaDlaGetNumOfOutputTensors
NvMediaStatus NvMediaDlaGetNumOfOutputTensors(const NvMediaDla *dla, int32_t *numOfOutputTensors)
Gets the number of output tensors for the current loadable in the NvMediaDla context.
NvMediaTensor
struct NvMediaTensor NvMediaTensor
A handle representing tensor objects.
Definition: nvmedia_tensor.h:88
NVM_TENSOR_ATTR_MAX
@ NVM_TENSOR_ATTR_MAX
Defines the maximum number of tensor creation attributes.
Definition: nvmedia_tensor.h:118
nvmedia_core.h
NVIDIA Media Interface: Core
NvMediaDlaGetMaxOutstandingTasks
NvMediaStatus NvMediaDlaGetMaxOutstandingTasks(const NvMediaDla *dla, uint32_t *maxOutstandingTasks)
Returns the maximum number of tasks that can be queued to an instance of an engine.
NvMediaDlaGetNumEngines
NvMediaStatus NvMediaDlaGetNumEngines(const NvMediaDla *dla, uint16_t *numEngines)
Returns the number of DLA hardware engines available.
NvMediaDlaGetInstanceId
NvMediaStatus NvMediaDlaGetInstanceId(const NvMediaDla *dla, uint32_t *dlaId)
Returns the instance id of the NvMediaDla.
NvMediaDlaAppendDiagnosticLoadable
NvMediaStatus NvMediaDlaAppendDiagnosticLoadable(const NvMediaDla *dla, NvMediaDlaLoadable *loadable)
Appends diagnostic loadable to the NvMediaDla context.
NvMediaDlaGetOutputTensorDescriptor
NvMediaStatus NvMediaDlaGetOutputTensorDescriptor(const NvMediaDla *dla, const uint32_t idx, NvMediaDlaTensorDescriptor *descriptor)
Gets the output tensor descriptor for the current loadable in the NvMediaDla context.
NVMEDIA_DLA_TENSOR_DESC_NAME_MAX_LEN
#define NVMEDIA_DLA_TENSOR_DESC_NAME_MAX_LEN
Maximum length of the name of the tensor to store in the descriptor.
Definition: nvmedia_dla.h:67
NvMediaDlaGetUMDVersion
NvMediaStatus NvMediaDlaGetUMDVersion(const NvMediaDla *dla, NvMediaDlaUMDVersion *version)
Returns the version information for the NvMedia DLA UMD library.
NvMediaDlaLoadLoadable
NvMediaStatus NvMediaDlaLoadLoadable(NvMediaDla *dla)
Loads the current loadable to the provided NvMediaDla context.
NvMediaDlaTensorDescriptor::numAttrs
uint32_t numAttrs
Holds the number of tensor attributes in tensorAttrs[ ].
Definition: nvmedia_dla.h:155
NvMediaDlaLoadableCreate
NvMediaStatus NvMediaDlaLoadableCreate(NvMediaDla *dla, NvMediaDlaLoadable **loadable)
Creates a loadable handle.
NvMediaDlaLoadableDestroy
NvMediaStatus NvMediaDlaLoadableDestroy(const NvMediaDla *dla, NvMediaDlaLoadable *loadable)
Destroys a loadable handle.
NvMediaDlaTensorDescriptor
Holds tensor attributes.
Definition: nvmedia_dla.h:149
NvMediaDlaGetVersion
NvMediaStatus NvMediaDlaGetVersion(NvMediaVersion *version)
Returns the version information for the NvMediaDla library.
NvMediaDlaBinaryLoadable::loadableSize
uint64_t loadableSize
Size (in bytes) of in-memory loadable.
Definition: nvmedia_dla.h:133
NvMediaDlaBinaryLoadable
Holds attributes for populating binary loadables for NvMediaDla.
Definition: nvmedia_dla.h:129
NvMediaDlaPingById
NvMediaStatus NvMediaDlaPingById(const uint32_t dlaId)
Checks the status of the DLA engine.
NvMediaDla
struct NvMediaDla NvMediaDla
Holds a handle to the NvMedia DLA device.
Definition: nvmedia_dla.h:78
NvMediaDlaGetInputTensorDescriptor
NvMediaStatus NvMediaDlaGetInputTensorDescriptor(const NvMediaDla *dla, const uint32_t idx, NvMediaDlaTensorDescriptor *descriptor)
Gets the input tensor descriptor for the current loadable in the NvMediaDla context.
NvMediaDlaSubmitBypass
NvMediaStatus NvMediaDlaSubmitBypass(NvMediaDla *dla, const NvMediaDlaArgs *inputArgs, const NvMediaDlaArgs *scratchpadArgs, const NvMediaDlaArgs *outputArgs)
Submits a job to the DLA but its execution is skipped.
NvMediaDlaData::type
NvMediaDlaDataType type
An NvMediaDlaDataType type.
Definition: nvmedia_dla.h:113
NVMEDIA_DLA_DATA_TYPE_TENSOR
@ NVMEDIA_DLA_DATA_TYPE_TENSOR
NvMediaTensor data type.
Definition: nvmedia_dla.h:97
NvMediaDlaDestroy
NvMediaStatus NvMediaDlaDestroy(NvMediaDla *dla)
Destroys a DLA engine instance created by NvMediaDlaCreate().
NvMediaTensorAttr
Holds tensor creation attributes.
Definition: nvmedia_tensor.h:155
NvMediaDlaSetCurrentLoadable
NvMediaStatus NvMediaDlaSetCurrentLoadable(NvMediaDla *dla, const NvMediaDlaLoadable *loadable)
Sets the current loadable for the NvMediaDla.
NvMediaDlaCreate
NvMediaDla * NvMediaDlaCreate(void)
Creates a default context for NvMediaDla.
NvMediaDlaData::pointer
NvMediaDlaDataPointer pointer
A pointer to NvMediaDlaDataPointer.
Definition: nvmedia_dla.h:115
NvMediaDlaDataType
NvMediaDlaDataType
Defines the data types that DLA can operate on.
Definition: nvmedia_dla.h:95
NvMediaDlaGetNumTasks
NvMediaStatus NvMediaDlaGetNumTasks(const NvMediaDla *dla, uint32_t *numTasks)
Returns the number of outstanding tasks of NvMediaDla.
NvMediaDlaUMDVersion::subMinor
uint8_t subMinor
Sub-minor version.
Definition: nvmedia_dla.h:89
NvMediaDlaArgs::dlaData
NvMediaDlaData * dlaData
Pointer to array of NvMediaDlaData.
Definition: nvmedia_dla.h:141
NvMediaDlaData
Specifies the data type and data pointer.
Definition: nvmedia_dla.h:111