13d0407baSopenharmony_ci/*
23d0407baSopenharmony_ci * Copyright (c) 2021 Rockchip Electronics Co., Ltd.
33d0407baSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
43d0407baSopenharmony_ci * you may not use this file except in compliance with the License.
53d0407baSopenharmony_ci * You may obtain a copy of the License at
63d0407baSopenharmony_ci *
73d0407baSopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
83d0407baSopenharmony_ci *
93d0407baSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
103d0407baSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
113d0407baSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
123d0407baSopenharmony_ci * See the License for the specific language governing permissions and
133d0407baSopenharmony_ci * limitations under the License.
143d0407baSopenharmony_ci */
153d0407baSopenharmony_ci
163d0407baSopenharmony_ci#ifndef __VCODEC_SERVICE_H__
173d0407baSopenharmony_ci#define __VCODEC_SERVICE_H__
183d0407baSopenharmony_ci
193d0407baSopenharmony_ci#include "rk_type.h"
203d0407baSopenharmony_ci
213d0407baSopenharmony_ci#define EXTRA_INFO_MAGIC (0x4C4A46)
223d0407baSopenharmony_ci
233d0407baSopenharmony_ci#define VPU_IOC_MAGIC 'l'
243d0407baSopenharmony_ci
253d0407baSopenharmony_ci#define VPU_IOC_SET_CLIENT_TYPE _IOW(VPU_IOC_MAGIC, 1, unsigned long)
263d0407baSopenharmony_ci#define VPU_IOC_GET_HW_FUSE_STATUS _IOW(VPU_IOC_MAGIC, 2, unsigned long)
273d0407baSopenharmony_ci#define VPU_IOC_SET_REG _IOW(VPU_IOC_MAGIC, 3, unsigned long)
283d0407baSopenharmony_ci#define VPU_IOC_GET_REG _IOW(VPU_IOC_MAGIC, 4, unsigned long)
293d0407baSopenharmony_ci
303d0407baSopenharmony_ci#define VPU_IOC_SET_CLIENT_TYPE_U32 _IOW(VPU_IOC_MAGIC, 1, unsigned int)
313d0407baSopenharmony_ci
323d0407baSopenharmony_ci#define VPU_IOC_WRITE(nr, size) _IOC(_IOC_WRITE, VPU_IOC_MAGIC, (nr), (size))
333d0407baSopenharmony_ci
343d0407baSopenharmony_ci#define VDPU1_REGISTERS (101)
353d0407baSopenharmony_ci#define VDPU2_REGISTERS (159)
363d0407baSopenharmony_ci#define VDPU1_PP_REGISTERS (164)
373d0407baSopenharmony_ci#define VDPU2_PP_REGISTERS (184)
383d0407baSopenharmony_ci#define RKHEVC_REGISTERS (68)
393d0407baSopenharmony_ci#define RKVDEC_REGISTERS (78)
403d0407baSopenharmony_ci#define AVSD_REGISTERS (60)
413d0407baSopenharmony_ci
423d0407baSopenharmony_ci#define VEPU1_REGISTERS (164)
433d0407baSopenharmony_ci#define VEPU2_REGISTERS (184)
443d0407baSopenharmony_ci#define RKVENC_REGISTERS (140)
453d0407baSopenharmony_ci
463d0407baSopenharmony_ci#define EXTRA_INFO_SIZE (sizeof(unsigned int) * 34)
473d0407baSopenharmony_ci
483d0407baSopenharmony_ci#ifdef __cplusplus
493d0407baSopenharmony_ciextern "C" {
503d0407baSopenharmony_ci#endif
513d0407baSopenharmony_ci
523d0407baSopenharmony_ciconst char *mpp_get_vcodec_dev_name(MppCtxType type, MppCodingType coding);
533d0407baSopenharmony_ci
543d0407baSopenharmony_ci#ifdef __cplusplus
553d0407baSopenharmony_ci}
563d0407baSopenharmony_ci#endif
573d0407baSopenharmony_ci
583d0407baSopenharmony_ci#endif /* __VCODEC_SERVICE_H__ */