![]() |
DSPLIB User Guide
|
Header file for kernel's internal use. For the kernel's interface, please see DSPLIB_fir.
Definition in file DSPLIB_fir_priv.h.
Go to the source code of this file.
Data Structures | |
| struct | DSPLIB_fir_PrivArgs |
| Structure that is reserved for internal use by the kernel. More... | |
Macros | |
| #define | DSPLIB_FIR_IXX_IXX_OXX_PBLOCK_SIZE (3 * SE_PARAM_SIZE + 1 * DSPLIB_PARAM_SIZE + 2 * sizeof(int32_t)) |
| Macro to define the size of bufPblock array of DSPLIB_fir_PrivArgs structure. More... | |
Typedefs | |
| typedef DSPLIB_STATUS(* | pFxnDSPLIB_fir_exec) (DSPLIB_kernelHandle handle, void *restrict pIn, void *restrict pFilter, void *restrict pOut) |
| This is a function pointer type that conforms to the declaration of DSPLIB_fir_exec_ci and DSPLIB_fir_exec_cn. More... | |
Functions | |
| template<typename dataType > | |
| DSPLIB_STATUS | DSPLIB_fir_init_ci (DSPLIB_kernelHandle handle, const DSPLIB_bufParams2D_t *bufParamsIn, const DSPLIB_bufParams2D_t *bufParamsFilter, const DSPLIB_bufParams2D_t *bufParamsOut, const DSPLIB_fir_InitArgs *pKerInitArgs) |
| This function is the initialization function for the C7x implementation of the kernel. The function declaration conforms to the declaration of DSPLIB_fir_init. More... | |
| template<typename dataType > | |
| DSPLIB_STATUS | DSPLIB_fir_exec_ci (DSPLIB_kernelHandle handle, void *restrict pIn, void *restrict pFilter, void *restrict pOut) |
| This function is the main execution function for the C7x implementation of the kernel. The function declaration conforms to the declaration of DSPLIB_fir_exec. More... | |
| template<typename dataType , typename accumulateType > | |
| DSPLIB_STATUS | DSPLIB_fir_exec_cn (DSPLIB_kernelHandle handle, void *restrict pIn, void *restrict pFilter, void *restrict pOut) |
| This function is the main execution function for the natural C implementation of the kernel. The function declaration conforms to the declaration of DSPLIB_fir_exec. More... | |
| template<typename dataType > | |
| DSPLIB_STATUS | DSPLIB_fir_getSizes (const DSPLIB_fir_InitArgs *pKerInitArgs, DSPLIB_bufParams2D_t *bufParamsIn, DSPLIB_bufParams2D_t *bufParamsFilter, DSPLIB_bufParams2D_t *bufParamsOut) |
| This function is a utility function that the application calls to obtain the sizes of data buffers. More... | |
| DSPLIB_STATUS | DSPLIB_fir_init_cn (DSPLIB_kernelHandle handle, DSPLIB_bufParams2D_t *bufParamsIn, DSPLIB_bufParams2D_t *bufParamsFilter, DSPLIB_bufParams2D_t *bufParamsOut, DSPLIB_fir_InitArgs *pKerInitArgs) |
| This function is the initialization function for the natural C implementation of the kernel. The function declaration conforms to the declaration of DSPLIB_fir_init. More... | |
| #define DSPLIB_FIR_IXX_IXX_OXX_PBLOCK_SIZE (3 * SE_PARAM_SIZE + 1 * DSPLIB_PARAM_SIZE + 2 * sizeof(int32_t)) |
Macro to define the size of bufPblock array of DSPLIB_fir_PrivArgs structure.
Definition at line 38 of file DSPLIB_fir_priv.h.
| typedef DSPLIB_STATUS(* pFxnDSPLIB_fir_exec) (DSPLIB_kernelHandle handle, void *restrict pIn, void *restrict pFilter, void *restrict pOut) |
This is a function pointer type that conforms to the declaration of DSPLIB_fir_exec_ci and DSPLIB_fir_exec_cn.
Definition at line 45 of file DSPLIB_fir_priv.h.
| DSPLIB_STATUS DSPLIB_fir_init_ci | ( | DSPLIB_kernelHandle | handle, |
| const DSPLIB_bufParams2D_t * | bufParamsIn, | ||
| const DSPLIB_bufParams2D_t * | bufParamsFilter, | ||
| const DSPLIB_bufParams2D_t * | bufParamsOut, | ||
| const DSPLIB_fir_InitArgs * | pKerInitArgs | ||
| ) |
This function is the initialization function for the C7x implementation of the kernel. The function declaration conforms to the declaration of DSPLIB_fir_init.
This function determines the configuration for the streaming engine and MMA hardware resources based on the function call parameters, and the configuration is saved in bufPBlock array. In the kernel call sequence, DSPLIB_fir_exec_ci would be called later independently by the application. When DSPLIB_fir_exec_ci runs, it merely retrieves the configuration from the bufPBlock and uses it to set up the hardware resources. This arrangement is so that DSPLIB_fir_exec_ci does not lose cycles to determine the hardware configuration.
| [in] | handle | : Active handle to the kernel |
| [in] | bufParamsIn | : Pointer to the structure containing dimensional information of input buffer |
| [in] | bufParamsFilter | : Pointer to the structure containing dimensional information of filter buffer |
| [out] | bufParamsOut | : Pointer to the structure containing dimensional information of ouput buffer |
| [in] | pKerInitArgs | : Pointer to the structure holding init parameters |
Definition at line 128 of file DSPLIB_fir_ci.cpp.
| DSPLIB_STATUS DSPLIB_fir_exec_ci | ( | DSPLIB_kernelHandle | handle, |
| void *restrict | pIn, | ||
| void *restrict | pFilter, | ||
| void *restrict | pOut | ||
| ) |
This function is the main execution function for the C7x implementation of the kernel. The function declaration conforms to the declaration of DSPLIB_fir_exec.
The function uses MMA hardware accelerator to perform the convolution computation. Filter data is loaded into B panel of the MMA from memory using one streaming engine, while the input data is loaded into A vectors of the MMA using the other streaming engine. Result of the compute from MMA C panel is stored into memory using a stream address generator.
| [in] | handle | : Active handle to the kernel |
| [in] | pIn | : Pointer to buffer holding the input data |
| [in] | pFilter | : Pointer to buffer holding the filter data |
| [out] | pOut | : Pointer to buffer holding the output data |
Definition at line 424 of file DSPLIB_fir_ci.cpp.
| DSPLIB_STATUS DSPLIB_fir_exec_cn | ( | DSPLIB_kernelHandle | handle, |
| void *restrict | pIn, | ||
| void *restrict | pFilter, | ||
| void *restrict | pOut | ||
| ) |
This function is the main execution function for the natural C implementation of the kernel. The function declaration conforms to the declaration of DSPLIB_fir_exec.
| [in] | handle | : Active handle to the kernel |
| [in] | pIn | : Pointer to buffer holding the input data |
| [in] | pFilter | : Pointer to buffer holding the filter data |
| [out] | pOut | : Pointer to buffer holding the output data |
Definition at line 43 of file DSPLIB_fir_cn.cpp.
| DSPLIB_STATUS DSPLIB_fir_init_cn | ( | DSPLIB_kernelHandle | handle, |
| DSPLIB_bufParams2D_t * | bufParamsIn, | ||
| DSPLIB_bufParams2D_t * | bufParamsFilter, | ||
| DSPLIB_bufParams2D_t * | bufParamsOut, | ||
| DSPLIB_fir_InitArgs * | pKerInitArgs | ||
| ) |
This function is the initialization function for the natural C implementation of the kernel. The function declaration conforms to the declaration of DSPLIB_fir_init.
| [in] | handle | : Active handle to the kernel |
| [in] | bufParamsIn | : Pointer to the structure containing dimensional information of input buffer |
| [in] | bufParamsFilter | : Pointer to the structure containing dimensional information of filter buffer |
| [out] | bufParamsOut | : Pointer to the structure containing dimensional information of ouput buffer |
| [in] | pKerInitArgs | : Pointer to the structure holding init parameters |
Definition at line 31 of file DSPLIB_fir_cn.cpp.