xref: /OK3568_Linux_fs/external/rknpu2/examples/3rdparty/rga/RK3588/include/rga.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Copyright (C) 2016 Rockchip Electronics Co., Ltd.
3*4882a593Smuzhiyun  * Authors:
4*4882a593Smuzhiyun  *    Zhiqin Wei <wzq@rock-chips.com>
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * Licensed under the Apache License, Version 2.0 (the "License");
7*4882a593Smuzhiyun  * you may not use this file except in compliance with the License.
8*4882a593Smuzhiyun  * You may obtain a copy of the License at
9*4882a593Smuzhiyun  *
10*4882a593Smuzhiyun  *      http://www.apache.org/licenses/LICENSE-2.0
11*4882a593Smuzhiyun  *
12*4882a593Smuzhiyun  * Unless required by applicable law or agreed to in writing, software
13*4882a593Smuzhiyun  * distributed under the License is distributed on an "AS IS" BASIS,
14*4882a593Smuzhiyun  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15*4882a593Smuzhiyun  * See the License for the specific language governing permissions and
16*4882a593Smuzhiyun  * limitations under the License.
17*4882a593Smuzhiyun  */
18*4882a593Smuzhiyun 
19*4882a593Smuzhiyun #ifndef _RGA_DRIVER_H_
20*4882a593Smuzhiyun #define _RGA_DRIVER_H_
21*4882a593Smuzhiyun 
22*4882a593Smuzhiyun 
23*4882a593Smuzhiyun #ifndef ENABLE
24*4882a593Smuzhiyun #define ENABLE 1
25*4882a593Smuzhiyun #endif
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun #ifndef DISABLE
28*4882a593Smuzhiyun #define DISABLE 0
29*4882a593Smuzhiyun #endif
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun #ifdef __cplusplus
32*4882a593Smuzhiyun extern "C"
33*4882a593Smuzhiyun {
34*4882a593Smuzhiyun #endif
35*4882a593Smuzhiyun 
36*4882a593Smuzhiyun /* In order to be compatible with RK_FORMAT_XX and HAL_PIXEL_FORMAT_XX,
37*4882a593Smuzhiyun  * RK_FORMAT_XX is shifted to the left by 8 bits to distinguish.  */
38*4882a593Smuzhiyun typedef enum _Rga_SURF_FORMAT {
39*4882a593Smuzhiyun     RK_FORMAT_RGBA_8888    = 0x0 << 8,
40*4882a593Smuzhiyun     RK_FORMAT_RGBX_8888    = 0x1 << 8,
41*4882a593Smuzhiyun     RK_FORMAT_RGB_888      = 0x2 << 8,
42*4882a593Smuzhiyun     RK_FORMAT_BGRA_8888    = 0x3 << 8,
43*4882a593Smuzhiyun     RK_FORMAT_RGB_565      = 0x4 << 8,
44*4882a593Smuzhiyun     RK_FORMAT_RGBA_5551    = 0x5 << 8,
45*4882a593Smuzhiyun     RK_FORMAT_RGBA_4444    = 0x6 << 8,
46*4882a593Smuzhiyun     RK_FORMAT_BGR_888      = 0x7 << 8,
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun     RK_FORMAT_YCbCr_422_SP = 0x8 << 8,
49*4882a593Smuzhiyun     RK_FORMAT_YCbCr_422_P  = 0x9 << 8,
50*4882a593Smuzhiyun     RK_FORMAT_YCbCr_420_SP = 0xa << 8,
51*4882a593Smuzhiyun     RK_FORMAT_YCbCr_420_P  = 0xb << 8,
52*4882a593Smuzhiyun 
53*4882a593Smuzhiyun     RK_FORMAT_YCrCb_422_SP = 0xc << 8,
54*4882a593Smuzhiyun     RK_FORMAT_YCrCb_422_P  = 0xd << 8,
55*4882a593Smuzhiyun     RK_FORMAT_YCrCb_420_SP = 0xe << 8,
56*4882a593Smuzhiyun     RK_FORMAT_YCrCb_420_P  = 0xf << 8,
57*4882a593Smuzhiyun 
58*4882a593Smuzhiyun     RK_FORMAT_BPP1         = 0x10 << 8,
59*4882a593Smuzhiyun     RK_FORMAT_BPP2         = 0x11 << 8,
60*4882a593Smuzhiyun     RK_FORMAT_BPP4         = 0x12 << 8,
61*4882a593Smuzhiyun     RK_FORMAT_BPP8         = 0x13 << 8,
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun     RK_FORMAT_Y4           = 0x14 << 8,
64*4882a593Smuzhiyun     RK_FORMAT_YCbCr_400    = 0x15 << 8,
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun     RK_FORMAT_BGRX_8888    = 0x16 << 8,
67*4882a593Smuzhiyun 
68*4882a593Smuzhiyun     RK_FORMAT_YVYU_422     = 0x18 << 8,
69*4882a593Smuzhiyun     RK_FORMAT_YVYU_420     = 0x19 << 8,
70*4882a593Smuzhiyun     RK_FORMAT_VYUY_422     = 0x1a << 8,
71*4882a593Smuzhiyun     RK_FORMAT_VYUY_420     = 0x1b << 8,
72*4882a593Smuzhiyun     RK_FORMAT_YUYV_422     = 0x1c << 8,
73*4882a593Smuzhiyun     RK_FORMAT_YUYV_420     = 0x1d << 8,
74*4882a593Smuzhiyun     RK_FORMAT_UYVY_422     = 0x1e << 8,
75*4882a593Smuzhiyun     RK_FORMAT_UYVY_420     = 0x1f << 8,
76*4882a593Smuzhiyun 
77*4882a593Smuzhiyun     RK_FORMAT_YCbCr_420_SP_10B = 0x20 << 8,
78*4882a593Smuzhiyun     RK_FORMAT_YCrCb_420_SP_10B = 0x21 << 8,
79*4882a593Smuzhiyun     RK_FORMAT_YCbCr_422_SP_10B = 0x22 << 8,
80*4882a593Smuzhiyun     RK_FORMAT_YCrCb_422_SP_10B = 0x23 << 8,
81*4882a593Smuzhiyun     /* For compatibility with misspellings */
82*4882a593Smuzhiyun     RK_FORMAT_YCbCr_422_10b_SP = RK_FORMAT_YCbCr_422_SP_10B,
83*4882a593Smuzhiyun     RK_FORMAT_YCrCb_422_10b_SP = RK_FORMAT_YCrCb_422_SP_10B,
84*4882a593Smuzhiyun 
85*4882a593Smuzhiyun     RK_FORMAT_BGR_565      = 0x24 << 8,
86*4882a593Smuzhiyun     RK_FORMAT_BGRA_5551    = 0x25 << 8,
87*4882a593Smuzhiyun     RK_FORMAT_BGRA_4444    = 0x26 << 8,
88*4882a593Smuzhiyun 
89*4882a593Smuzhiyun     RK_FORMAT_ARGB_8888    = 0x28 << 8,
90*4882a593Smuzhiyun     RK_FORMAT_XRGB_8888    = 0x29 << 8,
91*4882a593Smuzhiyun     RK_FORMAT_ARGB_5551    = 0x2a << 8,
92*4882a593Smuzhiyun     RK_FORMAT_ARGB_4444    = 0x2b << 8,
93*4882a593Smuzhiyun     RK_FORMAT_ABGR_8888    = 0x2c << 8,
94*4882a593Smuzhiyun     RK_FORMAT_XBGR_8888    = 0x2d << 8,
95*4882a593Smuzhiyun     RK_FORMAT_ABGR_5551    = 0x2e << 8,
96*4882a593Smuzhiyun     RK_FORMAT_ABGR_4444    = 0x2f << 8,
97*4882a593Smuzhiyun 
98*4882a593Smuzhiyun     RK_FORMAT_RGBA2BPP     = 0x30 << 8,
99*4882a593Smuzhiyun 
100*4882a593Smuzhiyun     RK_FORMAT_UNKNOWN      = 0x100 << 8,
101*4882a593Smuzhiyun } RgaSURF_FORMAT;
102*4882a593Smuzhiyun 
103*4882a593Smuzhiyun enum {
104*4882a593Smuzhiyun     yuv2rgb_mode0            = 0x0,     /* BT.601 MPEG */
105*4882a593Smuzhiyun     yuv2rgb_mode1            = 0x1,     /* BT.601 JPEG */
106*4882a593Smuzhiyun     yuv2rgb_mode2            = 0x2,     /* BT.709      */
107*4882a593Smuzhiyun 
108*4882a593Smuzhiyun     rgb2yuv_601_full                = 0x1 << 8,
109*4882a593Smuzhiyun     rgb2yuv_709_full                = 0x2 << 8,
110*4882a593Smuzhiyun     yuv2yuv_601_limit_2_709_limit   = 0x3 << 8,
111*4882a593Smuzhiyun     yuv2yuv_601_limit_2_709_full    = 0x4 << 8,
112*4882a593Smuzhiyun     yuv2yuv_709_limit_2_601_limit   = 0x5 << 8,
113*4882a593Smuzhiyun     yuv2yuv_709_limit_2_601_full    = 0x6 << 8,     //not support
114*4882a593Smuzhiyun     yuv2yuv_601_full_2_709_limit    = 0x7 << 8,
115*4882a593Smuzhiyun     yuv2yuv_601_full_2_709_full     = 0x8 << 8,     //not support
116*4882a593Smuzhiyun     yuv2yuv_709_full_2_601_limit    = 0x9 << 8,     //not support
117*4882a593Smuzhiyun     yuv2yuv_709_full_2_601_full     = 0xa << 8,     //not support
118*4882a593Smuzhiyun     full_csc_mask = 0xf00,
119*4882a593Smuzhiyun };
120*4882a593Smuzhiyun 
121*4882a593Smuzhiyun enum {
122*4882a593Smuzhiyun     RGA3_SCHEDULER_CORE0    = 1 << 0,
123*4882a593Smuzhiyun     RGA3_SCHEDULER_CORE1    = 1 << 1,
124*4882a593Smuzhiyun     RGA2_SCHEDULER_CORE0    = 1 << 2,
125*4882a593Smuzhiyun };
126*4882a593Smuzhiyun 
127*4882a593Smuzhiyun /* RGA3 rd_mode */
128*4882a593Smuzhiyun enum
129*4882a593Smuzhiyun {
130*4882a593Smuzhiyun     raster_mode             = 0x1 << 0,
131*4882a593Smuzhiyun     fbc_mode                = 0x1 << 1,
132*4882a593Smuzhiyun     tile_mode               = 0x1 << 2,
133*4882a593Smuzhiyun };
134*4882a593Smuzhiyun 
135*4882a593Smuzhiyun #ifdef __cplusplus
136*4882a593Smuzhiyun }
137*4882a593Smuzhiyun #endif
138*4882a593Smuzhiyun 
139*4882a593Smuzhiyun #endif /*_RK29_IPP_DRIVER_H_*/
140