TI J721E Imaging User Guide
hwa_vpac_nf.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright (c) 2019-2021 Texas Instruments Incorporated
4  *
5  * All rights reserved not granted herein.
6  *
7  * Limited License.
8  *
9  * Texas Instruments Incorporated grants a world-wide, royalty-free, non-exclusive
10  * license under copyrights and patents it now or hereafter owns or controls to make,
11  * have made, use, import, offer to sell and sell ("Utilize") this software subject to the
12  * terms herein. With respect to the foregoing patent license, such license is granted
13  * solely to the extent that any such patent is necessary to Utilize the software alone.
14  * The patent license shall not apply to any combinations which include this software,
15  * other than combinations with devices manufactured by or for TI ("TI Devices").
16  * No hardware patent is licensed hereunder.
17  *
18  * Redistributions must preserve existing copyright notices and reproduce this license
19  * (including the above copyright notice and the disclaimer and (if applicable) source
20  * code license limitations below) in the documentation and/or other materials provided
21  * with the distribution
22  *
23  * Redistribution and use in binary form, without modification, are permitted provided
24  * that the following conditions are met:
25  *
26  * * No reverse engineering, decompilation, or disassembly of this software is
27  * permitted with respect to any software provided in binary form.
28  *
29  * * any redistribution and use are licensed by TI for use only with TI Devices.
30  *
31  * * Nothing shall obligate TI to provide you with source code for the software
32  * licensed and provided to you in object code.
33  *
34  * If software source code is provided to you, modification and redistribution of the
35  * source code are permitted provided that the following conditions are met:
36  *
37  * * any redistribution and use of the source code, including any resulting derivative
38  * works, are licensed by TI for use only with TI Devices.
39  *
40  * * any redistribution and use of any object code compiled from the source code
41  * and any resulting derivative works, are licensed by TI for use only with TI Devices.
42  *
43  * Neither the name of Texas Instruments Incorporated nor the names of its suppliers
44  *
45  * may be used to endorse or promote products derived from this software without
46  * specific prior written permission.
47  *
48  * DISCLAIMER.
49  *
50  * THIS SOFTWARE IS PROVIDED BY TI AND TI'S LICENSORS "AS IS" AND ANY EXPRESS
51  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
52  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
53  * IN NO EVENT SHALL TI AND TI'S LICENSORS BE LIABLE FOR ANY DIRECT, INDIRECT,
54  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
55  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
56  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
57  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
58  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
59  * OF THE POSSIBILITY OF SUCH DAMAGE.
60  *
61  */
62 
63 #ifndef HWA_VPAC_NF_H_
64 #define HWA_VPAC_NF_H_
65 
66 #include <VX/vx.h>
67 #include <VX/vx_kernels.h>
68 
69 #ifdef __cplusplus
70 extern "C" {
71 #endif
72 
81 #define TIVX_KERNEL_VPAC_NF_GENERIC_NAME "com.ti.hwa.vpac_nf_generic"
82 
86 #define TIVX_KERNEL_VPAC_NF_BILATERAL_NAME "com.ti.hwa.vpac_nf_bilateral"
87 
88 
89 /*********************************
90  * VPAC_NF Control Commands
91  *********************************/
92 
97 #define TIVX_VPAC_NF_CMD_SET_HTS_LIMIT (0x10000000u)
98 
103 #define TIVX_VPAC_NF_CMD_SET_COEFF (0x10000001u)
104 
119 #define TIVX_VPAC_NF_CMD_GET_ERR_STATUS (0x10000002u)
120 
124 #define TIVX_VPAC_NF_CMD_GET_PSA_STATUS (0x10000003u)
125 
126 /*********************************
127  * VPAC_NF Defines
128  *********************************/
129 
137 #define TIVX_VPAC_NF_RD_ERR (0x400U)
138 
139 #define TIVX_VPAC_NF_WR_ERR (0x200U)
140 
141 #define TIVX_VPAC_NF_WDTIMER_ERR (0x40000000U)
142 
143 #define TIOVX_VPAC_NF_MAX_COMP (2u)
144 
147 /*********************************
148  * VPAC_NF STRUCTURES
149  *********************************/
150 
157 typedef struct {
158  uint16_t input_interleaved;
160  uint16_t output_offset;
161  uint16_t output_pixel_skip;
163  uint16_t kern_ln_offset;
164  uint16_t kern_sz_height;
165  uint16_t src_ln_inc_2;
191  uint32_t enable_psa;
193 
199 typedef struct {
205  uint16_t adaptive_mode;
206  uint16_t sub_table_select;
208 
214 typedef struct {
229  uint16_t num_sigmas;
230  vx_float64 sigma_space[8];
231  vx_float64 sigma_range[8];
233 
240 typedef struct {
244  uint32_t cycle_cnt;
246  uint32_t token_cnt;
248 
249 typedef struct {
255  uint32_t psa_values[TIOVX_VPAC_NF_MAX_COMP];
256 
262  uint64_t timestamp;
264 
265 
266 /*********************************
267  * Function Prototypes
268  *********************************/
269 
275 
276 
282 
283 
295 VX_API_ENTRY vx_node VX_API_CALL tivxVpacNfGenericNode(vx_graph graph,
296  vx_user_data_object configuration,
297  vx_image input,
298  vx_convolution conv,
299  vx_image output);
300 
312 VX_API_ENTRY vx_node VX_API_CALL tivxVpacNfBilateralNode(vx_graph graph,
313  vx_user_data_object configuration,
314  vx_image input,
315  vx_user_data_object sigmas,
316  vx_image output);
317 
326 
335 
344 
353 
354 
355 #ifdef __cplusplus
356 }
357 #endif
358 
359 #endif /* HWA_VPAC_NF_H_ */
360 
The configuration data structure used by the TIVX_KERNEL_VPAC_NF_BILATERAL kernel.
Definition: hwa_vpac_nf.h:199
VX_API_ENTRY vx_node VX_API_CALL tivxVpacNfGenericNode(vx_graph graph, vx_user_data_object configuration, vx_image input, vx_convolution conv, vx_image output)
[Graph] Creates a VPAC_NF_GENERIC Node.
uint16_t input_interleaved
Definition: hwa_vpac_nf.h:158
void tivx_vpac_nf_common_params_init(tivx_vpac_nf_common_params_t *prms)
Function to initialize NF common Parameters.
uint32_t cycle_cnt
Definition: hwa_vpac_nf.h:244
uint32_t token_cnt
Definition: hwa_vpac_nf.h:246
Definition: hwa_vpac_nf.h:249
uint16_t output_pixel_skip_odd
Definition: hwa_vpac_nf.h:162
void tivx_vpac_nf_hts_bw_limit_params_init(tivx_vpac_nf_hts_bw_limit_params_t *prms)
Function to initialize NF HTS bandwidth limit Parameters.
uint16_t src_ln_inc_2
Definition: hwa_vpac_nf.h:165
void tivx_vpac_nf_bilateral_sigmas_init(tivx_vpac_nf_bilateral_sigmas_t *sigmas)
Function to initialize NF bilateral Sigmas.
uint16_t adaptive_mode
Definition: hwa_vpac_nf.h:205
uint16_t output_offset
Definition: hwa_vpac_nf.h:160
tivx_vpac_nf_common_params_t params
Definition: hwa_vpac_nf.h:200
void tivx_vpac_nf_bilateral_params_init(tivx_vpac_nf_bilateral_params_t *prms)
Function to initialize NF bilateral Parameters.
#define TIOVX_VPAC_NF_MAX_COMP
Maximum possible NF iteration for a simgle request (Luma + Chroma)
Definition: hwa_vpac_nf.h:143
uint16_t kern_ln_offset
Definition: hwa_vpac_nf.h:163
uint64_t timestamp
Timestamp value.
Definition: hwa_vpac_nf.h:262
uint16_t num_sigmas
Definition: hwa_vpac_nf.h:229
void tivxUnRegisterHwaTargetVpacNfKernels(void)
Function to un-register HWA Kernels on the vpac_nf Target.
int16_t output_downshift
Definition: hwa_vpac_nf.h:159
void tivxRegisterHwaTargetVpacNfKernels(void)
Function to register HWA Kernels on the vpac_nf Target.
uint32_t enable_error_events
Definition: hwa_vpac_nf.h:186
The sigmas data structure used by the TIVX_KERNEL_VPAC_NF_BILATERAL kernel.
Definition: hwa_vpac_nf.h:214
uint16_t output_pixel_skip
Definition: hwa_vpac_nf.h:161
uint16_t sub_table_select
Definition: hwa_vpac_nf.h:206
VX_API_ENTRY vx_node VX_API_CALL tivxVpacNfBilateralNode(vx_graph graph, vx_user_data_object configuration, vx_image input, vx_user_data_object sigmas, vx_image output)
[Graph] Creates a VPAC_NF_BILATERAL Node.
uint16_t kern_sz_height
Definition: hwa_vpac_nf.h:164
uint32_t enable_hts_bw_limit
Definition: hwa_vpac_nf.h:242
uint32_t enable_psa
Definition: hwa_vpac_nf.h:191
The configuration data structure used by the TIVX_KERNEL_VPAC_NF_GENERIC and TIVX_KERNEL_VPAC_NF_BILA...
Definition: hwa_vpac_nf.h:157
Configuration parameters used to set HTS BW limit used by TIVX_KERNEL_VPAC_NF kernel.
Definition: hwa_vpac_nf.h:240