blob: 4c9d28193b1827981a259f82b30846d6fa17e021 [file] [log] [blame]
/*
* 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