1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun #ifndef __RGA_API_H__ 3*4882a593Smuzhiyun #define __RGA_API_H__ 4*4882a593Smuzhiyun 5*4882a593Smuzhiyun #include <linux/miscdevice.h> 6*4882a593Smuzhiyun #include <linux/wakelock.h> 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #include "rga_reg_info.h" 9*4882a593Smuzhiyun #include "rga.h" 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #define ENABLE 1 12*4882a593Smuzhiyun #define DISABLE 0 13*4882a593Smuzhiyun 14*4882a593Smuzhiyun struct rga_drvdata { 15*4882a593Smuzhiyun struct miscdevice miscdev; 16*4882a593Smuzhiyun struct device *dev; 17*4882a593Smuzhiyun void *rga_base; 18*4882a593Smuzhiyun int irq; 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun struct delayed_work power_off_work; 21*4882a593Smuzhiyun void (*rga_irq_callback)(int rga_retval); //callback function used by aync call 22*4882a593Smuzhiyun struct wake_lock wake_lock; 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun struct clk *pd_rga; 25*4882a593Smuzhiyun struct clk *aclk_rga; 26*4882a593Smuzhiyun struct clk *hclk_rga; 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun //#if defined(CONFIG_ION_ROCKCHIP) 29*4882a593Smuzhiyun struct ion_client *ion_client; 30*4882a593Smuzhiyun //#endif 31*4882a593Smuzhiyun char *version; 32*4882a593Smuzhiyun }; 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun int32_t RGA_gen_two_pro(struct rga_req *msg, struct rga_req *msg1); 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun 40*4882a593Smuzhiyun #endif 41