arm64: vpu: m850d: hantro
Add hantro decoder driver: drivers/mxc/hantro include/linux/hantrodec.h include/uapi/linux/hantrodec.h Signed-off-by: Zhou Peng <eagle.zhou@nxp.com>
This commit is contained in:
parent
7339b6c620
commit
83ac8664e5
|
@ -0,0 +1,14 @@
|
|||
#
|
||||
# Codec configuration
|
||||
#
|
||||
|
||||
menu "MXC HANTRO(Video Processing Unit) support"
|
||||
depends on ARCH_FSL_IMX8MQ
|
||||
|
||||
config MXC_HANTRO
|
||||
tristate "Support for MXC HANTRO(Video Processing Unit)"
|
||||
default y
|
||||
---help---
|
||||
VPU codec device.
|
||||
|
||||
endmenu
|
|
@ -0,0 +1,8 @@
|
|||
#
|
||||
# Makefile for the VPU drivers.
|
||||
#
|
||||
|
||||
ccflags-y += -I$(PWD)/./dwl
|
||||
|
||||
obj-$(CONFIG_MXC_HANTRO) += hantrodec.o
|
||||
|
|
@ -0,0 +1,94 @@
|
|||
/*****************************************************************************
|
||||
* The GPL License (GPL)
|
||||
*
|
||||
* Copyright (c) 2015-2017, VeriSilicon Inc.
|
||||
* Copyright (c) 2011-2014, Google Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You may obtain a copy of the GNU General Public License
|
||||
* Version 2 or later at the following locations:
|
||||
* http://www.opensource.org/licenses/gpl-license.html
|
||||
* http://www.gnu.org/copyleft/gpl.html
|
||||
*****************************************************************************/
|
||||
|
||||
#ifndef SOFTWARE_LINUX_DWL_DWL_DEFS_H_
|
||||
#define SOFTWARE_LINUX_DWL_DWL_DEFS_H_
|
||||
|
||||
#define DWL_MPEG2_E 31 /* 1 bit */
|
||||
#define DWL_VC1_E 29 /* 2 bits */
|
||||
#define DWL_JPEG_E 28 /* 1 bit */
|
||||
#define DWL_MPEG4_E 26 /* 2 bits */
|
||||
#define DWL_H264_E 24 /* 2 bits */
|
||||
#define DWL_VP6_E 23 /* 1 bit */
|
||||
#define DWL_RV_E 26 /* 2 bits */
|
||||
#define DWL_VP8_E 23 /* 1 bit */
|
||||
#define DWL_VP7_E 24 /* 1 bit */
|
||||
#define DWL_WEBP_E 19 /* 1 bit */
|
||||
#define DWL_AVS_E 22 /* 1 bit */
|
||||
#if 0
|
||||
#define DWL_PP_E 16 /* 1 bit */
|
||||
#endif
|
||||
#define DWL_PP_E 31 /* 1 bit */
|
||||
#define DWL_HEVC_E 5 /* 2 bits */
|
||||
#define DWL_VP9_E 3 /* 2 bits */
|
||||
|
||||
#define DWL_HEVC_ENA 0 /* 1 bits */
|
||||
#define DWL_VP9_ENA 1 /* 1 bits */
|
||||
#define DWL_RFC_E 2 /* 1 bits */
|
||||
#define DWL_DS_E 3 /* 1 bits */
|
||||
#define DWL_HEVC_VER 8 /* 4 bits */
|
||||
#define DWL_VP9_PROFILE 12 /* 3 bits */
|
||||
#define DWL_RING_E 16 /* 1 bits */
|
||||
|
||||
#define HANTRODEC_IRQ_STAT_DEC 1
|
||||
#define HANTRODEC_IRQ_STAT_DEC_OFF (HANTRODEC_IRQ_STAT_DEC * 4)
|
||||
|
||||
#define HANTRODECPP_SYNTH_CFG 60
|
||||
#define HANTRODECPP_SYNTH_CFG_OFF (HANTRODECPP_SYNTH_CFG * 4)
|
||||
#define HANTRODEC_SYNTH_CFG 50
|
||||
#define HANTRODEC_SYNTH_CFG_OFF (HANTRODEC_SYNTH_CFG * 4)
|
||||
#define HANTRODEC_SYNTH_CFG_2 54
|
||||
#define HANTRODEC_SYNTH_CFG_2_OFF (HANTRODEC_SYNTH_CFG_2 * 4)
|
||||
#define HANTRODEC_SYNTH_CFG_3 56
|
||||
#define HANTRODEC_SYNTH_CFG_3_OFF (HANTRODEC_SYNTH_CFG_3 * 4)
|
||||
#define HANTRODEC_CFG_STAT 23
|
||||
#define HANTRODEC_CFG_STAT_OFF (HANTRODEC_CFG_STAT * 4)
|
||||
|
||||
|
||||
#define HANTRODEC_DEC_E 0x01
|
||||
#define HANTRODEC_PP_E 0x01
|
||||
#define HANTRODEC_DEC_ABORT 0x20
|
||||
#define HANTRODEC_DEC_IRQ_DISABLE 0x10
|
||||
#define HANTRODEC_DEC_IRQ 0x100
|
||||
|
||||
/* Legacy from G1 */
|
||||
#define HANTRO_IRQ_STAT_DEC 1
|
||||
#define HANTRO_IRQ_STAT_DEC_OFF (HANTRO_IRQ_STAT_DEC * 4)
|
||||
#define HANTRO_IRQ_STAT_PP 60
|
||||
#define HANTRO_IRQ_STAT_PP_OFF (HANTRO_IRQ_STAT_PP * 4)
|
||||
|
||||
#define HANTROPP_SYNTH_CFG 100
|
||||
#define HANTROPP_SYNTH_CFG_OFF (HANTROPP_SYNTH_CFG * 4)
|
||||
#define HANTRODEC_SYNTH_CFG 50
|
||||
#define HANTRODEC_SYNTH_CFG_OFF (HANTRODEC_SYNTH_CFG * 4)
|
||||
#define HANTRODEC_SYNTH_CFG_2 54
|
||||
#define HANTRODEC_SYNTH_CFG_2_OFF (HANTRODEC_SYNTH_CFG_2 * 4)
|
||||
|
||||
#define HANTRO_DEC_E 0x01
|
||||
#define HANTRO_PP_E 0x01
|
||||
#define HANTRO_DEC_ABORT 0x20
|
||||
#define HANTRO_DEC_IRQ_DISABLE 0x10
|
||||
#define HANTRO_PP_IRQ_DISABLE 0x10
|
||||
#define HANTRO_DEC_IRQ 0x100
|
||||
#define HANTRO_PP_IRQ 0x100
|
||||
|
||||
#endif /* SOFTWARE_LINUX_DWL_DWL_DEFS_H_ */
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,29 @@
|
|||
/*****************************************************************************
|
||||
*
|
||||
* The GPL License (GPL)
|
||||
*
|
||||
* Copyright (c) 2015-2017, VeriSilicon Inc.
|
||||
* Copyright (c) 2011-2014, Google Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#ifndef _HANTRODEC_H_
|
||||
#define _HANTRODEC_H_
|
||||
|
||||
#include <uapi/linux/hantrodec.h>
|
||||
|
||||
#endif /* !_HANTRODEC_H_ */
|
|
@ -0,0 +1,93 @@
|
|||
/*****************************************************************************
|
||||
*
|
||||
* The GPL License (GPL)
|
||||
*
|
||||
* Copyright (c) 2015-2017, VeriSilicon Inc.
|
||||
* Copyright (c) 2011-2014, Google Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#ifndef _UAPI_HANTRODEC_H_
|
||||
#define _UAPI_HANTRODEC_H_
|
||||
#include <linux/ioctl.h>
|
||||
#include <linux/types.h>
|
||||
|
||||
#undef PDEBUG
|
||||
#ifdef HANTRODEC_DEBUG
|
||||
# ifdef __KERNEL__
|
||||
# define PDEBUG(fmt, args...) pr_info("hantrodec: " fmt, ## args)
|
||||
# else
|
||||
# define PDEBUG(fmt, args...) fprintf(stderr, fmt, ## args)
|
||||
# endif
|
||||
#else
|
||||
# define PDEBUG(fmt, args...)
|
||||
#endif
|
||||
|
||||
struct core_desc {
|
||||
__u32 id; /* id of the Core */
|
||||
__u32 *regs; /* pointer to user registers */
|
||||
__u32 size; /* size of register space */
|
||||
};
|
||||
|
||||
/* Use 'k' as magic number */
|
||||
#define HANTRODEC_IOC_MAGIC 'k'
|
||||
|
||||
/*
|
||||
* S means "Set" through a ptr,
|
||||
* T means "Tell" directly with the argument value
|
||||
* G means "Get": reply by setting through a pointer
|
||||
* Q means "Query": response is on the return value
|
||||
* X means "eXchange": G and S atomically
|
||||
* H means "sHift": T and Q atomically
|
||||
*/
|
||||
|
||||
#define HANTRODEC_PP_INSTANCE _IO(HANTRODEC_IOC_MAGIC, 1)
|
||||
#define HANTRODEC_HW_PERFORMANCE _IO(HANTRODEC_IOC_MAGIC, 2)
|
||||
#define HANTRODEC_IOCGHWOFFSET _IOR(HANTRODEC_IOC_MAGIC, 3, unsigned long *)
|
||||
#define HANTRODEC_IOCGHWIOSIZE _IOR(HANTRODEC_IOC_MAGIC, 4, unsigned int *)
|
||||
|
||||
#define HANTRODEC_IOC_CLI _IO(HANTRODEC_IOC_MAGIC, 5)
|
||||
#define HANTRODEC_IOC_STI _IO(HANTRODEC_IOC_MAGIC, 6)
|
||||
#define HANTRODEC_IOC_MC_OFFSETS _IOR(HANTRODEC_IOC_MAGIC, 7, unsigned long *)
|
||||
#define HANTRODEC_IOC_MC_CORES _IOR(HANTRODEC_IOC_MAGIC, 8, unsigned int *)
|
||||
|
||||
|
||||
#define HANTRODEC_IOCS_DEC_PUSH_REG _IOW(HANTRODEC_IOC_MAGIC, 9, struct core_desc *)
|
||||
#define HANTRODEC_IOCS_PP_PUSH_REG _IOW(HANTRODEC_IOC_MAGIC, 10, struct core_desc *)
|
||||
|
||||
#define HANTRODEC_IOCH_DEC_RESERVE _IO(HANTRODEC_IOC_MAGIC, 11)
|
||||
#define HANTRODEC_IOCT_DEC_RELEASE _IO(HANTRODEC_IOC_MAGIC, 12)
|
||||
#define HANTRODEC_IOCQ_PP_RESERVE _IO(HANTRODEC_IOC_MAGIC, 13)
|
||||
#define HANTRODEC_IOCT_PP_RELEASE _IO(HANTRODEC_IOC_MAGIC, 14)
|
||||
|
||||
#define HANTRODEC_IOCX_DEC_WAIT _IOWR(HANTRODEC_IOC_MAGIC, 15, struct core_desc *)
|
||||
#define HANTRODEC_IOCX_PP_WAIT _IOWR(HANTRODEC_IOC_MAGIC, 16, struct core_desc *)
|
||||
|
||||
#define HANTRODEC_IOCS_DEC_PULL_REG _IOWR(HANTRODEC_IOC_MAGIC, 17, struct core_desc *)
|
||||
#define HANTRODEC_IOCS_PP_PULL_REG _IOWR(HANTRODEC_IOC_MAGIC, 18, struct core_desc *)
|
||||
|
||||
#define HANTRODEC_IOCG_CORE_WAIT _IOR(HANTRODEC_IOC_MAGIC, 19, int *)
|
||||
|
||||
#define HANTRODEC_IOX_ASIC_ID _IOWR(HANTRODEC_IOC_MAGIC, 20, __u32 *)
|
||||
|
||||
#define HANTRODEC_IOCG_CORE_ID _IO(HANTRODEC_IOC_MAGIC, 21)
|
||||
|
||||
#define HANTRODEC_DEBUG_STATUS _IO(HANTRODEC_IOC_MAGIC, 29)
|
||||
|
||||
#define HANTRODEC_IOC_MAXNR 29
|
||||
|
||||
#endif /* !_UAPI_HANTRODEC_H_ */
|
Loading…
Reference in New Issue