xref: /rockchip-linux_mpp/mpp/vproc/inc/rga_api.h (revision 437bfbeb9567cca9cd9080e3f6954aa9d6a94f18)
1*437bfbebSnyanmisaka /*
2*437bfbebSnyanmisaka  * Copyright 2015 Rockchip Electronics Co. LTD
3*437bfbebSnyanmisaka  *
4*437bfbebSnyanmisaka  * Licensed under the Apache License, Version 2.0 (the "License");
5*437bfbebSnyanmisaka  * you may not use this file except in compliance with the License.
6*437bfbebSnyanmisaka  * You may obtain a copy of the License at
7*437bfbebSnyanmisaka  *
8*437bfbebSnyanmisaka  *      http://www.apache.org/licenses/LICENSE-2.0
9*437bfbebSnyanmisaka  *
10*437bfbebSnyanmisaka  * Unless required by applicable law or agreed to in writing, software
11*437bfbebSnyanmisaka  * distributed under the License is distributed on an "AS IS" BASIS,
12*437bfbebSnyanmisaka  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*437bfbebSnyanmisaka  * See the License for the specific language governing permissions and
14*437bfbebSnyanmisaka  * limitations under the License.
15*437bfbebSnyanmisaka  */
16*437bfbebSnyanmisaka 
17*437bfbebSnyanmisaka #ifndef __RGA_API_H__
18*437bfbebSnyanmisaka #define __RGA_API_H__
19*437bfbebSnyanmisaka 
20*437bfbebSnyanmisaka #include "rk_type.h"
21*437bfbebSnyanmisaka #include "mpp_err.h"
22*437bfbebSnyanmisaka #include "mpp_frame.h"
23*437bfbebSnyanmisaka 
24*437bfbebSnyanmisaka /*
25*437bfbebSnyanmisaka  * NOTE: Normal rga usage should consider address align issue.
26*437bfbebSnyanmisaka  * But memory in mpp is always aligned. So we do not tak align issue into
27*437bfbebSnyanmisaka  * consideration.
28*437bfbebSnyanmisaka  */
29*437bfbebSnyanmisaka typedef enum RgaCmd_e {
30*437bfbebSnyanmisaka     RGA_CMD_INIT,                           // reset msg to all zero
31*437bfbebSnyanmisaka     RGA_CMD_SET_SRC,                        // config source image info
32*437bfbebSnyanmisaka     RGA_CMD_SET_DST,                        // config destination image info
33*437bfbebSnyanmisaka 
34*437bfbebSnyanmisaka     RGA_CMD_SET_SCALE_CFG       = 0x0100,   // config copy parameter
35*437bfbebSnyanmisaka 
36*437bfbebSnyanmisaka     RGA_CMD_SET_COLOR_CONVERT   = 0x0200,   // config color convert parameter
37*437bfbebSnyanmisaka 
38*437bfbebSnyanmisaka     RGA_CMD_SET_ROTATION        = 0x0300,   // config rotation parameter
39*437bfbebSnyanmisaka 
40*437bfbebSnyanmisaka     // hardware trigger command
41*437bfbebSnyanmisaka     RGA_CMD_RUN_SYNC            = 0x1000,   // start sync mode process
42*437bfbebSnyanmisaka     RGA_CMD_RUN_ASYNC,                      // start async mode process
43*437bfbebSnyanmisaka } RgaCmd;
44*437bfbebSnyanmisaka 
45*437bfbebSnyanmisaka typedef void* RgaCtx;
46*437bfbebSnyanmisaka 
47*437bfbebSnyanmisaka #ifdef __cplusplus
48*437bfbebSnyanmisaka extern "C" {
49*437bfbebSnyanmisaka #endif
50*437bfbebSnyanmisaka 
51*437bfbebSnyanmisaka MPP_RET rga_init(RgaCtx *ctx);
52*437bfbebSnyanmisaka MPP_RET rga_deinit(RgaCtx ctx);
53*437bfbebSnyanmisaka 
54*437bfbebSnyanmisaka MPP_RET rga_control(RgaCtx ctx, RgaCmd cmd, void *param);
55*437bfbebSnyanmisaka 
56*437bfbebSnyanmisaka #ifdef __cplusplus
57*437bfbebSnyanmisaka }
58*437bfbebSnyanmisaka #endif
59*437bfbebSnyanmisaka 
60*437bfbebSnyanmisaka #endif /* __RGA_API_H__ */
61