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