1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun * Copyright 2015 Rockchip Electronics Co. LTD
3*4882a593Smuzhiyun *
4*4882a593Smuzhiyun * Licensed under the Apache License, Version 2.0 (the "License");
5*4882a593Smuzhiyun * you may not use this file except in compliance with the License.
6*4882a593Smuzhiyun * You may obtain a copy of the License at
7*4882a593Smuzhiyun *
8*4882a593Smuzhiyun * http://www.apache.org/licenses/LICENSE-2.0
9*4882a593Smuzhiyun *
10*4882a593Smuzhiyun * Unless required by applicable law or agreed to in writing, software
11*4882a593Smuzhiyun * distributed under the License is distributed on an "AS IS" BASIS,
12*4882a593Smuzhiyun * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4882a593Smuzhiyun * See the License for the specific language governing permissions and
14*4882a593Smuzhiyun * limitations under the License.
15*4882a593Smuzhiyun */
16*4882a593Smuzhiyun
17*4882a593Smuzhiyun #define MODULE_TAG "mpp_platform"
18*4882a593Smuzhiyun
19*4882a593Smuzhiyun #include <string.h>
20*4882a593Smuzhiyun
21*4882a593Smuzhiyun #include "mpp_env.h"
22*4882a593Smuzhiyun #include "mpp_debug.h"
23*4882a593Smuzhiyun #include "mpp_common.h"
24*4882a593Smuzhiyun #include "mpp_platform.h"
25*4882a593Smuzhiyun #include "mpp_service.h"
26*4882a593Smuzhiyun
check_kernel_version(void)27*4882a593Smuzhiyun static MppKernelVersion check_kernel_version(void)
28*4882a593Smuzhiyun {
29*4882a593Smuzhiyun static const char *kernel_version_path = "/proc/version";
30*4882a593Smuzhiyun MppKernelVersion version = KERNEL_UNKNOWN;
31*4882a593Smuzhiyun FILE *fp = NULL;
32*4882a593Smuzhiyun char buf[32];
33*4882a593Smuzhiyun
34*4882a593Smuzhiyun if (access(kernel_version_path, F_OK | R_OK))
35*4882a593Smuzhiyun return version;
36*4882a593Smuzhiyun
37*4882a593Smuzhiyun fp = fopen(kernel_version_path, "rb");
38*4882a593Smuzhiyun if (fp) {
39*4882a593Smuzhiyun size_t len = fread(buf, 1, sizeof(buf) - 1, fp);
40*4882a593Smuzhiyun char *pos = NULL;
41*4882a593Smuzhiyun
42*4882a593Smuzhiyun buf[len] = '\0';
43*4882a593Smuzhiyun pos = strstr(buf, "Linux version ");
44*4882a593Smuzhiyun if (pos) {
45*4882a593Smuzhiyun RK_S32 major = 0;
46*4882a593Smuzhiyun RK_S32 minor = 0;
47*4882a593Smuzhiyun RK_S32 last = 0;
48*4882a593Smuzhiyun RK_S32 count = 0;
49*4882a593Smuzhiyun
50*4882a593Smuzhiyun pos += 14;
51*4882a593Smuzhiyun count = sscanf(pos, "%d.%d.%d ", &major, &minor, &last);
52*4882a593Smuzhiyun if (count >= 2 && major > 0 && minor > 0) {
53*4882a593Smuzhiyun switch (major) {
54*4882a593Smuzhiyun case 3: {
55*4882a593Smuzhiyun version = KERNEL_3_10;
56*4882a593Smuzhiyun } break;
57*4882a593Smuzhiyun case 4: {
58*4882a593Smuzhiyun version = KERNEL_4_4;
59*4882a593Smuzhiyun if (minor >= 19)
60*4882a593Smuzhiyun version = KERNEL_4_19;
61*4882a593Smuzhiyun } break;
62*4882a593Smuzhiyun case 5: {
63*4882a593Smuzhiyun version = KERNEL_5_10;
64*4882a593Smuzhiyun } break;
65*4882a593Smuzhiyun default: break;
66*4882a593Smuzhiyun }
67*4882a593Smuzhiyun }
68*4882a593Smuzhiyun }
69*4882a593Smuzhiyun fclose(fp);
70*4882a593Smuzhiyun }
71*4882a593Smuzhiyun return version;
72*4882a593Smuzhiyun }
73*4882a593Smuzhiyun
74*4882a593Smuzhiyun class MppPlatformService
75*4882a593Smuzhiyun {
76*4882a593Smuzhiyun private:
77*4882a593Smuzhiyun // avoid any unwanted function
78*4882a593Smuzhiyun MppPlatformService();
~MppPlatformService()79*4882a593Smuzhiyun ~MppPlatformService() {};
80*4882a593Smuzhiyun MppPlatformService(const MppPlatformService &);
81*4882a593Smuzhiyun MppPlatformService &operator=(const MppPlatformService &);
82*4882a593Smuzhiyun
83*4882a593Smuzhiyun MppIoctlVersion ioctl_version;
84*4882a593Smuzhiyun MppKernelVersion kernel_version;
85*4882a593Smuzhiyun RK_U32 vcodec_type;
86*4882a593Smuzhiyun RK_U32 hw_ids[32];
87*4882a593Smuzhiyun MppServiceCmdCap mpp_service_cmd_cap;
88*4882a593Smuzhiyun const MppSocInfo *soc_info;
89*4882a593Smuzhiyun const char *soc_name;
90*4882a593Smuzhiyun
91*4882a593Smuzhiyun public:
get_instance()92*4882a593Smuzhiyun static MppPlatformService *get_instance() {
93*4882a593Smuzhiyun static MppPlatformService instance;
94*4882a593Smuzhiyun return &instance;
95*4882a593Smuzhiyun }
96*4882a593Smuzhiyun
get_ioctl_version(void)97*4882a593Smuzhiyun MppIoctlVersion get_ioctl_version(void) { return ioctl_version; };
get_kernel_version(void)98*4882a593Smuzhiyun MppKernelVersion get_kernel_version(void) { return kernel_version; };
get_soc_name()99*4882a593Smuzhiyun const char *get_soc_name() { return soc_name; };
get_mpp_service_cmd_cap()100*4882a593Smuzhiyun MppServiceCmdCap *get_mpp_service_cmd_cap() { return &mpp_service_cmd_cap; };
101*4882a593Smuzhiyun RK_U32 get_hw_id(RK_S32 client_type);
get_vcodec_type(void)102*4882a593Smuzhiyun RK_U32 get_vcodec_type(void) { return vcodec_type; };
103*4882a593Smuzhiyun };
104*4882a593Smuzhiyun
MppPlatformService()105*4882a593Smuzhiyun MppPlatformService::MppPlatformService()
106*4882a593Smuzhiyun : ioctl_version(IOCTL_MPP_SERVICE_V1),
107*4882a593Smuzhiyun kernel_version(KERNEL_UNKNOWN),
108*4882a593Smuzhiyun vcodec_type(0),
109*4882a593Smuzhiyun soc_info(NULL),
110*4882a593Smuzhiyun soc_name(NULL)
111*4882a593Smuzhiyun {
112*4882a593Smuzhiyun /* judge vdpu support version */
113*4882a593Smuzhiyun MppServiceCmdCap *cap = &mpp_service_cmd_cap;
114*4882a593Smuzhiyun
115*4882a593Smuzhiyun /* default value */
116*4882a593Smuzhiyun cap->support_cmd = 0;
117*4882a593Smuzhiyun cap->query_cmd = MPP_CMD_QUERY_BASE + 1;
118*4882a593Smuzhiyun cap->init_cmd = MPP_CMD_INIT_BASE + 1;
119*4882a593Smuzhiyun cap->send_cmd = MPP_CMD_SEND_BASE + 1;
120*4882a593Smuzhiyun cap->poll_cmd = MPP_CMD_POLL_BASE + 1;
121*4882a593Smuzhiyun cap->ctrl_cmd = MPP_CMD_CONTROL_BASE + 0;
122*4882a593Smuzhiyun
123*4882a593Smuzhiyun mpp_env_get_u32("mpp_debug", &mpp_debug, 0);
124*4882a593Smuzhiyun
125*4882a593Smuzhiyun /* read soc name */
126*4882a593Smuzhiyun soc_name = mpp_get_soc_name();
127*4882a593Smuzhiyun soc_info = mpp_get_soc_info();
128*4882a593Smuzhiyun
129*4882a593Smuzhiyun if (soc_info->soc_type == ROCKCHIP_SOC_AUTO)
130*4882a593Smuzhiyun mpp_log("can not found match soc name: %s\n", soc_name);
131*4882a593Smuzhiyun
132*4882a593Smuzhiyun ioctl_version = IOCTL_VCODEC_SERVICE;
133*4882a593Smuzhiyun if (mpp_get_mpp_service_name()) {
134*4882a593Smuzhiyun ioctl_version = IOCTL_MPP_SERVICE_V1;
135*4882a593Smuzhiyun check_mpp_service_cap(&vcodec_type, hw_ids, cap);
136*4882a593Smuzhiyun }
137*4882a593Smuzhiyun kernel_version = check_kernel_version();
138*4882a593Smuzhiyun if (!vcodec_type)
139*4882a593Smuzhiyun vcodec_type = soc_info->vcodec_type;
140*4882a593Smuzhiyun }
141*4882a593Smuzhiyun
get_hw_id(RK_S32 client_type)142*4882a593Smuzhiyun RK_U32 MppPlatformService::get_hw_id(RK_S32 client_type)
143*4882a593Smuzhiyun {
144*4882a593Smuzhiyun RK_U32 hw_id = 0;
145*4882a593Smuzhiyun
146*4882a593Smuzhiyun if (vcodec_type & (1 << client_type))
147*4882a593Smuzhiyun hw_id = hw_ids[client_type];
148*4882a593Smuzhiyun
149*4882a593Smuzhiyun return hw_id;
150*4882a593Smuzhiyun }
151*4882a593Smuzhiyun
mpp_get_ioctl_version(void)152*4882a593Smuzhiyun MppIoctlVersion mpp_get_ioctl_version(void)
153*4882a593Smuzhiyun {
154*4882a593Smuzhiyun return MppPlatformService::get_instance()->get_ioctl_version();
155*4882a593Smuzhiyun }
156*4882a593Smuzhiyun
mpp_get_kernel_version(void)157*4882a593Smuzhiyun MppKernelVersion mpp_get_kernel_version(void)
158*4882a593Smuzhiyun {
159*4882a593Smuzhiyun return MppPlatformService::get_instance()->get_kernel_version();
160*4882a593Smuzhiyun }
161*4882a593Smuzhiyun
mpp_get_2d_hw_flag(void)162*4882a593Smuzhiyun RK_U32 mpp_get_2d_hw_flag(void)
163*4882a593Smuzhiyun {
164*4882a593Smuzhiyun RK_U32 flag = 0;
165*4882a593Smuzhiyun
166*4882a593Smuzhiyun if (!access("/dev/rga", F_OK))
167*4882a593Smuzhiyun flag |= HAVE_RGA;
168*4882a593Smuzhiyun
169*4882a593Smuzhiyun if (!access("/dev/iep", F_OK))
170*4882a593Smuzhiyun flag |= HAVE_IEP;
171*4882a593Smuzhiyun
172*4882a593Smuzhiyun return flag;
173*4882a593Smuzhiyun }
174*4882a593Smuzhiyun
mpp_get_mpp_service_cmd_cap(void)175*4882a593Smuzhiyun const MppServiceCmdCap *mpp_get_mpp_service_cmd_cap(void)
176*4882a593Smuzhiyun {
177*4882a593Smuzhiyun return MppPlatformService::get_instance()->get_mpp_service_cmd_cap();
178*4882a593Smuzhiyun }
179*4882a593Smuzhiyun
mpp_get_client_hw_id(RK_S32 client_type)180*4882a593Smuzhiyun RK_U32 mpp_get_client_hw_id(RK_S32 client_type)
181*4882a593Smuzhiyun {
182*4882a593Smuzhiyun return MppPlatformService::get_instance()->get_hw_id(client_type);
183*4882a593Smuzhiyun }
184*4882a593Smuzhiyun
mpp_get_vcodec_type(void)185*4882a593Smuzhiyun RK_U32 mpp_get_vcodec_type(void)
186*4882a593Smuzhiyun {
187*4882a593Smuzhiyun static RK_U32 vcodec_type = 0;
188*4882a593Smuzhiyun
189*4882a593Smuzhiyun if (!vcodec_type)
190*4882a593Smuzhiyun vcodec_type = MppPlatformService::get_instance()->get_vcodec_type();
191*4882a593Smuzhiyun
192*4882a593Smuzhiyun return vcodec_type;
193*4882a593Smuzhiyun }
194