summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--[-rwxr-xr-x]Media.mk1
-rw-r--r--drivers/amvdec_ports/Makefile1
-rw-r--r--drivers/amvdec_ports/aml_vcodec_adapt.c112
-rw-r--r--drivers/amvdec_ports/aml_vcodec_adapt.h5
-rw-r--r--drivers/amvdec_ports/aml_vcodec_dec.c992
-rw-r--r--drivers/amvdec_ports/aml_vcodec_dec.h2
-rw-r--r--drivers/amvdec_ports/aml_vcodec_dec_drv.c122
-rw-r--r--drivers/amvdec_ports/aml_vcodec_dec_pm.c206
-rw-r--r--drivers/amvdec_ports/aml_vcodec_dec_pm.h34
-rw-r--r--drivers/amvdec_ports/aml_vcodec_drv.h188
-rw-r--r--drivers/amvdec_ports/aml_vcodec_util.c34
-rw-r--r--drivers/amvdec_ports/aml_vcodec_util.h90
-rw-r--r--drivers/amvdec_ports/aml_vcodec_vfm.c28
-rw-r--r--drivers/amvdec_ports/decoder/aml_h264_parser.c81
-rw-r--r--drivers/amvdec_ports/decoder/aml_h264_parser.h1
-rw-r--r--drivers/amvdec_ports/decoder/aml_hevc_parser.c133
-rw-r--r--drivers/amvdec_ports/decoder/aml_hevc_parser.h1
-rw-r--r--drivers/amvdec_ports/decoder/aml_mjpeg_parser.c34
-rw-r--r--drivers/amvdec_ports/decoder/aml_mjpeg_parser.h1
-rw-r--r--drivers/amvdec_ports/decoder/aml_mpeg12_parser.h1
-rw-r--r--drivers/amvdec_ports/decoder/aml_mpeg4_parser.c178
-rw-r--r--drivers/amvdec_ports/decoder/aml_mpeg4_parser.h1
-rw-r--r--drivers/amvdec_ports/decoder/aml_vp9_parser.c26
-rw-r--r--drivers/amvdec_ports/decoder/aml_vp9_parser.h1
-rw-r--r--drivers/amvdec_ports/decoder/vdec_h264_if.c223
-rw-r--r--drivers/amvdec_ports/decoder/vdec_hevc_if.c194
-rw-r--r--drivers/amvdec_ports/decoder/vdec_mjpeg_if.c210
-rw-r--r--drivers/amvdec_ports/decoder/vdec_mpeg12_if.c304
-rw-r--r--drivers/amvdec_ports/decoder/vdec_mpeg4_if.c209
-rw-r--r--drivers/amvdec_ports/decoder/vdec_vp9_if.c195
-rw-r--r--drivers/amvdec_ports/vdec_drv_if.c6
-rw-r--r--drivers/amvdec_ports/vdec_drv_if.h21
-rw-r--r--drivers/common/chips/chips.c1
-rw-r--r--drivers/common/chips/decoder_cpu_ver_info.c8
-rw-r--r--drivers/common/chips/decoder_cpu_ver_info.h1
-rw-r--r--drivers/common/firmware/firmware_drv.c9
-rw-r--r--drivers/common/firmware/firmware_type.c1
-rw-r--r--drivers/common/firmware/firmware_type.h1
-rw-r--r--drivers/common/media_clock/clk/clk.c3
-rw-r--r--drivers/common/media_clock/clk/clkg12.c5
-rw-r--r--drivers/frame_provider/decoder/Makefile1
-rw-r--r--drivers/frame_provider/decoder/avs/avs.c60
-rw-r--r--drivers/frame_provider/decoder/avs2/avs2_bufmgr.c12
-rw-r--r--drivers/frame_provider/decoder/avs2/avs2_global.h3
-rw-r--r--drivers/frame_provider/decoder/avs2/vavs2.c115
-rw-r--r--drivers/frame_provider/decoder/avs_multi/Makefile2
-rw-r--r--drivers/frame_provider/decoder/avs_multi/avs_multi.c1633
-rw-r--r--drivers/frame_provider/decoder/avs_multi/avsp_trans_multi.c5065
-rw-r--r--drivers/frame_provider/decoder/h264/vh264.c58
-rw-r--r--drivers/frame_provider/decoder/h264_multi/h264_dpb.c50
-rw-r--r--drivers/frame_provider/decoder/h264_multi/h264_dpb.h34
-rw-r--r--drivers/frame_provider/decoder/h264_multi/vmh264.c1043
-rw-r--r--drivers/frame_provider/decoder/h265/vh265.c707
-rw-r--r--drivers/frame_provider/decoder/mjpeg/vmjpeg_multi.c60
-rw-r--r--drivers/frame_provider/decoder/mpeg12/vmpeg12_multi.c595
-rw-r--r--drivers/frame_provider/decoder/mpeg4/vmpeg4.c5
-rw-r--r--drivers/frame_provider/decoder/mpeg4/vmpeg4_multi.c80
-rw-r--r--drivers/frame_provider/decoder/utils/amvdec.c5
-rw-r--r--drivers/frame_provider/decoder/utils/frame_check.c178
-rw-r--r--drivers/frame_provider/decoder/utils/frame_check.h4
-rw-r--r--drivers/frame_provider/decoder/utils/vdec.c530
-rw-r--r--drivers/frame_provider/decoder/utils/vdec.h18
-rw-r--r--drivers/frame_provider/decoder/utils/vdec_input.c12
-rw-r--r--drivers/frame_provider/decoder/utils/vdec_input.h3
-rw-r--r--drivers/frame_provider/decoder/utils/vdec_v4l2_buffer_ops.c92
-rw-r--r--drivers/frame_provider/decoder/utils/vdec_v4l2_buffer_ops.h7
-rw-r--r--drivers/frame_provider/decoder/vav1/Makefile2
-rw-r--r--drivers/frame_provider/decoder/vav1/aom_av1_define.h171
-rw-r--r--drivers/frame_provider/decoder/vav1/av1_bufmgr.c3392
-rw-r--r--drivers/frame_provider/decoder/vav1/av1_global.h2310
-rw-r--r--drivers/frame_provider/decoder/vav1/vav1.c9946
-rw-r--r--drivers/frame_provider/decoder/vav1/vav1.h22
-rw-r--r--drivers/frame_provider/decoder/vc1/vvc1.c46
-rw-r--r--drivers/frame_provider/decoder/vp9/vvp9.c449
-rw-r--r--drivers/frame_sink/encoder/h264/encoder.c2
-rw-r--r--drivers/stream_input/Makefile5
-rw-r--r--drivers/stream_input/amports/amstream.c263
-rw-r--r--drivers/stream_input/parser/demux/aml_dvb.h5
-rw-r--r--drivers/stream_input/parser/demux/hw_demux/demod_gt.h62
-rw-r--r--drivers/stream_input/parser/demux/hw_demux/frontend.c293
-rw-r--r--drivers/stream_input/parser/dvb_common.c17
-rw-r--r--drivers/stream_input/parser/dvb_common.h26
-rw-r--r--drivers/stream_input/parser/esparser.c15
-rw-r--r--drivers/stream_input/parser/hw_demux/aml_demod_gt.h87
-rw-r--r--drivers/stream_input/parser/hw_demux/aml_dmx.c270
-rw-r--r--drivers/stream_input/parser/hw_demux/aml_dvb.c445
-rw-r--r--drivers/stream_input/parser/hw_demux/aml_dvb.h32
-rw-r--r--drivers/stream_input/parser/streambuf.c9
-rw-r--r--drivers/stream_input/parser/tsdemux.c14
-rw-r--r--drivers/stream_input/parser/tsdemux.h1
-rw-r--r--drivers/stream_input/tv_frontend/Makefile16
-rw-r--r--drivers/stream_input/tv_frontend/aml_fe.c1372
-rw-r--r--drivers/stream_input/tv_frontend/aml_fe.h213
-rw-r--r--drivers/stream_input/tv_frontend/atv_demod/atvdemod_frontend.c791
-rw-r--r--drivers/stream_input/tv_frontend/atv_demod/atvdemod_func.c2163
-rw-r--r--drivers/stream_input/tv_frontend/atv_demod/atvdemod_func.h323
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/aml_demod.c725
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/amlfrontend.c1402
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/demod_func.c2996
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/dvbc_func.c1331
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/dvbt_func.c2188
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/i2c_func.c42
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/acf_filter_coefficient.h414
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/addr_dtmb_che.h77
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/addr_dtmb_che_bit.h266
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/addr_dtmb_front.h70
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/addr_dtmb_front_bit.h331
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/addr_dtmb_sync.h53
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/addr_dtmb_sync_bit.h110
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/addr_dtmb_top.h90
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/addr_dtmb_top_bit.h178
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/aml_dtv_demod_reg.h28
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/amlfrontend.h86
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/include/demod_func.h626
-rw-r--r--drivers/stream_input/tv_frontend/dtv_demod/tuner_func.c189
-rw-r--r--firmware/video_ucode.bin14148
116 files changed, 25845 insertions, 36303 deletions
diff --git a/drivers/stream_input/tv_frontend/dtv_demod/include/demod_func.h b/drivers/stream_input/tv_frontend/dtv_demod/include/demod_func.h
deleted file mode 100644
index 4c9d281..0000000
--- a/drivers/stream_input/tv_frontend/dtv_demod/include/demod_func.h
+++ b/dev/null
@@ -1,626 +0,0 @@
-/*
-* Copyright (C) 2017 Amlogic, Inc. All rights reserved.
-*
-* 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.,
-* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-*
-* Description:
-*/
-#ifdef DEMOD_FUNC_H
-#else
-#define DEMOD_FUNC_H
-
-#include <linux/types.h>
-/* #include <mach/am_regs.h> */
-/*#include <mach/register.h>
- * #include <mach/avosstyle_io.h>
- #include <mach/io.h>
-*/
-#include <linux/dvb/aml_demod.h>
-#include "aml_fe.h"
-#include "amlfrontend.h"
-#include "addr_dtmb_top.h"
-#include "c_stb_define.h"
-#include "c_stb_regs_define.h"
-#include <linux/io.h>
-
-/* #define G9_TV */
-#define GX_TV
-#define safe_addr
-
-#define PWR_ON 1
-#define PWR_OFF 0
-
-#define dtmb_mobile_mode
-
-
-/* void __iomem *meson_reg_demod_map[1024]; */
-
-#define IO_CBUS_PHY_BASE (0xc0800000)
-
-#ifdef safe_addr
-#define IO_DEMOD_BASE (0xc8844000)
-#define IO_AOBUS_BASE (0xc8100000)
-#define IO_HIU_BASE (0xc883c000)
-#else
-#define IO_DEMOD_BASE (0xda844000)
-#define IO_AOBUS_BASE (0xda100000)
-#define IO_HIU_BASE (0xda83c000)
-#endif
-
-#define DEMOD_REG_OFFSET(reg) (reg & 0xfffff)
-#define DEMOD_REG_ADDR(reg) (IO_DEMOD_BASE + DEMOD_REG_OFFSET(reg))
-
-#define DEMOD_CBUS_REG_OFFSET(reg) (reg << 2)
-#define DEMOD_CBUS_REG_ADDR(reg) (IO_CBUS_PHY_BASE + \
- DEMOD_CBUS_REG_OFFSET(reg))
-
-#define DEMOD_AOBUS_REG_OFFSET(reg) ((reg))
-#define DEMOD_AOBUS_REG_ADDR(reg) (IO_AOBUS_BASE + \
- DEMOD_AOBUS_REG_OFFSET(reg))
-
-/* #define DEMOD_BASE APB_REG_ADDR(0x20000) */
-#define DEMOD_BASE DEMOD_REG_ADDR(0x0) /* 0xc8020000 */
-
-/* #define DEMOD_BASE 0xc8020000 */
-#define DTMB_BASE (DEMOD_BASE + 0x000)
-#define DVBT_BASE (DEMOD_BASE + 0x000)
-#define ISDBT_BASE (DEMOD_BASE + 0x000)
-#define QAM_BASE (DEMOD_BASE + 0x400)
-#define ATSC_BASE (DEMOD_BASE + 0x800)
-#define DEMOD_CFG_BASE (DEMOD_BASE + 0xC00)
-
-/* #ifdef TXL_TV */
-#define TXLTV_ADC_RESET_VALUE 0xca6a2110 /* 0xce7a2110 */
-#define TXLTV_ADC_REG1_VALUE 0x5d414260
-#define TXLTV_ADC_REG2_VALUE 0x5ba00384 /* 0x34e0bf81 */
-#define TXLTV_ADC_REG2_VALUE_CRY 0x34e0bf81
-#define TXLTV_ADC_REG3_VALUE 0x4a6a2110 /* 0x4e7a2110 */
-#define TXLTV_ADC_REG4_VALUE 0x02913004
-#define TXLTV_ADC_REG4_CRY_VALUE 0x301
-#define TXLTV_ADC_REG7_VALUE 0x00102038
-#define TXLTV_ADC_REG8_VALUE 0x00000406
-#define TXLTV_ADC_REG9_VALUE 0x00082183
-#define TXLTV_ADC_REGA_VALUE 0x80480240
-#define TXLTV_ADC_REGB_VALUE 0x22000442
-#define TXLTV_ADC_REGC_VALUE 0x00034a00
-#define TXLTV_ADC_REGD_VALUE 0x00005000
-#define TXLTV_ADC_REGE_VALUE 0x00000200
-
-
-/* DADC DPLL */
-#define ADC_REG1 (IO_HIU_BASE + (0xaa << 2))
-#define ADC_REG2 (IO_HIU_BASE + (0xab << 2))
-#define ADC_REG3 (IO_HIU_BASE + (0xac << 2))
-#define ADC_REG4 (IO_HIU_BASE + (0xad << 2))
-
-#define ADC_REG5 (IO_HIU_BASE + (0x73 << 2))
-#define ADC_REG6 (IO_HIU_BASE + (0x74 << 2))
-
-#define ADC_REGB (IO_HIU_BASE + (0xaf << 2))
-#define ADC_REGC (IO_HIU_BASE + (0x9e << 2))
-#define ADC_REGD (IO_HIU_BASE + (0x9f << 2))
-
-/* DADC REG */
-#define ADC_REG7 (IO_HIU_BASE + (0x27 << 2))
-#define ADC_REG8 (IO_HIU_BASE + (0x28 << 2))
-#define ADC_REG9 (IO_HIU_BASE + (0x2a << 2))
-#define ADC_REGA (IO_HIU_BASE + (0x2b << 2))
-#define ADC_REGE (IO_HIU_BASE + (0xbd << 2))
-
-/* #endif */
-
-
-/* #ifdef GX_TV */
-
-#define ADC_RESET_VALUE 0x8a2a2110 /* 0xce7a2110 */
-#define ADC_REG1_VALUE 0x00100228
-#define ADC_REG2_VALUE 0x34e0bf80 /* 0x34e0bf81 */
-#define ADC_REG2_VALUE_CRY 0x34e0bf81
-#define ADC_REG3_VALUE 0x0a2a2110 /* 0x4e7a2110 */
-#define ADC_REG4_VALUE 0x02933800
-#define ADC_REG4_CRY_VALUE 0x301
-#define ADC_REG7_VALUE 0x01411036
-#define ADC_REG8_VALUE 0x00000000
-#define ADC_REG9_VALUE 0x00430036
-#define ADC_REGA_VALUE 0x80480240
-#if 0
-/* DADC DPLL */
-#define ADC_REG1 (IO_HIU_BASE + (0xaa << 2))
-#define ADC_REG2 (IO_HIU_BASE + (0xab << 2))
-#define ADC_REG3 (IO_HIU_BASE + (0xac << 2))
-#define ADC_REG4 (IO_HIU_BASE + (0xad << 2))
-
-#define ADC_REG5 (IO_HIU_BASE + (0x73 << 2))
-#define ADC_REG6 (IO_HIU_BASE + (0x74 << 2))
-
-/* DADC REG */
-#define ADC_REG7 (IO_HIU_BASE + (0x27 << 2))
-#define ADC_REG8 (IO_HIU_BASE + (0x28 << 2))
-#define ADC_REG9 (IO_HIU_BASE + (0x2a << 2))
-#define ADC_REGA (IO_HIU_BASE + (0x2b << 2))
-#endif
-/* #endif */
-
-#ifdef G9_TV
-
-#define ADC_RESET_VALUE 0x8a2a2110 /* 0xce7a2110 */
-#define ADC_REG1_VALUE 0x00100228
-#define ADC_REG2_VALUE 0x34e0bf80 /* 0x34e0bf81 */
-#define ADC_REG2_VALUE_CRY 0x34e0bf81
-#define ADC_REG3_VALUE 0x0a2a2110 /* 0x4e7a2110 */
-#define ADC_REG4_VALUE 0x02933800
-#define ADC_REG4_CRY_VALUE 0x301
-#define ADC_REG7_VALUE 0x01411036
-#define ADC_REG8_VALUE 0x00000000
-#define ADC_REG9_VALUE 0x00430036
-#define ADC_REGA_VALUE 0x80480240
-
-/* DADC DPLL */
-#define ADC_REG1 0x10aa
-#define ADC_REG2 0x10ab
-#define ADC_REG3 0x10ac
-#define ADC_REG4 0x10ad
-
-#define ADC_REG5 0x1073
-#define ADC_REG6 0x1074
-
-/* DADC REG */
-#define ADC_REG7 0x1027
-#define ADC_REG8 0x1028
-#define ADC_REG9 0x102a
-#define ADC_REGA 0x102b
-#endif
-
-#ifdef M6_TV
-#define ADC_REG1_VALUE 0x003b0232
-#define ADC_REG2_VALUE 0x814d3928
-#define ADC_REG3_VALUE 0x6b425012
-#define ADC_REG4_VALUE 0x101
-#define ADC_REG4_CRY_VALUE 0x301
-#define ADC_REG5_VALUE 0x70b
-#define ADC_REG6_VALUE 0x713
-
-#define ADC_REG1 0x10aa
-#define ADC_REG2 0x10ab
-#define ADC_REG3 0x10ac
-#define ADC_REG4 0x10ad
-#define ADC_REG5 0x1073
-#define ADC_REG6 0x1074
-#endif
-
-#define DEMOD_REG1_VALUE 0x0000d007
-#define DEMOD_REG2_VALUE 0x2e805400
-#define DEMOD_REG3_VALUE 0x201
-
-#define DEMOD_REG1 (DEMOD_BASE + 0xc00)
-#define DEMOD_REG2 (DEMOD_BASE + 0xc04)
-#define DEMOD_REG3 (DEMOD_BASE + 0xc08)
-#define DEMOD_REG4 (DEMOD_BASE + 0xc0c)
-
-/* #define Wr(addr, data) WRITE_CBUS_REG(addr, data)*/
-/* #define Rd(addr) READ_CBUS_REG(addr) */
-
-/*#define Wr(addr, data) *(volatile unsigned long *)(addr) = (data)*/
-/*#define Rd(addr) *(volatile unsigned long *)(addr)*/
-
-enum {
- enable_mobile,
- disable_mobile
-};
-
-enum {
- OPEN_TIME_EQ,
- CLOSE_TIME_EQ
-};
-
-enum {
- AMLOGIC_DTMB_STEP0,
- AMLOGIC_DTMB_STEP1,
- AMLOGIC_DTMB_STEP2,
- AMLOGIC_DTMB_STEP3,
- AMLOGIC_DTMB_STEP4,
- AMLOGIC_DTMB_STEP5, /* time eq */
- AMLOGIC_DTMB_STEP6, /* set normal mode sc */
- AMLOGIC_DTMB_STEP7,
- AMLOGIC_DTMB_STEP8, /* set time eq mode */
- AMLOGIC_DTMB_STEP9, /* reset */
- AMLOGIC_DTMB_STEP10, /* set normal mode mc */
- AMLOGIC_DTMB_STEP11,
-};
-
-enum {
- DTMB_IDLE = 0,
- DTMB_AGC_READY = 1,
- DTMB_TS1_READY = 2,
- DTMB_TS2_READY = 3,
- DTMB_FE_READY = 4,
- DTMB_PNPHASE_READY = 5,
- DTMB_SFO_INIT_READY = 6,
- DTMB_TS3_READY = 7,
- DTMB_PM_INIT_READY = 8,
- DTMB_CHE_INIT_READY = 9,
- DTMB_FEC_READY = 10
-};
-
-/* i2c functions */
-/* int aml_i2c_sw_test_bus(struct aml_demod_i2c *adap, char *name); */
-int am_demod_i2c_xfer(struct aml_demod_i2c *adap, struct i2c_msg *msgs,
- int num);
-int init_tuner_fj2207(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *adap);
-int set_tuner_fj2207(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *adap);
-
-int get_fj2207_ch_power(void);
-int tuner_get_ch_power(struct aml_fe_dev *adap);
-int tda18273_tuner_set_frequnecy(unsigned int dwFrequency,
- unsigned int dwStandard);
-int dtmb_get_power_strength(int agc_gain);
-
-
-int tuner_set_ch(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c);
-
-/* dvbt */
-int dvbt_set_ch(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c,
- struct aml_demod_dvbt *demod_dvbt);
-
-struct demod_status_ops {
- int (*get_status)(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c);
- int (*get_ber)(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c);
- int (*get_snr)(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c);
- int (*get_strength)(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c);
- int (*get_ucblocks)(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c);
-};
-
-struct demod_status_ops *dvbt_get_status_ops(void);
-
-/* dvbc */
-
-int dvbc_set_ch(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c,
- struct aml_demod_dvbc *demod_dvbc);
-int dvbc_status(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c,
- struct aml_demod_sts *demod_sts);
-int dvbc_isr_islock(void);
-void dvbc_isr(struct aml_demod_sta *demod_sta);
-u32 dvbc_set_qam_mode(unsigned char mode);
-u32 dvbc_get_status(void);
-u32 dvbc_set_auto_symtrack(void);
-int dvbc_timer_init(void);
-void dvbc_timer_exit(void);
-int dvbc_cci_task(void *data);
-int dvbc_get_cci_task(void);
-void dvbc_create_cci_task(void);
-void dvbc_kill_cci_task(void);
-
-/* atsc */
-
-int atsc_set_ch(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c,
- struct aml_demod_atsc *demod_atsc);
-int check_atsc_fsm_status(void);
-
-void atsc_write_reg(int reg_addr, int reg_data);
-
-unsigned long atsc_read_reg(int reg_addr);
-
-unsigned long atsc_read_iqr_reg(void);
-
-int atsc_qam_set(fe_modulation_t mode);
-
-void qam_initial(int qam_id);
-
-/* dtmb */
-
-int dtmb_set_ch(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c,
- struct aml_demod_dtmb *demod_atsc);
-
-void dtmb_reset(void);
-
-int dtmb_check_status_gxtv(struct dvb_frontend *fe);
-int dtmb_check_status_txl(struct dvb_frontend *fe);
-
-
-void dtmb_write_reg(int reg_addr, int reg_data);
-int dtmb_read_reg(int reg_addr);
-void dtmb_register_reset(void);
-
-/* demod functions */
-unsigned long apb_read_reg_collect(unsigned long addr);
-void apb_write_reg_collect(unsigned int addr, unsigned int data);
-void apb_write_reg(unsigned int reg, unsigned int val);
-unsigned long apb_read_reg_high(unsigned long addr);
-unsigned long apb_read_reg(unsigned long reg);
-int app_apb_write_reg(int addr, int data);
-int app_apb_read_reg(int addr);
-
-void demod_set_cbus_reg(unsigned int data, unsigned int addr);
-unsigned int demod_read_cbus_reg(unsigned int addr);
-void demod_set_demod_reg(unsigned int data, unsigned int addr);
-unsigned int demod_read_demod_reg(unsigned int addr);
-
-/* extern int clk_measure(char index); */
-
-void ofdm_initial(int bandwidth,
- /* 00:8M 01:7M 10:6M 11:5M */
- int samplerate,
- /* 00:45M 01:20.8333M 10:20.7M 11:28.57 */
- int IF,
- /* 000:36.13M 001:-5.5M 010:4.57M 011:4M 100:5M */
- int mode,
- /* 00:DVBT,01:ISDBT */
- int tc_mode
- /* 0: Unsigned, 1:TC */);
-
-void monitor_isdbt(void);
-void demod_set_reg(struct aml_demod_reg *demod_reg);
-void demod_get_reg(struct aml_demod_reg *demod_reg);
-
-/* void demod_calc_clk(struct aml_demod_sta *demod_sta); */
-int demod_set_sys(struct aml_demod_sta *demod_sta,
- struct aml_demod_i2c *demod_i2c,
- struct aml_demod_sys *demod_sys);
-/* int demod_get_sys(struct aml_demod_i2c *demod_i2c, */
-/* struct aml_demod_sys *demod_sys); */
-/* int dvbt_set_ch(struct aml_demod_sta *demod_sta, */
-/* struct aml_demod_i2c *demod_i2c, */
-/* struct aml_demod_dvbt *demod_dvbt); */
-/* int tuner_set_ch (struct aml_demod_sta *demod_sta, */
-/* struct aml_demod_i2c *demod_i2c); */
-
-/* typedef char int8_t; */
-/* typedef short int int16_t; */
-/* typedef int int32_t; */
-/* typedef long int64_t; */
-/*typedef unsigned char uint8_t;
- * typedef unsigned short int uint16_t;
- * typedef unsigned int uint32_t;
- * typedef unsigned long uint64_t;
- */
-
-/*typedef unsigned char u8_t;
- * typedef signed char s8_t;
- * typedef unsigned short u16_t;
- * typedef signed short s16_t;
- * typedef unsigned int u32_t;
- * typedef signed int s32_t;
- * typedef unsigned long u64_t;
- * typedef signed long s64_t;
- */
-
-/* #define extadc */
-
-/* for g9tv */
-void adc_dpll_setup(int clk_a, int clk_b, int clk_sys);
-void demod_power_switch(int pwr_cntl);
-
-union adc_pll_cntl {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned pll_m:9;
- unsigned pll_n:5;
- unsigned pll_od0:2;
- unsigned pll_od1:2;
- unsigned pll_od2:2;
- unsigned pll_xd0:6;
- unsigned pll_xd1:6;
- } b;
-};
-
-union adc_pll_cntl2 {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned output_mux_ctrl:4;
- unsigned div2_ctrl:1;
- unsigned b_polar_control:1;
- unsigned a_polar_control:1;
- unsigned gate_ctrl:6;
- unsigned tdc_buf:8;
- unsigned lm_s:6;
- unsigned lm_w:4;
- unsigned reserved:1;
- } b;
-};
-
-union adc_pll_cntl3 {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned afc_dsel_in:1;
- unsigned afc_dsel_bypass:1;
- unsigned dco_sdmck_sel:2;
- unsigned dc_vc_in:2;
- unsigned dco_m_en:1;
- unsigned dpfd_lmode:1;
- unsigned filter_acq1:11;
- unsigned enable:1;
- unsigned filter_acq2:11;
- unsigned reset:1;
- } b;
-};
-
-union adc_pll_cntl4 {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned reve:12;
- unsigned tdc_en:1;
- unsigned dco_sdm_en:1;
- unsigned dco_iup:2;
- unsigned pvt_fix_en:1;
- unsigned iir_bypass_n:1;
- unsigned pll_od3:2;
- unsigned filter_pvt1:4;
- unsigned filter_pvt2:4;
- unsigned reserved:4;
- } b;
-};
-
-/* ///////////////////////////////////////////////////////////////// */
-
-union demod_dig_clk {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned demod_clk_div:7;
- unsigned reserved0:1;
- unsigned demod_clk_en:1;
- unsigned demod_clk_sel:2;
- unsigned reserved1:5;
- unsigned adc_extclk_div:7; /* 34 */
- unsigned use_adc_extclk:1; /* 1 */
- unsigned adc_extclk_en:1; /* 1 */
- unsigned adc_extclk_sel:3; /* 1 */
- unsigned reserved2:4;
- } b;
-};
-
-union demod_adc_clk {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned pll_m:9;
- unsigned pll_n:5;
- unsigned pll_od:2;
- unsigned pll_xd:5;
- unsigned reserved0:3;
- unsigned pll_ss_clk:4;
- unsigned pll_ss_en:1;
- unsigned reset:1;
- unsigned pll_pd:1;
- unsigned reserved1:1;
- } b;
-};
-
-union demod_cfg0 {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned mode:4;
- unsigned ts_sel:4;
- unsigned test_bus_clk:1;
- unsigned adc_ext:1;
- unsigned adc_rvs:1;
- unsigned adc_swap:1;
- unsigned adc_format:1;
- unsigned adc_regout:1;
- unsigned adc_regsel:1;
- unsigned adc_regadj:5;
- unsigned adc_value:10;
- unsigned adc_test:1;
- unsigned ddr_sel:1;
- } b;
-};
-
-union demod_cfg1 {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned reserved:8;
- unsigned ref_top:2;
- unsigned ref_bot:2;
- unsigned cml_xs:2;
- unsigned cml_1s:2;
- unsigned vdda_sel:2;
- unsigned bias_sel_sha:2;
- unsigned bias_sel_mdac2:2;
- unsigned bias_sel_mdac1:2;
- unsigned fast_chg:1;
- unsigned rin_sel:3;
- unsigned en_ext_vbg:1;
- unsigned en_cmlgen_res:1;
- unsigned en_ext_vdd12:1;
- unsigned en_ext_ref:1;
- } b;
-};
-
-union demod_cfg2 {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned en_adc:1;
- unsigned biasgen_ibipt_sel:2;
- unsigned biasgen_ibic_sel:2;
- unsigned biasgen_rsv:4;
- unsigned biasgen_en:1;
- unsigned biasgen_bias_sel_adc:2;
- unsigned biasgen_bias_sel_cml1:2;
- unsigned biasgen_bias_sel_ref_op:2;
- unsigned clk_phase_sel:1;
- unsigned reserved:15;
- } b;
-};
-
-union demod_cfg3 {
- /** raw register data */
- uint32_t d32;
- /** register bits */
- struct {
- unsigned dc_arb_mask:3;
- unsigned dc_arb_enable:1;
- unsigned reserved:28;
- } b;
-};
-
-struct atsc_cfg {
- int adr;
- int dat;
- int rw;
-};
-
-struct agc_power_tab {
- char name[128];
- int level;
- int ncalcE;
- int *calcE;
-};
-
-struct dtmb_cfg {
- int dat;
- int adr;
- int rw;
-};
-
-void dtvpll_lock_init(void);
-void dtvpll_init_flag(int on);
-void demod_set_irq_mask(void);
-void demod_clr_irq_stat(void);
-void demod_set_adc_core_clk(int adc_clk, int sys_clk, int dvb_mode);
-void demod_set_adc_core_clk_fix(int clk_adc, int clk_dem);
-void calculate_cordic_para(void);
-void ofdm_read_all_regs(void);
-extern int aml_fe_analog_set_frontend(struct dvb_frontend *fe);
-
-#endif